五月综合缴情婷婷六月,色94色欧美sute亚洲线路二,日韩制服国产精品一区,色噜噜一区二区三区,香港三级午夜理伦三级三

您現(xiàn)在的位置: 365建站網(wǎng) > 365文章 > php連接mssql(sql server)數(shù)據(jù)庫的方法總結(jié)

php連接mssql(sql server)數(shù)據(jù)庫的方法總結(jié)

文章來源:365jz.com     點(diǎn)擊數(shù):536    更新時(shí)間:2018-01-07 09:27   參與評論

php連接mssql(sql server)數(shù)據(jù)庫的方法總結(jié)
 

一開始我下載的php版本是5.93的,下載下來添加環(huán)境變量等等搞了半天后,phpinfo()這個(gè)函數(shù)終于成功的運(yùn)行在瀏覽器中了。然后當(dāng)我在滿世界的找php_mssql.dll,才發(fā)現(xiàn)在5.3以及以上版本的php中已經(jīng)不是原生態(tài)的支持mssql了。

好不容易找到了微軟Microsoft Drivers 3.0 for PHP for SQL Server,心想微軟的東西應(yīng)該做的可以,卻無奈的發(fā)現(xiàn)SQLSRV30.EXE沒有辦法運(yùn)行:“SQLSRV30.EXE 不是有效的win32程序”。

 


首先,php.ini文件中;extension=php_pdo_mssql.dll ;extension=php_pdo_odbc.dll 前面的分號去掉,對應(yīng)的使哪種方式連接mssql。注意要重啟服務(wù)使其生效。

一、建立連接

1、odbc

首先,在php程序所在的服務(wù)器設(shè)置odbc。這里32位和64位操作系統(tǒng)有區(qū)別。32位的從控制面板中管理工具中的數(shù)據(jù)源(odbc)直接建立就可以了,64位的要運(yùn)行C:\Windows\SysWOW64\odbcad32.exe

從這里面設(shè)置。注意:上面只的是數(shù)據(jù)庫服務(wù)器為32為的,數(shù)據(jù)源設(shè)置服務(wù)器為32位和64位兩種的情況。只要兩個(gè)服務(wù)器建立的數(shù)據(jù)源位數(shù)一致就好。

下面是odbc建立連接代碼。

 

$con = odbc_connect('odbc名稱','用戶名','密碼');

2、連接mssql2000

 

 

$con = mssql_connect('數(shù)據(jù)庫地址','用戶名','密碼');

 

3、連接mssql2008

$connectionInfo =  array("UID"=>用戶名,"PWD"=>密碼,"Database"=>"數(shù)據(jù)庫名稱");
$con = sqlsrv_connect( 數(shù)據(jù)庫地址,$connectionInfo);

 

二、輸入查詢代碼

這個(gè)都一樣,可以直接寫入,也可以從mssql中驗(yàn)證好后復(fù)制過來。簡單點(diǎn)說就是把一個(gè)sql語句賦值給一個(gè)變量。

類似下面代碼

$query = "SELECT top 12 * 數(shù)據(jù)庫名稱 order by id desc";

三、建立查詢并取出數(shù)據(jù)

 

1、odbc

$result = odbc_do($con,$query);
while(odbc_fetch_row($result))
{
    $變量名稱 = odbc_result($result, "字段名稱");
}

2、連接mssql2000
$result = mssql_query($con, $query);
while($row =mssql_fetch_array($result))
{
    $變量名稱 = $row["字段名稱"];
}

3、連接mssql2008
$result = sqlsrv_query($con, $query);
while($row = sqlsrv_fetch_array($result))
{
    $變量名稱 = $row["字段名稱"];
}

在php5.3及以后的版本中不附帶sqlsrv庫了。所以要從微軟這里下載。

 

四、關(guān)閉連接

這個(gè)沒有什么區(qū)別,分別是odbc_close();和mssql_close()和sqlsrv_close();

 

 為了能讓PHP連接MSSQL,系統(tǒng)需要安裝MSSQL,PHP,且在PHP.ini中的配置中,將 ;extension=php_mssql.dll前面的;去掉

1.連接MSSQL

  $conn=mssql_connect("實(shí)例名或者服務(wù)器IP","用戶名","密碼");

  //測試連接
  if($conn)
  {
  echo "連接成功";
  }

2.選擇要連接的數(shù)據(jù)庫      

 mssql_select_db("dbname");

