也就是說
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是非持繼串連函數而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編譯進去
mysqli的面向過程的使用: 複製代碼 代碼如下:$conn = mysqli_connect('localhost', 'root', '123', 'db_test') or ('error');
$sql = "select * from db_table";
$query = mysqli_query($conn,$sql);
while($row = mysqli_fetch_array($query)){
echo $row['title'];
}
mysqli的物件導向的使用: 複製代碼 代碼如下:$conn = mysqli('localhost', 'root', '123', 'db_test');
$sql = "select * from db_table";
$query = $conn->query($sql);
while($row = $query->fetch_array()){
echo $row['title'];
}
mysql_pconnect開啟的串連不會關閉(即使調用mysql_close也不會關閉,因為對其無效),
類似於串連緩衝池,如果下次有來自於同一個機器的同一個使用者名稱
對同一個資料庫的串連,php會自動使用上次已經建立的串連,而不需要再重建立立一個。
好處:是省去了每次與資料庫建立串連的開銷,
壞處:是需要浪費一些記憶體,佔用一些串連,
所以如果使用者訪問量大的時候會出現錯誤,要把mysql的max_connections參數改大一點, 或者使用mysql_connect()就解決問題。
首先兩個函數都是用來處理DB 的。
首先, mysqli 串連是永久串連,而mysql是非永久串連。什麼意思呢? mysql串連每當第二次使用的時候,都會重新開啟一個新的進程,而mysqli則只使用同一個進程,這樣可以很大程度的減輕伺服器端壓力。
其次,mysqli封裝了諸如事務等一些進階操作,同時封裝了DB操作過程中的很多可用的方法。具體查看 http://cn.php.net/mysqli
應用比較多的地方是 mysqli的事務。
比如下面的樣本: 複製代碼 代碼如下:$mysqli = new mysqli('localhost','root','','DB_Lib2Test');
$mysqli->autocommit(false);//開始事物
$mysqli->query($sql1);
$mysqli->query($sql2);
if(!$mysqli->errno){
$mysqli->commit();
echo 'ok';
}else{
echo 'err';
$mysqli->rollback();
}