当前位置:首页 > PHP教程 > php应用 > 列表

PHP连接MSSQL方法汇总

发布:smiling 来源: PHP粉丝网  添加日期:2021-07-09 11:57:04 浏览: 评论:0 

这篇文章主要为大家详细汇总了PHP连接MSSQL的实现方法,帮助大家更好的实现PHP与MSSQL的连接,感兴趣的小伙伴们可以参考一下。

为了能让PHP连接MSSQL,系统需要安装MSSQL,PHP,且在PHP.ini中的配置中,将 ;extension=php_mssql.dll前面的;去掉

1.连接MSSQL

  1. $conn=mssql_connect("实例名或者服务器IP","用户名","密码"); 
  2.  
  3. //测试连接 
  4. if($conn
  5. echo "连接成功"

2.选择要连接的数据库     

mssql_select_db("dbname");

3.执行查询

  1. $rs = mssql_query("select top 1 id,username from tbname",$conn); 
  2. // 或者直接执行update,insert等语句,可以不用为返回结果赋值 
  3. mssql_query("update tbname set username='niunv' where id=1"); 

4.获取记录集行数     

echo mssql_num_rows($rs);

5.获取记录集

  1. if($row=mssql_fetch_array($rs)) 
  2.  { 
  3.  $id = $row[0];//获取ID字段值 
  4.  $username = $row[1];//获取username字段值 
  5.  } 

6.获取新增记录的ID

将id字段设置为IDENTITY字段,执行insert语句以后,就会产生一个 @@IDENTITY 全局变量值,查询出来就是最后一条新增记录的ID了.

  1. mssql_query("insert into tbname(username) values ('nv')",$conn);  
  2. $rs = mssql_query("select @@IDENTITY as id",$conn); 
  3. if($row=mssql_fetch_array($rs)) 
  4. echo $row[0]; 

7.释放记录集

mssql_free_result($rs);

8.关闭连接

mssql_close($conn); 

注:用PHP操作MSSQL比在ASP连接MYSQL要简单,所以,当需要MSSQL与MYSQL并存时,用PHP连接MSSQL来操作MYSQL与MSSQL并存比较简单好用.如果是ASP连接MYSQL,需要安装一个MYSQL驱动,默认windows的ODBC没有安装,很遗憾...   

在web服务器上至少安装了mssql的客户端   

打开php.ini把;extension=php_mssql.dll   前面的分号去掉 

有必要话:需要制定extension_dir 

推荐使用   php<=4.0.9     <=5.0.3目前   我还没有连接成功过4.010和   5.0.3 

数据库的 连接分页可以到phpe.net上获取到相应的class   

下面是我修改的 一个class   

  1. <?php  
  2. /**  
  3. *mssql 数据库连接类  
  4. **/ 
  5. class SQL{  
  6.  
  7. var $server;  
  8. var $userName;  
  9. var $passWord;  
  10. var $dataBase;  
  11.  
  12. var $linkID = 0;  
  13. var $queryResult;  
  14. var $lastInsertID;  
  15.  
  16. var $pageNum = 0;//分页用---共有几条数据  
  17. var $ER;  
  18.  
  19. /**  
  20. *构造函数  
  21. **/ 
  22. function  SQL($Server='',$UserName='',$PassWord='',$DataBase=''){  
  23. $this->server = $Server;  
  24. $this->userName = $UserName;  
  25. $this->passWord = $PassWord;  
  26. $this->dataBase = $DataBase;  
  27. }  
  28. /**  
  29. *数据库连接  
  30. **/ 
  31. function db_connect(){  
  32. $this->linkID = mssql_pconnect($this->server,$this->userName,$this->passWord);  
  33. if(!$this->linkID){  
  34. $this->ER = "db_connect($this->server,$this->userName,$this->passWord) error";  
  35. return 0;  
  36. }  
  37. if (!mssql_select_db($this->dataBase,$this->linkID)) {  
  38. $this->ER = "mssql_select_db($this->dataBase,$this->lastInsertID) error";  
  39. return 0;  
  40. }  
  41. return $this->linkID;  
  42. }  
  43.  
  44. /**public  
  45. *  function: Check the database, if exist then select  
  46. *  exist: return 1  
  47. *  not exist: return 0  
  48. */ 
  49. function selectDatabase(){  
  50. if(mssql_select_db($this->dataBase))  
  51. return 1;  
  52. else 
  53. return 0;  
  54. }  
  55.  
  56. /**  
  57. *数据操作  
  58. **/ 
  59. function  query($Str){  
  60. if ($this->linkID == 0) {  
  61. $this->ER = "数据库还没有连接!!";  
  62. }  
  63.  
  64.    $this->queryResult = mssql_query($Str);   
  65. //$this->queryResult = mssql_query($Str,$this->linkID);  
  66. if (!$this->queryResult) {  
  67.    
  68.  
  69. $this->ER = "$Str.没有操作成功,query error!!";  
  70. return 0;//****************对于php 4.3.9以上版本的错误用1  
  71. }  
  72. return $this->queryResult;  
  73. }  
  74.  
  75. /**  
  76. *数据获取  
  77. **/  
  78. function fetch_array($result){  
  79. if($result != ""$this->queryResult = $result;  
  80. $rec =mssql_fetch_array($this->queryResult);  
  81.  
  82. if(is_array($rec)){  
  83. return $rec;  
  84.  
  85. }  
  86.  
  87. //$this->ER = "没有获取数据!";  
  88. return 0;  
  89. }  
  90.  
  91. /**public  
  92. *  function: Free the Query Result  
  93. *  success return 1  
  94. *  failed: return 0  
  95. */ 
  96. function freeResult($result=""){  
  97. if($result != ""$this->queryResult = $result;  
  98. return mssql_free_result($this->queryResult);  
  99. }  
  100.     
  101. /**  
  102. *获取影响的的行数  
  103. *获取操作过的行数  
  104. **/ 
  105. function num_rows($result=""){  
  106. if ($result != "") {  
  107. $this->queryResult = $result;  
  108. $row = mssql_num_rows($this->queryResult);  
  109. return $row;  
  110. }  
  111. }  
  112.     
  113. /**  
  114. *获取查询结果---多个  
  115. **/ 
  116. function result_ar($str=''){  
  117. if (emptyempty($str)) {  
  118. return 0;  
  119. }  
  120. $back = array();  
  121. $this->queryResult = $this->query($str);  
  122.  
  123. while ($row = $this->fetch_array($this->queryResult)) {  
  124. $back[] = $row;  
  125. }  
  126. return $back;  
  127. }  
  128.  
  129. /**  
  130. *数据库信息分页  
  131. *$Result 数据库操作  
  132. *str ==sql语句   
  133. *page ==第几页  
  134. *showNum ==显示几页  
  135. */ 
  136. function page($Str,$Page=0,$ShowNum=5){  
  137. $back = array();//返回数据  
  138. $maxNum = 0;  
  139. if ($Str == "") {  
  140. $this->ER = "没有数据";  
  141. return  0;  
  142. }  
  143. $this->queryResult = $this->query($Str);  
  144. if($this->queryResult){  
  145. if($Page==""){  
  146. $nopa=0;  
  147. }else{  
  148. $nopa = ($Page-1)*$ShowNum;  
  149. if ($nopa<0) {  
  150. $nopa = 0;  
  151. }  
  152. }  
  153. $maxNum=$this->num_rows($this->queryResult);  
  154. $k=0;  
  155. $i=0;  
  156. $dd=$this->fetch_array($this->queryResult);  
  157.  
  158. while($dd&&$nopa<=$maxNum&&$i<$ShowNum){  
  159. if($nopa >= $maxNum)  $nopa = $maxNum;  
  160. mssql_data_seek($this->queryResult,$nopa);  
  161.  
  162. $row=$this->fetch_array($this->queryResult);  
  163.  
  164. $nopa++;  
  165. $i++;  
  166. $back[] = $row;  
  167.  
  168. if ($nopa >=$maxNum) {  
  169. break;  
  170. }  
  171. }  
  172. }  
  173. $this->pageNum = $maxNum;  
  174. return $back;  
  175. }  
  176.  
  177. /**  
  178. *分页的html页码  
  179. */ 
  180. function  page_html($DataNum=0,$Page=1,$ShowNum=3,$web,$Post=''){  
  181. if ($DataNum == 0) {  
  182. $back =  "没有要查询的数据";  
  183. }else {  
  184. if ($ShowNum<=0) {  
  185. $ShowNum = 3;  
  186. }  
  187. if ($Page<=0) {  
  188. $Page = 1;  
  189. }  
  190. if (emptyempty($web)) {  
  191. $web = "#";  
  192. }  
  193. $pageNum = ceil($DataNum/$ShowNum);  
  194. if ($Page <= 1) {  
  195. $top =  "首页<<";  
  196. }else {  
  197. $top = "<a href='".$web."?page=0&".$Post."' target='_self'>首页<< </a>";  
  198. }  
  199. if ($Page !==1) {  
  200. $upPage =  "<a href='".$web."?page=".($Page-1)."&".$Post."' target='_self'>上一页</a>";  
  201. }else {  
  202. $upPage = "上一页";  
  203. }  
  204. if ($Page < $pageNum) {  
  205. $downPage = "<a href='".$web."?page=".($Page+1)."&".$Post."' target='_self'>下一页</a>";  
  206. }else {  
  207. $downPage = "下一页";  
  208. }  
  209. if ($Page == $pageNum) {  
  210. $foot = ">>尾页";  
  211. }else {  
  212. $foot = "<a href='".$web."?page=".$pageNum."&".$Post."' target='_self'> >>尾页</a>";  
  213. }  
  214.  
  215. $back = <<<EOT  
  216.  
  217. 共 $pageNum 页 &nbsp;&nbsp;  
  218. 第 $Page/$pageNum 页 $top &nbsp; $upPage &nbsp; $downPage  &nbsp; $foot 
  219. EOT;  
  220. }  
  221. return $back;  
  222. }  
  223. }//end class  
  224. ?> 

以上就是PHP连接MSSQL方法的总结,希望对大家的学习有所帮助。

Tags: PHP连接MSSQL

分享到: