国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 php教程 php手冊 php中對(duì)Mysql數(shù)據(jù)庫的訪問操作

php中對(duì)Mysql數(shù)據(jù)庫的訪問操作

Jun 06, 2016 pm 07:59 PM
mysql php 操作 數(shù)據(jù)庫 訪問

一: PHP-MySQL 是 PHP 操作 MySQL 資料庫最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相對(duì)進(jìn)階的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object) 則是提供了一個(gè) Abstraction Layer 來操作資料庫,用講的其實(shí)

一:?
PHP-MySQL 是 PHP 操作 MySQL 資料庫最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相對(duì)進(jìn)階的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object) 則是提供了一個(gè) Abstraction Layer 來操作資料庫,用講的其實(shí)看不出來有有什麼差別,所以就直接看程序吧…?

首先,先來看一段用 PHP-MySQL 寫成的程式碼,這類的范例常用在世界各地:

?
mysql_connect($db_host, $db_user, $db_password);?
mysql_select_db($dn_name);?
$result = mysql_query("SELECT `name` FROM `users` WHERE `location` = '$location'");?
while ($row = mysql_fetch_array($result, MYSQL_ASSOC))?
{?
echo $row['name'];?
}?
mysql_free_result($result);?
?>?

乍看之下沒什麼問題,但其實(shí)背后有些學(xué)問…?
這種方式不能 Bind Column ,以前例的 SQL 敘述來說,$location 的地方容易被 SQL Injection。后來于是發(fā)展出了 mysql_escape_string() (備注:5.3.0之后棄用) 以及 mysql_real_escape_string() 來解決這個(gè)問題,不過這麼一搞,整個(gè)敘述會(huì)變得複雜且丑陋,而且如果欄位多了,可以想見會(huì)是怎樣的情形…?

$query = sprintf("SELECT * FROM users WHERE user='%s' AND password='%s'",?
mysql_real_escape_string($user),?
mysql_real_escape_string($password));?
mysql_query($query);?
?>?

在 PHP-MySQLi 中有了不少進(jìn)步,除了透過 Bind Column 來解決上述問題,而且也多援 Transaction, Multi Query ,并且同時(shí)提供了 Object oriented style (下面這段 PHP-MySQLi 范例的寫法) 和 Procedural style (上面 PHP-MySQL 范例的寫法)兩種寫法…等等。

$mysqli = new mysqli($db_host, $db_user, $db_password, $db_name);?
$sql = "INSERT INTO `users` (id, name, gender, location) VALUES (?, ?, ?, ?)";?
$stmt = $mysqli->prepare($sql);?
$stmt->bind_param('dsss', $source_id, $source_name, $source_gender, $source_location);?
$stmt->execute();?
$stmt->bind_result($id, $name, $gender, $location);?
while ($stmt->fetch())?
{?
echo $id . $name . $gender . $location;?
}?
$stmt->close();?
$mysqli->close();?
?>?

但看到這邊又發(fā)現(xiàn)了一些缺點(diǎn),例如得 Bind Result,這個(gè)就有點(diǎn)多馀,不過這其實(shí)無關(guān)緊要,因?yàn)樽畲蟮膯栴}還是在于這不是一個(gè)抽象(Abstraction)的方法,所以當(dāng)后端更換資料庫的時(shí)候,就是痛苦的開始…?
于是 PDO 就出現(xiàn)了(備注:目前 Ubuntu 和 Debian 來說,PDO 并沒有直接的套件可以安裝,而是必須透過 PECL 安裝)。?

roga@carlisten-lx:~$ pecl search pdo?
=======================================?
Package Stable/(Latest) Local?
PDO 1.0.3 (stable) PHP Data Objects Interface.?
PDO_4D 0.3 (beta) PDO driver for 4D-SQL database?
PDO_DBLIB 1.0 (stable) FreeTDS/Sybase/MSSQL driver for PDO?
PDO_FIREBIRD 0.2 (beta) Firebird/InterBase 6 driver for PDO?
PDO_IBM 1.3.2 (stable) PDO driver for IBM databases?
PDO_INFORMIX 1.2.6 (stable) PDO driver for IBM Informix INFORMIX databases?
PDO_MYSQL 1.0.2 (stable) MySQL driver for PDO?
PDO_OCI 1.0 (stable) Oracle Call Interface driver for PDO?
PDO_ODBC 1.0.1 (stable) ODBC v3 Interface driver for PDO?
PDO_PGSQL 1.0.2 (stable) PostgreSQL driver for PDO?
PDO_SQLITE 1.0.1 (stable) SQLite v3 Interface driver for PDO?
pdo_user 0.3.0 (beta) Userspace driver for PDO?