3.執(zhí)行查詢

$rs = mssql_query("select top 1 id,username from tbname",$conn);
// 或者直接執(zhí)行update,insert等語句,可以不用為返回結(jié)果賦值
mssql_query("update tbname set username='niunv' where id=1");

 4.獲取記錄集行數(shù)      

 echo mssql_num_rows($rs);

5.獲取記錄集     

 if($row=mssql_fetch_array($rs))
  {
  $id = $row[0];//獲取ID字段值
  $username = $row[1];//獲取username字段值
  }

6.獲取新增記錄的ID
       將id字段設(shè)置為IDENTITY字段,執(zhí)行insert語句以后,就會(huì)產(chǎn)生一個(gè) @@IDENTITY 全局變量值,查詢出來就是最后一條新增記錄的ID了.

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

7.釋放記錄集    

 mssql_free_result($rs);

 8.關(guān)閉連接    

 mssql_close($conn);  

       注:用PHP操作MSSQL比在ASP連接MYSQL要簡單,所以,當(dāng)需要MSSQL與MYSQL并存時(shí),用PHP連接MSSQL來操作MYSQL與MSSQL并存比較簡單好用.如果是ASP連接MYSQL,需要安裝一個(gè)MYSQL驅(qū)動(dòng),默認(rèn)windows的ODBC沒有安裝,很遺憾...   

  •   在web服務(wù)器上至少安裝了mssql的客戶端    
  •   打開php.ini把;extension=php_mssql.dll   前面的分號去掉  
  •       有必要話:需要制定extension_dir  
  •   推薦使用   php<=4.0.9     <=5.0.3目前   我還沒有連接成功過4.010和   5.0.3  
  •   數(shù)據(jù)庫的 連接分頁可以到phpe.net上獲取到相應(yīng)的class   

  下面是我修改的 一個(gè)class   

 <?php 
 /** 
 *mssql 數(shù)據(jù)庫連接類 
 **/ 
 class SQL{ 
 
 var $server; 
 var $userName; 
 var $passWord; 
 var $dataBase; 
 
 var $linkID = 0; 
 var $queryResult; 
 var $lastInsertID; 
 
 var $pageNum = 0;//分頁用---共有幾條數(shù)據(jù) 
 var $ER; 
 
 /** 
 *構(gòu)造函數(shù) 
 **/ 
 function  SQL($Server='',$UserName='',$PassWord='',$DataBase=''){ 
 $this->server = $Server; 
 $this->userName = $UserName; 
 $this->passWord = $PassWord; 
 $this->dataBase = $DataBase; 
 } 
 /** 
 *數(shù)據(jù)庫連接 
 **/ 
 function db_connect(){ 
 $this->linkID = mssql_pconnect($this->server,$this->userName,$this->passWord); 
 if(!$this->linkID){ 
 $this->ER = "db_connect($this->server,$this->userName,$this->passWord) error"; 
 return 0; 
 } 
 if (!mssql_select_db($this->dataBase,$this->linkID)) { 
 $this->ER = "mssql_select_db($this->dataBase,$this->lastInsertID) error"; 
 return 0; 
 } 
 return $this->linkID; 
 } 
 
 /**public 
 *  function: Check the database, if exist then select 
 *  exist: return 1 
 *  not exist: return 0 
 */ 
 function selectDatabase(){ 
 if(mssql_select_db($this->dataBase)) 
 return 1; 
 else 
 return 0; 
 } 
 
 /** 
 *數(shù)據(jù)操作 
 **/ 
 function  query($Str){ 
 if ($this->linkID == 0) { 
 $this->ER = "數(shù)據(jù)庫還沒有連接!!"; 
 } 
 
    $this->queryResult = mssql_query($Str);  
 //$this->queryResult = mssql_query($Str,$this->linkID); 
 if (!$this->queryResult) { 
  
 
 $this->ER = "$Str.沒有操作成功,query error?。?quot;; 
 return 0;//****************對于php 4.3.9以上版本的錯(cuò)誤用1 
 } 
 return $this->queryResult; 
 } 
 
 /** 
 *數(shù)據(jù)獲取 
 **/ 
 function fetch_array($result){ 
 if($result != "") $this->queryResult = $result; 
 $rec =mssql_fetch_array($this->queryResult); 
 
 if(is_array($rec)){ 
 return $rec; 
 
 } 
 
 //$this->ER = "沒有獲取數(shù)據(jù)!"; 
 return 0; 
 } 
 
 /**public 
 *  function: Free the Query Result 
 *  success return 1 
 *  failed: return 0 
 */ 
 function freeResult($result=""){ 
 if($result != "") $this->queryResult = $result; 
 return mssql_free_result($this->queryResult); 
 } 
   
 /** 
 *獲取影響的的行數(shù) 
 *獲取操作過的行數(shù) 
 **/ 
 function num_rows($result=""){ 
 if ($result != "") { 
 $this->queryResult = $result; 
 $row = mssql_num_rows($this->queryResult); 
 return $row; 
 } 
 } 
   
 /** 
 *獲取查詢結(jié)果---多個(gè) 
 **/ 
 function result_ar($str=''){ 
 if (empty($str)) { 
 return 0; 
 } 
 $back = array(); 
 $this->queryResult = $this->query($str); 
 
 while ($row = $this->fetch_array($this->queryResult)) { 
 $back[] = $row; 
 } 
 return $back; 
 } 
 
 /** 
 *數(shù)據(jù)庫信息分頁 
 *$Result 數(shù)據(jù)庫操作 
 *str ==sql語句  
 *page ==第幾頁 
 *showNum ==顯示幾頁 
 */ 
 function page($Str,$Page=0,$ShowNum=5){ 
 $back = array();//返回?cái)?shù)據(jù) 
 $maxNum = 0; 
 if ($Str == "") { 
 $this->ER = "沒有數(shù)據(jù)"; 
 return  0; 
 } 
 $this->queryResult = $this->query($Str); 
 if($this->queryResult){ 
 if($Page==""){ 
 $nopa=0; 
 }else{ 
 $nopa = ($Page-1)*$ShowNum; 
 if ($nopa<0) { 
 $nopa = 0; 
 } 
 } 
 $maxNum=$this->num_rows($this->queryResult); 
 $k=0; 
 $i=0; 
 $dd=$this->fetch_array($this->queryResult); 
 
 while($dd&&$nopa<=$maxNum&&$i<$ShowNum){ 
 if($nopa >= $maxNum)  $nopa = $maxNum; 
 mssql_data_seek($this->queryResult,$nopa); 
 
 $row=$this->fetch_array($this->queryResult); 
 
 $nopa++; 
 $i++; 
 $back[] = $row; 
 
 if ($nopa >=$maxNum) { 
 break; 
 } 
 } 
 } 
 $this->pageNum = $maxNum; 
 return $back; 
 } 
 
 /** 
 *分頁的html頁碼 
 */ 
 function  page_html($DataNum=0,$Page=1,$ShowNum=3,$web,$Post=''){ 
 if ($DataNum == 0) { 
 $back =  "沒有要查詢的數(shù)據(jù)"; 
 }else { 
 if ($ShowNum<=0) { 
 $ShowNum = 3; 
 } 
 if ($Page<=0) { 
 $Page = 1; 
 } 
 if (empty($web)) { 
 $web = "#"; 
 } 
 $pageNum = ceil($DataNum/$ShowNum); 
 if ($Page <= 1) { 
 $top =  "首頁<<"; 
 }else { 
 $top = "<a href='".$web."?page=0&".$Post."' target='_self'>首頁<< </a>"; 
 } 
 if ($Page !==1) { 
 $upPage =  "<a href='".$web."?page=".($Page-1)."&".$Post."' target='_self'>上一頁</a>"; 
 }else { 
 $upPage = "上一頁"; 
 } 
 if ($Page < $pageNum) { 
 $downPage = "<a href='".$web."?page=".($Page+1)."&".$Post."' target='_self'>下一頁</a>"; 
 }else { 
 $downPage = "下一頁"; 
 } 
 if ($Page == $pageNum) { 
 $foot = ">>尾頁"; 
 }else { 
 $foot = "<a href='".$web."?page=".$pageNum."&".$Post."' target='_self'> >>尾頁</a>"; 
 } 
 
 $back = <<<EOT 
 
 共 $pageNum 頁    
 第 $Page/$pageNum 頁 $top   $upPage   $downPage    $foot 
 EOT; 
 } 
 return $back; 
 } 
 }//end class 
 ?>

 

