php mysql mysqli區別比較詳解

來源:互聯網
上載者:User

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。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.