當(dāng)透過 PECL 安裝裝好后,就可以透過以下方式來操作資料庫:?

$dsn = "mysql:host=$db_host;dbname=$db_name";?
$dbh = new PDO($dsn, $db_user, $db_password);?
$sql = "SELECT `name`, `location` FROM `users` WHERE `location` = ? , `name` = ?";?
$sth = $dbh->prepare($sql);?
$sth->execute(array($location, $name));?
$result = $sth->fetch(PDO::FETCH_OBJ);?
echo $result->name . $result->location;?
$dbh = NULL;?
?>?
乍看之下,PDO 的程式碼好像也沒有比較短,那到底好處是什麼呢??
1. PDO 連接資料庫時(shí)透過 Connection String 來決定連接何種資料庫。?
2. PDO 可以透過 PDO::setAttribute 來決定連線時(shí)的設(shè)定,像是 Persistent Connection, 回傳錯(cuò)誤的方式(Exception, E_WARNING, NULL)。甚至是回傳欄位名稱的大小寫…等等。?
2. PDO 支援 Bind Column 的功能,除了基本的 Prepare, Execute 以外,也可以 Bind 單一欄位,并且指定欄位型態(tài)。?
4. PDO 是 Abstraction Layer 所以就算更換儲(chǔ)存媒介,需要花的功夫比起來是最少的。?
可惜的是,儘管這些東西都已經(jīng)出現(xiàn)很久了,但還是不夠大眾化。我想或許是肇因于大家習(xí)慣看坊間的書籍學(xué)習(xí),但那些書本往往只會(huì)介紹最簡單最傳統(tǒng)的方式。導(dǎo)致很多人還是在用 MySQL 這種方直接連資料庫。?
不過,目前來說我個(gè)人還是最喜愛透過 DBI 來連接資料庫,像是 ActiveRecord 以及 Propel ORM(Object-Relational Mapping)。?
例如說以 ActiveRecord 為例,如果要實(shí)現(xiàn)這樣的 SQL 敘述…?
INSERT INTO `users` (id, name, gender, location) VALUES(1, 'roga', 'male', 'tpe')?
以 PDO 來寫是:?

$sql = "INSERT INTO `users` (id, name, gender, location) VALUES(?, ?, ?, ?)";?
$sth = $dbh->prepare($sql);?
$sth->execute(array(1, 'roga', 'male', 'tpe'));?
?>?

但以 ActiveRecord 來說的話,則是:?

$user = new User();?
$user->id = 1;?
$user->name = 'roga';?
$user->gender = 'male';?
$user->location = 'tpe';?
$user->save();?
?>?

后者在語法上是不是簡潔很多呢,而且也大幅降低對(duì) SQL 語言的依賴性!(不同資料庫對(duì) SQL 實(shí)作的問題可參考 Comparison of different SQL implementations)?

