現(xiàn)在使用PDO鏈接數(shù)據(jù)庫(kù)的較多
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)建站!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了丹鳳免費(fèi)建站歡迎大家使用!
連接是通過(guò)創(chuàng)建 PDO 基類(lèi)的實(shí)例而建立的。不管使用哪種驅(qū)動(dòng)程序,都是用 PDO 類(lèi)名。構(gòu)造函數(shù)接收用于指定數(shù)據(jù)庫(kù)源(所謂的 DSN)以及可能還包括用戶(hù)名和密碼(如果有的話(huà))的參數(shù)。
連接到 MySQL
?php
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
?
如果有任何連接錯(cuò)誤,將拋出一個(gè) PDOException 異常對(duì)象。如果想處理錯(cuò)誤狀態(tài),可以捕獲異常,或者選擇留給通過(guò) set_exception_handler() 設(shè)置的應(yīng)用程序全局異常處理程序。
處理連接錯(cuò)誤
?php
try?{
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
foreach($dbh-query('SELECT?*?from?FOO')?as?$row)?{
print_r($row);
}
$dbh?=?null;
}?catch?(PDOException?$e)?{
print?"Error!:?"?.?$e-getMessage()?.?"br/";
die();
}
?
如果應(yīng)用程序不在 PDO 構(gòu)造函數(shù)中捕獲異常,zend 引擎采取的默認(rèn)動(dòng)作是結(jié)束腳本并顯示一個(gè)回溯跟蹤,此回溯跟蹤可能泄漏完整的數(shù)據(jù)庫(kù)連接細(xì)節(jié),包括用戶(hù)名和密碼。因此有責(zé)任去顯式(通過(guò) catch 語(yǔ)句)或隱式(通過(guò) set_exception_handler() )地捕獲異常。
連接數(shù)據(jù)成功后,返回一個(gè) PDO 類(lèi)的實(shí)例給腳本,此連接在 PDO 對(duì)象的生存周期中保持活動(dòng)。要想關(guān)閉連接,需要銷(xiāo)毀對(duì)象以確保所有剩余到它的引用都被刪除,可以賦一個(gè) NULL 值給對(duì)象變量。如果不明確地這么做,PHP 在腳本結(jié)束時(shí)會(huì)自動(dòng)關(guān)閉連接。
關(guān)閉一個(gè)連接
?php
$dbh?=?new?PDO('mysql:host=localhost;dbname=test',?$user,?$pass);
//?在此使用連接
//?現(xiàn)在運(yùn)行完成,在此關(guān)閉連接
$dbh?=?null;
?
很多 web 應(yīng)用程序通過(guò)使用到數(shù)據(jù)庫(kù)服務(wù)的持久連接獲得好處。持久連接在腳本結(jié)束后不會(huì)被關(guān)閉,且被緩存,當(dāng)另一個(gè)使用相同憑證的腳本連接請(qǐng)求時(shí)被重用。持久連接緩存可以避免每次腳本需要與數(shù)據(jù)庫(kù)回話(huà)時(shí)建立一個(gè)新連接的開(kāi)銷(xiāo),從而讓 web 應(yīng)用程序更快。
php知識(shí)框架總結(jié)
篇一:php基礎(chǔ)知識(shí)點(diǎn)總結(jié)
PHP語(yǔ)言基礎(chǔ)簡(jiǎn)單整理
1.開(kāi)始結(jié)束標(biāo)記的格式只有在沒(méi)有判斷語(yǔ)句時(shí)才能使用。
對(duì)表單傳遞的變量進(jìn)行編碼和解碼:PHP中實(shí)現(xiàn)對(duì)查詢(xún)字符串進(jìn)行URL編碼可以通過(guò)函數(shù)urlencode()實(shí)現(xiàn),該函數(shù)的使用格式如下:string urlencode(string str);對(duì)URL編碼后的查詢(xún)字符串進(jìn)行解碼,可以通過(guò)urldecode()函數(shù)實(shí)現(xiàn),該函數(shù)的使用格式如下:string urldecode(string str);
15.PHP連接數(shù)據(jù)庫(kù):
步驟: 一、建立連接------mssql_connect(server,uid,pwd);
二、指定database-------mssql_select_db(databasename);
三、執(zhí)行sql------mssql_query($sql,$link);
四、處理記錄集-------資源類(lèi)型數(shù)據(jù),格式:bof---數(shù)據(jù)---eof
五、以特定格式讀取數(shù)據(jù)-----mssql_fetch_array()....
六、釋放相關(guān)資源、關(guān)閉連接------mssql_free_result($result);mssql_close();
16.數(shù)組:php的數(shù)組由鍵值和value值組成
定義:$array = array("鍵值"="value","鍵值"="value","鍵值"="value");如果不給鍵值賦值,默認(rèn)從0開(kāi)始的int值
相關(guān)函數(shù):(1)in_array("值",數(shù)組名); 返回bool型-----查看數(shù)組中是否存在某value值
(2)array_key_exists("key值",數(shù)組名); 返回bool型-----查看數(shù)組中是否存在某鍵值
(3)array_keys(數(shù)組名);---將數(shù)組鍵值返回出來(lái)形成一個(gè)新數(shù)組,此鍵值作為新數(shù)組的value值
(4)array_values(數(shù)組名);---將數(shù)組value值返回出來(lái)形成一個(gè)新數(shù)組,此值作為新數(shù)組的value值
(5)key(數(shù)組名);----返回當(dāng)前指針指向的元素key值
(6)current(數(shù)組名);----返回當(dāng)前指針指向的元素value值
(7)next(數(shù)組名);----挪動(dòng)當(dāng)前數(shù)組指針到下一步
(8)reset(數(shù)組名);----恢復(fù)數(shù)組指針,指向第0個(gè)元素
(9)end(數(shù)組名);----將指針挪向最后一個(gè)元素
(10)prev(數(shù)組名);----將指針向前挪動(dòng)一位
(11)foreach(數(shù)組名 as $key=$value)
{
$key是鍵值,$value是value值,實(shí)現(xiàn)數(shù)組遍歷
}
(12)each(數(shù)組名);----將當(dāng)前數(shù)組元素依次取出(自動(dòng)挪動(dòng)指針)并放到一個(gè)新的數(shù)組中
(13)array_shift(數(shù)組名);----返回?cái)?shù)組中第一個(gè)元素值
(14)array_pop(數(shù)組名);----返回?cái)?shù)組最后一個(gè)元素值
(15)array_push(數(shù)組名,value);----向數(shù)組中追加元素
(16)array_unshift(數(shù)組名,value);----在數(shù)組最前面添加元素
(17)array_pad(數(shù)組名,數(shù)組長(zhǎng)度,value);----向數(shù)組中追加多個(gè)元素,對(duì)數(shù)組副本操作,不改變?cè)瓟?shù)組,返回一個(gè)新數(shù)組
(18)count();----返回個(gè)數(shù)
(19)array_unique(數(shù)組名);----去掉數(shù)組中重復(fù)部分,操作數(shù)組副本,不改變?cè)瓟?shù)組,返回新數(shù)組
(20)sort(數(shù)組名);----從小到大升序排列數(shù)組value值,一般針對(duì)int型value值,返回bool型,成功返回true
(21)rsort(數(shù)組名);----從大到小,逆序排列數(shù)組value值
(22)array_combine(數(shù)組1,數(shù)組2);----將數(shù)組1的value值作為key,數(shù)組2的value值作為value值,形成一個(gè)新數(shù)組
(23)array_merge(數(shù)組1,數(shù)組2,數(shù)組3...);----合并多個(gè)數(shù)組,將多個(gè)數(shù)組value值依次合并,合為一個(gè)數(shù)組
(24)array_slice(數(shù)組名,int,int);----從目標(biāo)數(shù)組截取元素,形成一個(gè)新數(shù)組。開(kāi)始位置為第二個(gè)參數(shù),結(jié)束位置為第三個(gè)參數(shù)。若第三個(gè)參數(shù)不寫(xiě),則默認(rèn)是截取到最后。
(25)array_splice();----用法同array_slice();但是其截取部分從原數(shù)組中刪除
(26)explode("字符依據(jù)",目標(biāo)字符串);----將字符串按照一定的依據(jù)拆分成數(shù)組
(27)implode("字符依據(jù)",目標(biāo)數(shù)組);----將數(shù)組元素按照依據(jù)組合成一個(gè)字符串
(28)range(mixed low,mixed high[number step]);----生成數(shù)組,例:range(1,100,8);---即從1到100,每8位取一個(gè)數(shù),組成一個(gè)數(shù)組
(29)shuffle(數(shù)組名);----用于將數(shù)組進(jìn)行隨機(jī)排序
(30)array_sum(數(shù)組名);----對(duì)數(shù)值型數(shù)組元素值進(jìn)行求和
(31)array_chunk(數(shù)組名,int);----分割目標(biāo)數(shù)組,返回一個(gè)新數(shù)組,其中數(shù)組的每個(gè)元素都是一個(gè)一維數(shù)組,int參數(shù)為分割成的一維數(shù)組的長(zhǎng)度
17.Cookie和會(huì)話(huà)控制:
Cookie是在HTTP協(xié)議下,服務(wù)器或腳本可以維護(hù)客戶(hù)工作站上信息的一種方式。Cookie是由Web服務(wù)器保存在客戶(hù)機(jī)上的小文本文件,它可以包含有關(guān)用戶(hù)的信息。無(wú)論何時(shí)用戶(hù)鏈接到服務(wù)器,Web站點(diǎn)都可以訪(fǎng)問(wèn)Cookie信息。
存在server端的是session,存在client端的是cookie,它們用來(lái)存儲(chǔ)全局變量。 設(shè)定Cookie值:setcookie("名","值");
通過(guò)Cookie數(shù)組取值:$_cookie["名"];
設(shè)置生成期:setcookie("名","值",time()+1800);生成期為當(dāng)前時(shí)間加1800秒之后。
刪除cookie: setcookie("名","",time()-3600);中間值設(shè)置為空,并將當(dāng)前時(shí)間減去3600秒。 Cookie數(shù)組:setcookie("名[key]","值"); 使用foreach讀取。
在PHP中可以通過(guò)$_COOKIE預(yù)定義變量訪(fǎng)問(wèn)Cookie的值。如果設(shè)置了php.ini中的register_long_arrays,那么就能夠應(yīng)用$_COOKIE和$HTTP_COOKIE_VARS;如果在php.ini中還設(shè)置了register_globals,那么就可以在PHP中作為全局變量使用各個(gè)Cookie值。但是,更改php.ini中的兩個(gè)文件設(shè)置,容易對(duì)PHP的安全構(gòu)成威脅,不推薦使用該方法,建議使用更新的$_COOKIE。
會(huì)話(huà)ID的傳送
會(huì)話(huà)ID的傳送有兩種方式,一種是Cookie方式,另一種是URL方式。
Cookie傳送方式:
這是最簡(jiǎn)單的會(huì)話(huà)方式,但是有些客戶(hù)可能限制使用Cookie,如果客戶(hù)限制使用Cookie的條件下,仍要繼續(xù)工作,那就要通過(guò)其他方式來(lái)實(shí)現(xiàn)了。
URL傳送方式:
在該方式中,URL本身用來(lái)傳送會(huì)話(huà),會(huì)話(huà)標(biāo)志被簡(jiǎn)單地附加到URL的尾部,或者作為窗體中的一個(gè)變量來(lái)傳遞。例:
本文實(shí)例講述了PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作。分享給大家供大家參考,具體如下:
PDO連接與查詢(xún):
try
{
$conn
=
new
PDO("odbc:driver={microsoft
access
driver
(*.mdb)};
dbq=".realpath("MyDatabase.mdb"))
or
die("鏈接錯(cuò)誤!");
//echo
"鏈接成功!";
}
catch(PDOException
$e){
echo
$e-getMessage();
}
$sql
=
"select
*
from
users";
1.
foreach()方法
foreach
($conn-query($sql)
as
$row)
{
$row["UserID"];
$row["UserName"];
$row["UserPassword"];
}
2.
while()方法
$rs
=
$conn-query($sql);
$rs-setFetchMode(PDO::FETCH_NUM);
while($row=$rs-fetch()){
$row[0];
$row[1];
$row[2];
}
php使用PDO抽象層獲取查詢(xún)結(jié)果,主要有三種方式:
(1)PDO::query()查詢(xún)。
看下面這段php代碼:
?php
//PDO::query()查詢(xún)
$res
=
$db-query('select
*
from
user');
$res-setFetchMode(PDO::FETCH_NUM);
//數(shù)字索引方式
while
($row
=
$res-fetch()){
print_r($row);
}
?
(2)PDO-exec()處理sql
?php
//PDO-exec()處理sql
$db-setAttribute(PDO::ATTR_ERRMODE,
PDO::ERRMODE_EXCEPTION);
$res
=
$db-exec("insert
into
user(id,name)
values('','php點(diǎn)點(diǎn)通')");
echo
$res;
?
(3)PDO::prepare()預(yù)處理執(zhí)行查詢(xún)
?php
//PDO::prepare()預(yù)處理執(zhí)行查詢(xún)
$res
=
$db-prepare("select
*
from
user");
$res-execute();
while
($row
=
$res-fetchAll())
{
print_r($row);
}
?
setAttribute()
方法是設(shè)置屬性,常用參數(shù)如下:
PDO::CASE_LOWER
--
強(qiáng)制列名是小寫(xiě)
PDO::CASE_NATURAL
--
列名按照原始的方式
PDO::CASE_UPPER
--
強(qiáng)制列名為大寫(xiě)
setFetchMode方法來(lái)設(shè)置獲取結(jié)果集的返回值的類(lèi)型,常用參數(shù)如下:
PDO::FETCH_ASSOC
--
關(guān)聯(lián)數(shù)組形式
PDO::FETCH_NUM
--
數(shù)字索引數(shù)組形式
PDO::FETCH_BOTH
--
兩者數(shù)組形式都有,這是默認(rèn)的
PDO::FETCH_OBJ
--
按照對(duì)象的形式,類(lèi)似于以前的
mysql_fetch_object()
對(duì)上面總結(jié)如下:
查詢(xún)操作主要是PDO::query()、PDO::exec()、PDO::prepare()。
PDO-query()
—
處理一條SQL語(yǔ)句,并返回一個(gè)“PDOStatement”
PDO-exec()
—
處理一條SQL語(yǔ)句,并返回所影響的條目數(shù)
PDO::prepare()主要是預(yù)處理操作,需要通過(guò)$rs-execute()來(lái)執(zhí)行預(yù)處理里面的SQL語(yǔ)句
最后介紹兩個(gè)常用的函數(shù):
(1)fetchColumn()獲取指定記錄里一個(gè)字段結(jié)果,默認(rèn)是第一個(gè)字段!
?php
$res
=
$db-query('select
*
from
user');
//獲取指定記錄里第二個(gè)字段結(jié)果
$col
=
$res-fetchColumn(1);
echo
$col;
?
(2)fetchAll(),從一個(gè)結(jié)果集中獲取數(shù)據(jù),然后存放在關(guān)聯(lián)數(shù)組中
?php
$res
=
$db-query('select
*
from
user');
$res_arr
=$res-fetchAll();
print_r($res_arr);
?
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:PHP使用PDO連接ACCESS數(shù)據(jù)庫(kù)PHP數(shù)據(jù)庫(kù)鏈接類(lèi)(PDO+Access)實(shí)例分享php中mysql連接方式PDO使用詳解關(guān)于php連接mssql:pdo
odbc
sql
serverPhp中用PDO查詢(xún)Mysql來(lái)避免SQL注入風(fēng)險(xiǎn)的方法php中在PDO中使用事務(wù)(Transaction)全新的PDO數(shù)據(jù)庫(kù)操作類(lèi)php版(僅適用Mysql)php使用pdo連接并查詢(xún)sql數(shù)據(jù)庫(kù)的方法php使用pdo連接mssql
server數(shù)據(jù)庫(kù)實(shí)例PHP實(shí)現(xiàn)PDO的mysql數(shù)據(jù)庫(kù)操作類(lèi)
分享標(biāo)題:PHP連接數(shù)據(jù)庫(kù)實(shí)驗(yàn)總結(jié) php連接數(shù)據(jù)庫(kù)的函數(shù)
網(wǎng)站URL:http://muchs.cn/article16/ddihedg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、網(wǎng)站內(nèi)鏈、微信公眾號(hào)、軟件開(kāi)發(fā)、定制網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
全網(wǎng)營(yíng)銷(xiāo)推廣知識(shí)