1、數(shù)據(jù)庫連接失敗的問題,提示 Fatal error: Call to undefined function mssql_connect() in。

首先要安裝WAMP5(我安裝在D:\wamp),該服務(wù)器默認(rèn)是連接My Sql 數(shù)據(jù)庫,所以要想連接SQL 
Server2005數(shù)據(jù)庫,必須修改php.ini。即去掉;extension=php_mssql.dll前的";",再設(shè)置 
mssql.secure_connection = On。然后檢查 D:/wamp/php/ext/ 中的ntwdblib.dll版本(版本 
2000.2.8.0支持SQL Server2000,版本2000.80.194.0支持SQL Server2005)。修改完后記得重啟整個(gè) 
WAMP5。

2、PHP頁面查詢SQL Server2005中數(shù)據(jù)時(shí),中文顯示亂碼。

這是因?yàn)镾QL Server2005默認(rèn)的是支持gb2312頁面編碼方式,而且php.ini配置與.php頁面編碼不一致, 
所以修改兩個(gè)地方:一是php.ini修改為default_charset = "gb2312";二是將.PHP頁面的編碼方式修改 
過來即可,即<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />。(注: 
Mysql 數(shù)據(jù)庫既支持gb2312編碼又支持utf-8編碼)

3、jquery.js放在根目錄下的inc文件夾中,但PHP頁面無法引用。

