mysql是非持繼串連函數而mysqli是永遠串連函數。也就是說
mysql每次連結都會開啟一個串連的進程而mysqli多次運行mysqli將使用同一串連進程,從而減少了伺服器的開銷
有些朋友在編程的時候,使用new mysqli('localhost', usenamer', 'password', 'databasename');總是報錯,Fatal error: Class 'mysqli' not found in d:...
mysqli類不是php內建的嗎?
不是預設開啟的,win下要改php.ini,去掉php_mysqli.dll前的;,linux下要把mysqli編譯進去
執行個體
mysql.dll(可以理解為函數式的方式):
| 代碼如下 |
複製代碼 |
$conn = mysql_connect(‘localhost’, ‘user’, ‘password’); //串連mysql資料庫 mysql_select_db(‘data_base’); //選擇資料庫 $result = mysql_query(‘select * from data_base’);//這裡有第二個選擇性參數,指定開啟的串連 $row = mysql_fetch_row( $result ) ) //為了簡單,這裡只取一行資料 echo $row[0]; //輸出第一個欄位的值 |
mysql_pconnect開啟的串連不會關閉(即使調用mysql_close也不會關閉,因為對其無效),
類似於串連緩衝池,如果下次有來自於同一個機器的同一個使用者名稱
對同一個資料庫的串連,php會自動使用上次已經建立的串連,而不需要再重建立立一個。
好處:是省去了每次與資料庫建立串連的開銷,
壞處:是需要浪費一些記憶體,佔用一些串連,
所以如果使用者訪問量大的時候會出現錯誤,要把mysql的max_connections參數改大一點, 或者使用mysql_connect()就解決問題。
mysqli也有過程式的方式,只不過開始貫以mysqli的首碼,其他都差不多。如果mysqli以過程式的方式操作的話,有些函數必須指定資源,比如說 mysqli_query(資源標識,SQL語句),並且資源標識的參數是放在前面的,而mysql_query(SQL語句,’可選’)的資源標識是放在後面的,並且可以不指定,它預設是上一個開啟的串連或資源。
執行個體
mysqli.dll(對象方式):
| 代碼如下 |
複製代碼 |
$conn = new mysqli(‘localhost’, ‘user’, ‘password’,'data_base’); //這裡的串連是new出來的,最後一個參數是直接指定資料庫,不用mysql_select_db()了 //也可以構造時候不指定,然後 $conn -> select_db(‘data_base’) $result = $conn -> query( ‘select * from data_base’ ); $row = $result -> fetch_row(); //取一行資料 echo row[0]; //輸出第一個欄位的值 |
-可以和mysql.dll一樣的方式使用;
-支援OO介面,簡簡單單調用;
-支援MYSQL4.引入的新特性;
-通過mysqli_init() 等相關函數,可以設定進階串連選項
一般安裝時選擇MySQL,因為有的伺服器不支援MySQLi。