PHP PDO函數(shù)庫(PDO Functions)
更新時(shí)間:2009年07月20日 22:51:07 作者:
PDO是一個(gè)“數(shù)據(jù)庫訪問抽象層”,作用是統(tǒng)一各種數(shù)據(jù)庫的訪問接口,與mysql和mysqli的函數(shù)庫相比,PDO讓跨數(shù)據(jù)庫的使用更具有親和力.
在test庫里面生成table表,并寫入一些數(shù)據(jù):
復(fù)制代碼 代碼如下:
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', '');
$dbh->query('set names utf8;');
$sql = "
DROP TABLE IF EXISTS `table`;
CREATE TABLE `test`.`table` (
`id` INT( 10 ) NOT NULL AUTO_INCREMENT PRIMARY KEY,
`name` VARCHAR( 255 ) NOT NULL ,
`age` VARCHAR( 255 ) NOT NULL
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('samon', '27');
INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('leo', '26');
INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('ben', '28');
";
$dbh->query($sql);
?>
PDO->exec()方法的作用是處理一條SQL語句,并返回所影響的條目數(shù)。
PDO->query()方法的作用是處理一條SQL語句,并返回一個(gè)“PDOStatement”。
PDO->prepare()方法的作用是生成一個(gè)“查詢對(duì)象”。
PDO->lastInsertId()方法的作用是獲取寫入的最后一條數(shù)據(jù)的主鍵值。
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', '');
$dbh->query('set names utf8;');
$sql = "INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);";
$dbh->query($sql);
$lid = $dbh->lastInsertId($sql);
print_r($lid); // 顯示主鍵的值
?>
PDO->quote()方法的作用是為某個(gè)SQL中的字符串添加引號(hào)。PDO->quote()方法有兩個(gè)參數(shù),第一個(gè)參數(shù)是字符串,第二個(gè)參數(shù)表示參數(shù)的類型。
PDO->getAttribute()方法的作用是獲取一個(gè)“數(shù)據(jù)庫連接對(duì)象”的屬性。PDO->setAttribute()方法的作用是為一個(gè)“數(shù)據(jù)庫連接對(duì)象”設(shè)定屬性。
<?php
// 修改默認(rèn)的錯(cuò)誤顯示級(jí)別
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
?>
屬性列表:
PDO::PARAM_BOOL
表示一個(gè)布爾類型
PDO::PARAM_NULL
表示一個(gè)SQL中的NULL類型
PDO::PARAM_INT
表示一個(gè)SQL中的INTEGER類型
PDO::PARAM_STR
表示一個(gè)SQL中的SQL CHAR,VARCHAR類型
PDO::PARAM_LOB
表示一個(gè)SQL中的large object類型
PDO::PARAM_STMT
表示一個(gè)SQL中的recordset類型,還沒有被支持
PDO::PARAM_INPUT_OUTPUT
Specifies that the parameter is an INOUT parameter for a stored procedure. You must bitwise-OR this value with an explicit PDO::PARAM_* data type.
PDO::FETCH_LAZY
將每一行結(jié)果作為一個(gè)對(duì)象返回
PDO::FETCH_ASSOC
僅僅返回以鍵值作為下標(biāo)的查詢的結(jié)果集,名稱相同的數(shù)據(jù)只返回一個(gè)
PDO::FETCH_NAMED
僅僅返回以鍵值作為下標(biāo)的查詢的結(jié)果集,名稱相同的數(shù)據(jù)以數(shù)組形式返回
PDO::FETCH_NUM
僅僅返回以數(shù)字作為下標(biāo)的查詢的結(jié)果集
PDO::FETCH_BOTH
同時(shí)返回以鍵值和數(shù)字作為下標(biāo)的查詢的結(jié)果集
PDO::FETCH_OBJ
以對(duì)象的形式返回結(jié)果集
PDO::FETCH_BOUND
將PDOStatement::bindParam()和PDOStatement::bindColumn()所綁定的值作為變量名賦值后返回
PDO::FETCH_COLUMN
表示僅僅返回結(jié)果集中的某一列
PDO::FETCH_CLASS
表示以類的形式返回結(jié)果集
PDO::FETCH_INTO
表示將數(shù)據(jù)合并入一個(gè)存在的類中進(jìn)行返回
PDO::FETCH_FUNC
PDO::FETCH_GROUP
PDO::FETCH_UNIQUE
PDO::FETCH_KEY_PAIR
以首個(gè)鍵值下表,后面數(shù)字下表的形式返回結(jié)果集
PDO::FETCH_CLASSTYPE
PDO::FETCH_SERIALIZE
表示將數(shù)據(jù)合并入一個(gè)存在的類中并序列化返回
PDO::FETCH_PROPS_LATE
Available since PHP 5.2.0
PDO::ATTR_AUTOCOMMIT
在設(shè)置成true的時(shí)候,PDO會(huì)自動(dòng)嘗試停止接受委托,開始執(zhí)行
PDO::ATTR_PREFETCH
設(shè)置應(yīng)用程序提前獲取的數(shù)據(jù)大小,并非所有的數(shù)據(jù)庫哦度支持
PDO::ATTR_TIMEOUT
設(shè)置連接數(shù)據(jù)庫超時(shí)的值
PDO::ATTR_ERRMODE
設(shè)置Error處理的模式
PDO::ATTR_SERVER_VERSION
只讀屬性,表示PDO連接的服務(wù)器端數(shù)據(jù)庫版本
PDO::ATTR_CLIENT_VERSION
只讀屬性,表示PDO連接的客戶端PDO驅(qū)動(dòng)版本
PDO::ATTR_SERVER_INFO
只讀屬性,表示PDO連接的服務(wù)器的meta信息
PDO::ATTR_CONNECTION_STATUS
PDO::ATTR_CASE
通過PDO::CASE_*中的內(nèi)容對(duì)列的形式進(jìn)行操作
PDO::ATTR_CURSOR_NAME
獲取或者設(shè)定指針的名稱
PDO::ATTR_CURSOR
設(shè)置指針的類型,PDO現(xiàn)在支持PDO::CURSOR_FWDONLY和PDO::CURSOR_FWDONLY
PDO::ATTR_DRIVER_NAME
返回使用的PDO驅(qū)動(dòng)的名稱
PDO::ATTR_ORACLE_NULLS
將返回的空字符串轉(zhuǎn)換為SQL的NULL
PDO::ATTR_PERSISTENT
獲取一個(gè)存在的連接
PDO::ATTR_STATEMENT_CLASS
PDO::ATTR_FETCH_CATALOG_NAMES
在返回的結(jié)果集中,使用自定義目錄名稱來代替字段名。
PDO::ATTR_FETCH_TABLE_NAMES
在返回的結(jié)果集中,使用自定義表格名稱來代替字段名。
PDO::ATTR_STRINGIFY_FETCHES
PDO::ATTR_MAX_COLUMN_LEN
PDO::ATTR_DEFAULT_FETCH_MODE
Available since PHP 5.2.0
PDO::ATTR_EMULATE_PREPARES
Available since PHP 5.1.3.
PDO::ERRMODE_SILENT
發(fā)生錯(cuò)誤時(shí)不匯報(bào)任何的錯(cuò)誤信息,是默認(rèn)值
PDO::ERRMODE_WARNING
發(fā)生錯(cuò)誤時(shí)發(fā)出一條php的E_WARNING的信息
PDO::ERRMODE_EXCEPTION
發(fā)生錯(cuò)誤時(shí)拋出一個(gè)PDOException
PDO::CASE_NATURAL
回復(fù)列的默認(rèn)顯示格式
PDO::CASE_LOWER
強(qiáng)制列的名字小寫
PDO::CASE_UPPER
強(qiáng)制列的名字大寫
PDO::NULL_NATURAL
PDO::NULL_EMPTY_STRING
PDO::NULL_TO_STRING
PDO::FETCH_ORI_NEXT
獲取結(jié)果集中的下一行數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::FETCH_ORI_PRIOR
獲取結(jié)果集中的上一行數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::FETCH_ORI_FIRST
獲取結(jié)果集中的第一行數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::FETCH_ORI_LAST
獲取結(jié)果集中的最后一行數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::FETCH_ORI_ABS
獲取結(jié)果集中的某一行數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::FETCH_ORI_REL
獲取結(jié)果集中當(dāng)前行后某行的數(shù)據(jù),僅在有指針功能時(shí)有效
PDO::CURSOR_FWDONLY
建立一個(gè)只能向后的指針操作對(duì)象
PDO::CURSOR_SCROLL
建立一個(gè)指針操作對(duì)象,傳遞PDO::FETCH_ORI_*中的內(nèi)容來控制結(jié)果集
PDO::ERR_NONE (string)
設(shè)定沒有錯(cuò)誤時(shí)候的錯(cuò)誤信息
PDO::PARAM_EVT_ALLOC
Allocation event
PDO::PARAM_EVT_FREE
Deallocation event
PDO::PARAM_EVT_EXEC_PRE
Event triggered prior to execution of a prepared statement.
PDO::PARAM_EVT_EXEC_POST
Event triggered subsequent to execution of a prepared statement.
PDO::PARAM_EVT_FETCH_PRE
Event triggered prior to fetching a result from a resultset.
PDO::PARAM_EVT_FETCH_POST
Event triggered subsequent to fetching a result from a resultset.
PDO::PARAM_EVT_NORMALIZE
Event triggered during bound parameter registration allowing the driver to normalize the parameter name.
PDO->getAvailableDrivers()方法的作用是獲取有效的PDO驅(qū)動(dòng)器名稱。
PDO->errorInfo()方法的作用獲取錯(cuò)誤的信息,PDO->errorCode()方法的作用是獲取錯(cuò)誤碼。
復(fù)制代碼 代碼如下:
<?php
$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', '');
$dbh->query('set names utf8;');
$sql = "INSERT INTO `test`.`table` (`name` ,`ageeeeee`)VALUES ('mick', 22);";
$dbh->query($sql);
print_r($dbh->errorInfo());
/**
* Array
* (
* [0] => 42S22
* [1] => 1054
* [2] => Unknown column 'ageeeeee' in 'field list'
* )
*/
?>
PDO->__construct()方法的作用是建立一個(gè)PDO鏈接數(shù)據(jù)庫的實(shí)例。
PDO->beginTransaction(),PDO->commit(),PDO->rollBack()這三個(gè)方法是在支持回滾功能時(shí)一起使用的。PDO->beginTransaction()方法標(biāo)明起始點(diǎn),PDO->commit()方法標(biāo)明回滾結(jié)束點(diǎn),并執(zhí)行SQL,PDO->rollBack()執(zhí)行回滾。
復(fù)制代碼 代碼如下:
<?php
try {
$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', '');
$dbh->query('set names utf8;');
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->beginTransaction();
$dbh->exec("INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);");
$dbh->exec("INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('lily', 29);");
$dbh->exec("INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('susan', 21);");
$dbh->commit();
} catch (Exception $e) {
$dbh->rollBack();
echo "Failed: " . $e->getMessage();
}
?>
您可能感興趣的文章:
- php_pdo 預(yù)處理語句詳解
- php PDO實(shí)現(xiàn)的事務(wù)回滾示例
- php pdo操作數(shù)據(jù)庫示例
- php基于PDO實(shí)現(xiàn)功能強(qiáng)大的MYSQL封裝類實(shí)例
- php使用PDO執(zhí)行SQL語句的方法分析
- PHP5中使用PDO連接數(shù)據(jù)庫的方法
- php使用pdo連接報(bào)錯(cuò)Connection failed SQLSTATE的解決方法
- php使用pdo連接并查詢sql數(shù)據(jù)庫的方法
- php中PDO方式實(shí)現(xiàn)數(shù)據(jù)庫的增刪改查
- php中mysql連接方式PDO使用詳解
- PHP實(shí)現(xiàn)PDO的mysql數(shù)據(jù)庫操作類
- 關(guān)于PHPDocument 代碼注釋規(guī)范的總結(jié)
- php實(shí)現(xiàn)基于PDO的預(yù)處理示例
相關(guān)文章
使用apache模塊rewrite_module (轉(zhuǎn))
使用apache模塊rewrite_module (轉(zhuǎn))...2007-02-02PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù)簡(jiǎn)單示例
這篇文章主要介紹了PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù),涉及php ajax交互獲取信息及json格式處理的相關(guān)操作技巧,需要的朋友可以參考下2018-05-05PHP類相關(guān)知識(shí)點(diǎn)實(shí)例總結(jié)
這篇文章主要介紹了PHP類相關(guān)知識(shí)點(diǎn),結(jié)合實(shí)例形式總結(jié)分析了php類相關(guān)的最終類、最終方法、抽象類、抽象方法、接口、重載、魔術(shù)方法等相關(guān)概念與操作技巧,需要的朋友可以參考下2016-09-09PHP實(shí)現(xiàn)的迪科斯徹(Dijkstra)最短路徑算法實(shí)例
這篇文章主要介紹了PHP實(shí)現(xiàn)的迪科斯徹(Dijkstra)最短路徑算法,簡(jiǎn)單描述了迪科斯徹(Dijkstra)最短路徑算法的概念、功能并結(jié)合具體實(shí)例形式分析了php實(shí)現(xiàn)迪科斯徹(Dijkstra)最短路徑算法的相關(guān)步驟與操作技巧,需要的朋友可以參考下2017-09-09php實(shí)現(xiàn)將數(shù)組轉(zhuǎn)換為XML的方法
這篇文章主要介紹了php實(shí)現(xiàn)將數(shù)組轉(zhuǎn)換為XML的方法,實(shí)例分析了php操作數(shù)組及XML格式文件的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03PHP 計(jì)算代碼執(zhí)行耗時(shí)的代碼修正網(wǎng)上普遍錯(cuò)誤
前幾天測(cè)試 SQLite 插入大數(shù)據(jù)量的時(shí)候, 找了一些關(guān)于計(jì)算執(zhí)行時(shí)間的代碼, 發(fā)現(xiàn)網(wǎng)上普遍流傳著這樣一份代碼2011-05-05