WEB頁面使用jquery技術(shù)不跳轉(zhuǎn)頁面實(shí)現(xiàn)后臺(tái)數(shù)據(jù)庫交互,必須引用jquery.js。寫法是<script 
type="text/javascript" src="/inc/jquery.js"></script>

4、PHP頁面使用header("location:shopping_car.php")定向頁面時(shí)出錯(cuò),Warning: Cannot modify 
header information - headers already sent by。

原因:setcookie函數(shù)必須在任何資料輸出至瀏覽器前,就先送出。

解決辦法:頭部最前方設(shè)置ob_start(); 打開緩沖區(qū);和尾部ob_end_flush();//輸出全部內(nèi)容到瀏覽器 

5、如果PHP頁面編碼方式是utf-8,但是頁面中沒有<meta http-equiv="Content-Type" 
content="text/html; charset=utf-8" />。用alert()時(shí),中文顯示亂碼。

解決辦法:一定要在網(wǎng)頁中指定編碼方式為UTF-8,即添加<meta http-equiv="Content-Type" 
content="text/html; charset=utf-8" />,因?yàn)橛衋lert()輸出中文到瀏覽器。

 


Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 
bytes)

今天要用php代碼來處理一個(gè)580M的日志文件,總共有219萬多行記錄,因?yàn)槭?log的文件,在windows下 
面很難將文件按照條數(shù)來分割,于是在linux下用split -l 10000 filename 前綴名 將整個(gè)文件按10000 
行一個(gè)分割成了200多個(gè)小文件,之后用php來循環(huán)處理這200多個(gè)文件,可是執(zhí)行到后來就出現(xiàn)了題目上 
面的錯(cuò)誤:

 

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 
bytes)

去百度了一下,原來是php.ini中的內(nèi)存分配的問題,默認(rèn)php代碼能夠申請到的最大內(nèi)存字節(jié)數(shù)就是 
134217728 bytes,如果代碼執(zhí)行的時(shí)候再需要更多的內(nèi)存,就會(huì)報(bào)錯(cuò)了,于是就將php.ini文件中的配 
置改了一下:


memory_limit = 128M;//將128M改成了256M

但是之后一想,一個(gè)php腳本一次請求的內(nèi)存空間就要超過128M,那不管你以后將memory_limit設(shè)置成多 
大,以后肯定有出問題的時(shí)候。

如對本文有疑問,請?zhí)峤坏浇涣髡搲?,廣大熱心網(wǎng)友會(huì)為你解答??! 點(diǎn)擊進(jìn)入論壇

發(fā)表評論 (536人查看0條評論)
請自覺遵守互聯(lián)網(wǎng)相關(guān)的政策法規(guī),嚴(yán)禁發(fā)布色情、暴力、反動(dòng)的言論。
昵稱:
最新評論
2018年01月07日 09:35游客

很詳細(xì)!O(∩_∩)O謝謝~

------分隔線----------------------------

其它欄目

· 建站教程
· 365學(xué)習(xí)

業(yè)務(wù)咨詢

· 技術(shù)支持
· 服務(wù)時(shí)間:9:00-18:00
365建站網(wǎng)二維碼

Powered by 365建站網(wǎng) RSS地圖 HTML地圖

copyright © 2013-2024 版權(quán)所有 鄂ICP備17013400號