PHP連接數(shù)據(jù)庫(kù)實(shí)驗(yàn)總結(jié) php連接數(shù)據(jù)庫(kù)的函數(shù)

php連接mysql數(shù)據(jù)庫(kù)原理是怎樣的

現(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知識(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)傳遞。例:

PHP使用pdo連接access數(shù)據(jù)庫(kù)并循環(huán)顯示數(shù)據(jù)操作示例

本文實(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)

營(yíng)銷(xiāo)型網(wǎng)站建設(shè)