這是連接mysql數(shù)據(jù)庫(kù)的簡(jiǎn)單代碼:
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比紅河哈尼網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式紅河哈尼網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋紅河哈尼地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。
$conn=new?PDO("mysql:host=localhost;dbname=webdata","user","pwd");
$sth=$conn-prepare("select?*?from?books");
$sth-execute();
while($res=$sth-fetch(PDO::FETCH_ASSOC))
{
echo("div".$res["id"].":".$res["title"]."--".$res["author"]);
}
pdo擴(kuò)展為php訪問(wèn)數(shù)據(jù)庫(kù)定義了一個(gè)輕量級(jí)的、一致性的接口,它提供了一個(gè)數(shù)據(jù)訪問(wèn)抽象層,這樣,無(wú)論使用什么數(shù)據(jù)庫(kù),都可以通過(guò)一致的函數(shù)執(zhí)行查詢和獲取數(shù)據(jù)。
在一些php管理系統(tǒng)需要開(kāi)啟pdo和pdo_mysql擴(kuò)展,方法很簡(jiǎn)單:
1、找到php.ini文件
2、打開(kāi)后,搜索
extension=php_pdo.dll
和
extension=php_pdo_mysql.dll
,去掉前面“;”的注釋。
最終這兩行配置內(nèi)容如下:
extension=php_pdo.dll
extension=php_pdo_mysql.dll
重新啟動(dòng)apache或者iis后,在phpinfo函數(shù)中查看,是否開(kāi)啟。
這個(gè)在配置里面是可以設(shè)置的,一般是與連接數(shù)據(jù)庫(kù)設(shè)置一起配置:
//數(shù)據(jù)庫(kù)配置信息
'DB_TYPE'???=?'mysql',?//?數(shù)據(jù)庫(kù)類型
'DB_HOST'???=?'localhost',?//?服務(wù)器地址
'DB_NAME'???=?'thinkphp',?//?數(shù)據(jù)庫(kù)名
'DB_USER'???=?'root',?//?用戶名
'DB_PWD'????=?'123456',?//?密碼
'DB_PORT'???=?3306,?//?端口
'DB_PREFIX'?=?'think_',?//?數(shù)據(jù)庫(kù)表前綴
'DB_CHARSET'=?'utf8',?//?字符集
'DB_DEBUG'??=??TRUE,?//?數(shù)據(jù)庫(kù)調(diào)試模式?開(kāi)啟后可以記錄SQL日志
其中數(shù)據(jù)庫(kù)類型可以設(shè)置為:mysqli
更多類型還有:
DB_TYPE設(shè)置
支持的????????????????數(shù)據(jù)庫(kù)類型
mysql或mysqli ? ?mysql ?
pgsql ? ???????????????pgsql ?
sqlite ? ???????????????sqlite ?
mssql 或sqlsrv ? ?sqlserver ?
oracle ? ??????????????oracle ?
ibase ? ?????????????? ibase ?
mongo ? ?????????????mongo ?
PDO ? ?????????????????PDO支持的所有數(shù)據(jù)庫(kù) ?
Mysqli是php5之后才有的功能,沒(méi)有開(kāi)啟擴(kuò)展的朋友可以打開(kāi)您的php.ini的配置文件。
查找下面的語(yǔ)句:;extension=php_mysqli.dll將其修改為:extension=php_mysqli.dll即可。
相對(duì)于mysql有很多新的特性和優(yōu)勢(shì)
(1)支持本地綁定、準(zhǔn)備(prepare)等語(yǔ)法
(2)執(zhí)行sql語(yǔ)句的錯(cuò)誤代碼
(3)同時(shí)執(zhí)行多個(gè)sql
(4)另外提供了面向?qū)ο蟮恼{(diào)用接口的方法。
下面一一用php實(shí)例進(jìn)行mysqli數(shù)據(jù)庫(kù)連接!
使用方法一:使用傳統(tǒng)的面向過(guò)程的方法
php代碼如下:
?php
$connect?=?mysqli_connect('localhost','root','','volunteer')?or?die('Unale?to?connect');
$sql?=?"select?*?from?vol_msg";
$result?=?mysqli_query($connect,$sql);
while($row?=?mysqli_fetch_row($result)){
echo?$row[0];
}
?
使用方法二:使用面向?qū)ο蟮姆椒ㄕ{(diào)用接口(推薦使用)
看php代碼如下:
復(fù)制代碼?代碼如下:
?php
//創(chuàng)建對(duì)象并打開(kāi)連接,最后一個(gè)參數(shù)是選擇的數(shù)據(jù)庫(kù)名稱
$mysqli?=?new?mysqli('localhost','root','','volunteer');
//檢查連接是否成功
if?(mysqli_connect_errno()){
//注意mysqli_connect_error()新特性
die('Unable?to?connect!').?mysqli_connect_error();
}
$sql?=?"select?*?from?vol_msg";
//執(zhí)行sql語(yǔ)句,完全面向?qū)ο蟮?/p>
$result?=?$mysqli-query($sql);
while($row?=?$result-fetch_array()){
echo?$row[0];
}
?
以上兩個(gè)php實(shí)例運(yùn)行的結(jié)果完全相同,可以清楚的看到使用mysqli類對(duì)象構(gòu)建數(shù)據(jù)庫(kù)連接的優(yōu)勢(shì)!
插入和修改記錄我就不用講了,只要更改一下sql語(yǔ)句就行,下一篇我會(huì)講prepare接口特性!
不需要進(jìn)行數(shù)據(jù)庫(kù)操作,不需要安裝mysql。 php的mysql擴(kuò)展是php用于操作mysql數(shù)據(jù)庫(kù)的函數(shù)庫(kù),如果需要進(jìn)行數(shù)據(jù)庫(kù)操作,不僅要有函數(shù)庫(kù),還需要安裝數(shù)據(jù)庫(kù)。
1.面向?qū)ο蟮氖褂梅绞?/p>
$db
=
new
mysqli('localhost',
'root',
'123456',
'dbname');
如果建立連接時(shí)未指定數(shù)據(jù)庫(kù)則選擇使用的數(shù)據(jù)庫(kù),切換使用的數(shù)據(jù)庫(kù)
$db-select_db('dbname');
$query
=
"SELECT
*
FROM
user
WHERE
uid=4";
$result
=
$db-query($query);
$result_num
=
$result-num_rows;
$row
=
$result-fetch_assoc();
//返回一個(gè)關(guān)聯(lián)數(shù)組,可以通過(guò)$row['uid']的方式取得值
$row
=
$result-fetch_row();
//返回一個(gè)列舉數(shù)組,可以通過(guò)$row[0]的方式取得值
$row
=
$result-fetch_array();
//返回一個(gè)混合數(shù)組,可以通過(guò)$row['uid']和$row[0]兩種方式取得值
$row
=
$result-fetch_object();
//返回一個(gè)對(duì)象,可以通過(guò)$row-uid的方式取得值
$result-free();
//釋放結(jié)果集
$db-close();
//關(guān)閉一個(gè)數(shù)據(jù)庫(kù)連接,這不是必要的,因?yàn)槟_本執(zhí)行完畢時(shí)會(huì)自動(dòng)關(guān)閉連接
當(dāng)進(jìn)行INSERT、UPDATE、DELETE操作時(shí),使用$db-affected_rows查看影響行數(shù)
2.面向過(guò)程的使用方式
$db
=
mysqli_connect('localhost',
'root',
'123456',
'dbname');
如果建立連接時(shí)未指定數(shù)據(jù)庫(kù)則選擇使用的數(shù)據(jù)庫(kù),切換使用的數(shù)據(jù)庫(kù)
mysqli_select_db($db,
'dbname');
查詢數(shù)據(jù)庫(kù)
$query
=
"SELECT
*
FROM
user
WHERE
uid=4";
$result
=
mysqli_query($db,
$query);
$result_num
=
mysqli_num_rows($result);
返回一行結(jié)果
$row
=
mysqli_fetch_assoc($result);
//返回一個(gè)關(guān)聯(lián)數(shù)組,可以通過(guò)$row['uid']的方式取得值
$row
=
mysqli_fetch_row($result);
//返回一個(gè)列舉數(shù)組,可以通過(guò)$row[0]的方式取得值
$row
=
mysqli_fetch_array($result);
//返回一個(gè)混合數(shù)組,可以通過(guò)$row['uid']和$row[0]兩種方式取得值
$row
=
mysqli_fetch_object($result);
//返回一個(gè)對(duì)象,可以通過(guò)$row-uid的方式取得值
斷開(kāi)數(shù)據(jù)庫(kù)連接
mysqli_free_result($result);
//釋放結(jié)果集
mysqli_close($db);
//關(guān)閉一個(gè)數(shù)據(jù)庫(kù)連接,這不是必要的,因?yàn)槟_本執(zhí)行完畢時(shí)會(huì)自動(dòng)關(guān)閉連接
當(dāng)進(jìn)行INSERT、UPDATE、DELETE操作時(shí),使用mysqli_affected_rows()查看影響行數(shù)