mysql是非持繼連接函數(shù)而mysqli是永遠(yuǎn)連接函數(shù)。也就是說?
mysql每次鏈接都會(huì)打開一個(gè)連接的進(jìn)程而mysqli多次運(yùn)行mysqli將使用同一連接進(jìn)程,從而減少了服務(wù)器的開銷?
有些朋友在編程的時(shí)候,使用new mysqli('localhost', usenamer', 'password', 'databasename');總是報(bào)?
錯(cuò),F(xiàn)atal error: Class 'mysqli' not found in d:\...?
mysqli類不是php自帶的嗎??
不是默認(rèn)開啟的,win下要改php.ini,去掉php_mysqli.dll前的;,linux下要把mysqli編譯進(jìn)去。?
一:Mysqli.dll是一個(gè)允許以對(duì)象的方式或者過程操作數(shù)據(jù)庫的,它的使用方式也很容易。這里就幾個(gè)常見的操作和 mysql.dll做一個(gè)對(duì)比。?
 ?。? ?mysql.dll(可以理解為函數(shù)式的方式):?

復(fù)制代碼代碼如下:


  $conn = mysql_connect('localhost', 'user', 'password'); //連接mysql數(shù)據(jù)庫?
  mysql_select_db('data_base'); //選擇數(shù)據(jù)庫?
  ?
  $result = mysql_query('select * from data_base');//這里有第二個(gè)可選參數(shù),指定打開的連接?
  $row = mysql_fetch_row( $result ) ) //為了簡單,這里只取一行數(shù)據(jù)?
  echo $row[0]; //輸出第一個(gè)字段的值?


  mysqli也有過程式的方式,只不過開始貫以mysqli的前綴,其他都差不多。如果mysqli以過程式的方式操作的話, 有些函數(shù)必須指定資源,比如說 mysqli_query(資源標(biāo)識(shí),SQL語句),并且資源標(biāo)識(shí)的參數(shù)是放在前面的,而 mysql_query(SQL語句,'可選')的資源標(biāo)識(shí)是放在后面的,并且可以不指定,它默認(rèn)是上一個(gè)打開的連接或資源。?
 ?。??mysqli.dll(對(duì)象方式):?

復(fù)制代碼代碼如下:


  $conn = new mysqli('localhost', 'user', 'password','data_base');?
  //這里的連接是new出來的,最后一個(gè)參數(shù)是直接指定數(shù)據(jù)庫,不用 ? ? ? ? ? ? ? ? ? mysql_select_db()了?
  //也可以構(gòu)造時(shí)候不指定,然后 $conn -> select_db('data_base')?
  $result = $conn -> query( 'select * from data_base' );?
  $row = $result -> fetch_row(); //取一行數(shù)據(jù)?
  echo row[0]; //輸出第一個(gè)字段的值?


  二:mysql_fetch_row(),mysql_fetch_array()?
  這兩個(gè)函數(shù),返回的都是一個(gè)數(shù)組,區(qū)別就是第一個(gè)函數(shù)返回的數(shù)組是只包含值,我們只能$row[0],?
? ? ? $row[1],這樣以數(shù)組下標(biāo)來讀取數(shù)據(jù),而mysql_fetch_array()返回的數(shù)組既包含第一種,也包含鍵值?
? ? ? 對(duì)的形式,我們可以這樣讀取數(shù)據(jù),(假如數(shù)據(jù)庫的字段是 username,passwd):?
  $row['username'], $row['passwd']?
  而且,如果用($row as $kay => $value)來操作的話,還以直接取得數(shù)據(jù)庫的字段名稱。?
  更主要的是mysqli是php5提供的新函數(shù)庫,(i)表示改進(jìn),其執(zhí)行速度更快.


本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用于處理時(shí)間,包括獲取當(dāng)前時(shí)間、測量執(zhí)行時(shí)間、操作時(shí)間點(diǎn)與持續(xù)時(shí)間及格式化解析時(shí)間。1.獲取當(dāng)前時(shí)間使用std::chrono::system_clock::now(),可轉(zhuǎn)換為可讀字符串但系統(tǒng)時(shí)鐘可能不單調(diào);2.測量執(zhí)行時(shí)間應(yīng)使用std::chrono::steady_clock以確保單調(diào)性,并通過duration_cast轉(zhuǎn)換為毫秒、秒等單位;3.時(shí)間點(diǎn)(time_point)和持續(xù)時(shí)間(duration)可相互操作,但需注意單位兼容性和時(shí)鐘紀(jì)元(epoch)

PHP如何處理環(huán)境變量? PHP如何處理環(huán)境變量? Jul 14, 2025 am 03:01 AM

toAccessenvironmentVariablesInphp,useGetenv()或$ _envsuperglobal.1.getEnv('var_name')retievesSpecificvariable.2。$ _ en v ['var_name'] accessesvariablesifvariables_orderInphp.iniincludes“ e” .setVariablesViaCliWithvar = vualitephpscript.php,inapach

mysql公共表表達(dá)式(CTE)示例 mysql公共表表達(dá)式(CTE)示例 Jul 14, 2025 am 02:28 AM

CTE是MySQL中用于簡化復(fù)雜查詢的臨時(shí)結(jié)果集。它在當(dāng)前查詢中可多次引用,提升代碼可讀性和維護(hù)性。例如,在orders表中查找每個(gè)用戶的最新訂單時(shí),可通過CTE先獲取每個(gè)用戶的最新訂單日期,再與原表關(guān)聯(lián)獲取完整記錄。相比子查詢,CTE結(jié)構(gòu)更清晰,邏輯更易調(diào)試。使用技巧包括明確別名、串聯(lián)多個(gè)CTE以及利用遞歸CTE處理樹形數(shù)據(jù)。掌握CTE能使SQL更優(yōu)雅高效。

為什么我們評(píng)論:PHP指南 為什么我們評(píng)論:PHP指南 Jul 15, 2025 am 02:48 AM

PHPhasthreecommentstyles://,#forsingle-lineand/.../formulti-line.Usecommentstoexplainwhycodeexists,notwhatitdoes.MarkTODO/FIXMEitemsanddisablecodetemporarilyduringdebugging.Avoidover-commentingsimplelogic.Writeconcise,grammaticallycorrectcommentsandu

php準(zhǔn)備的語句與條款 php準(zhǔn)備的語句與條款 Jul 14, 2025 am 02:56 AM

使用PHP預(yù)處理語句執(zhí)行帶有IN子句的查詢時(shí),1.需根據(jù)數(shù)組長度動(dòng)態(tài)生成占位符;2.使用PDO時(shí)可直接傳入數(shù)組,用array_values確保索引連續(xù);3.使用mysqli時(shí)需構(gòu)造類型字符串并綁定參數(shù),注意展開數(shù)組的方式及版本兼容性;4.避免拼接SQL、處理空數(shù)組和確保數(shù)據(jù)類型匹配。具體做法是:先用implode與array_fill生成占位符,再依擴(kuò)展特性綁定參數(shù),從而安全執(zhí)行IN查詢。

為MySQL表中的列選擇適當(dāng)?shù)臄?shù)據(jù)類型 為MySQL表中的列選擇適當(dāng)?shù)臄?shù)據(jù)類型 Jul 15, 2025 am 02:25 AM

insetTingUpmysqltables,選擇theStherightDatatatPesisionCrucialForeffifeffifeffifeffificeFifeffifeFrifeFifeScalible

PHP標(biāo)頭重定向不起作用 PHP標(biāo)頭重定向不起作用 Jul 14, 2025 am 01:59 AM

header函數(shù)跳轉(zhuǎn)失敗原因及解決方法:1.header前已有輸出,需檢查并移除所有前置輸出或使用ob_start()緩沖;2.未加exit導(dǎo)致后續(xù)代碼干擾,應(yīng)在跳轉(zhuǎn)后立即添加exit或die;3.路徑錯(cuò)誤應(yīng)使用絕對(duì)路徑或動(dòng)態(tài)拼接確保正確;4.服務(wù)器配置或緩存干擾可嘗試清除緩存或更換環(huán)境測試。

如何避免PHP中未定義的索引錯(cuò)誤 如何避免PHP中未定義的索引錯(cuò)誤 Jul 14, 2025 am 02:51 AM

避免“undefinedindex”錯(cuò)誤的關(guān)鍵方法有三:首先,使用isset()檢查數(shù)組鍵是否存在并確保值不為null,適用于大多數(shù)常規(guī)場景;其次,使用array_key_exists()僅判斷鍵是否存在,適用于需要區(qū)分鍵不存在和值為null的情況;最后,使用空合并運(yùn)算符??(PHP7 )簡潔地設(shè)置默認(rèn)值,推薦用于現(xiàn)代PHP項(xiàng)目,同時(shí)注意表單字段名拼寫、謹(jǐn)慎使用extract()及遍歷前檢查數(shù)組非空以進(jìn)一步規(guī)避風(fēng)險(xiǎn)。

See all articles