PHP PDO函數(shù)庫(PDO Functions)
更新時間:2009年07月20日 22:51:07 作者:
PDO是一個“數(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語句,并返回一個“PDOStatement”。
PDO->prepare()方法的作用是生成一個“查詢對象”。
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()方法的作用是為某個SQL中的字符串添加引號。PDO->quote()方法有兩個參數(shù),第一個參數(shù)是字符串,第二個參數(shù)表示參數(shù)的類型。
PDO->getAttribute()方法的作用是獲取一個“數(shù)據(jù)庫連接對象”的屬性。PDO->setAttribute()方法的作用是為一個“數(shù)據(jù)庫連接對象”設(shè)定屬性。
<?php
// 修改默認(rèn)的錯誤顯示級別
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
?>
屬性列表:
PDO::PARAM_BOOL
表示一個布爾類型
PDO::PARAM_NULL
表示一個SQL中的NULL類型
PDO::PARAM_INT
表示一個SQL中的INTEGER類型
PDO::PARAM_STR
表示一個SQL中的SQL CHAR,VARCHAR類型
PDO::PARAM_LOB
表示一個SQL中的large object類型
PDO::PARAM_STMT
表示一個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é)果作為一個對象返回
PDO::FETCH_ASSOC
僅僅返回以鍵值作為下標(biāo)的查詢的結(jié)果集,名稱相同的數(shù)據(jù)只返回一個
PDO::FETCH_NAMED
僅僅返回以鍵值作為下標(biāo)的查詢的結(jié)果集,名稱相同的數(shù)據(jù)以數(shù)組形式返回
PDO::FETCH_NUM
僅僅返回以數(shù)字作為下標(biāo)的查詢的結(jié)果集
PDO::FETCH_BOTH
同時返回以鍵值和數(shù)字作為下標(biāo)的查詢的結(jié)果集
PDO::FETCH_OBJ
以對象的形式返回結(jié)果集
PDO::FETCH_BOUND
將PDOStatement::bindParam()和PDOStatement::bindColumn()所綁定的值作為變量名賦值后返回
PDO::FETCH_COLUMN
表示僅僅返回結(jié)果集中的某一列
PDO::FETCH_CLASS
表示以類的形式返回結(jié)果集
PDO::FETCH_INTO
表示將數(shù)據(jù)合并入一個存在的類中進(jìn)行返回
PDO::FETCH_FUNC
PDO::FETCH_GROUP
PDO::FETCH_UNIQUE
PDO::FETCH_KEY_PAIR
以首個鍵值下表,后面數(shù)字下表的形式返回結(jié)果集
PDO::FETCH_CLASSTYPE
PDO::FETCH_SERIALIZE
表示將數(shù)據(jù)合并入一個存在的類中并序列化返回
PDO::FETCH_PROPS_LATE
Available since PHP 5.2.0
PDO::ATTR_AUTOCOMMIT
在設(shè)置成true的時候,PDO會自動嘗試停止接受委托,開始執(zhí)行
PDO::ATTR_PREFETCH
設(shè)置應(yīng)用程序提前獲取的數(shù)據(jù)大小,并非所有的數(shù)據(jù)庫哦度支持
PDO::ATTR_TIMEOUT
設(shè)置連接數(shù)據(jù)庫超時的值
PDO::ATTR_ERRMODE
設(shè)置Error處理的模式
PDO::ATTR_SERVER_VERSION
只讀屬性,表示PDO連接的服務(wù)器端數(shù)據(jù)庫版本
PDO::ATTR_CLIENT_VERSION
只讀屬性,表示PDO連接的客戶端PDO驅(qū)動版本
PDO::ATTR_SERVER_INFO
只讀屬性,表示PDO連接的服務(wù)器的meta信息
PDO::ATTR_CONNECTION_STATUS
PDO::ATTR_CASE
通過PDO::CASE_*中的內(nèi)容對列的形式進(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ū)動的名稱
PDO::ATTR_ORACLE_NULLS
將返回的空字符串轉(zhuǎn)換為SQL的NULL
PDO::ATTR_PERSISTENT
獲取一個存在的連接
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ā)生錯誤時不匯報任何的錯誤信息,是默認(rèn)值
PDO::ERRMODE_WARNING
發(fā)生錯誤時發(fā)出一條php的E_WARNING的信息
PDO::ERRMODE_EXCEPTION
發(fā)生錯誤時拋出一個PDOException
PDO::CASE_NATURAL
回復(fù)列的默認(rèn)顯示格式
PDO::CASE_LOWER
強制列的名字小寫
PDO::CASE_UPPER
強制列的名字大寫
PDO::NULL_NATURAL
PDO::NULL_EMPTY_STRING
PDO::NULL_TO_STRING
PDO::FETCH_ORI_NEXT
獲取結(jié)果集中的下一行數(shù)據(jù),僅在有指針功能時有效
PDO::FETCH_ORI_PRIOR
獲取結(jié)果集中的上一行數(shù)據(jù),僅在有指針功能時有效
PDO::FETCH_ORI_FIRST
獲取結(jié)果集中的第一行數(shù)據(jù),僅在有指針功能時有效
PDO::FETCH_ORI_LAST
獲取結(jié)果集中的最后一行數(shù)據(jù),僅在有指針功能時有效
PDO::FETCH_ORI_ABS
獲取結(jié)果集中的某一行數(shù)據(jù),僅在有指針功能時有效
PDO::FETCH_ORI_REL
獲取結(jié)果集中當(dāng)前行后某行的數(shù)據(jù),僅在有指針功能時有效
PDO::CURSOR_FWDONLY
建立一個只能向后的指針操作對象
PDO::CURSOR_SCROLL
建立一個指針操作對象,傳遞PDO::FETCH_ORI_*中的內(nèi)容來控制結(jié)果集
PDO::ERR_NONE (string)
設(shè)定沒有錯誤時候的錯誤信息
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ū)動器名稱。
PDO->errorInfo()方法的作用獲取錯誤的信息,PDO->errorCode()方法的作用是獲取錯誤碼。
復(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()方法的作用是建立一個PDO鏈接數(shù)據(jù)庫的實例。
PDO->beginTransaction(),PDO->commit(),PDO->rollBack()這三個方法是在支持回滾功能時一起使用的。PDO->beginTransaction()方法標(biāo)明起始點,PDO->commit()方法標(biāo)明回滾結(jié)束點,并執(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實現(xiàn)的事務(wù)回滾示例
- php pdo操作數(shù)據(jù)庫示例
- php基于PDO實現(xiàn)功能強大的MYSQL封裝類實例
- php使用PDO執(zhí)行SQL語句的方法分析
- PHP5中使用PDO連接數(shù)據(jù)庫的方法
- php使用pdo連接報錯Connection failed SQLSTATE的解決方法
- php使用pdo連接并查詢sql數(shù)據(jù)庫的方法
- php中PDO方式實現(xiàn)數(shù)據(jù)庫的增刪改查
- php中mysql連接方式PDO使用詳解
- PHP實現(xiàn)PDO的mysql數(shù)據(jù)庫操作類
- 關(guān)于PHPDocument 代碼注釋規(guī)范的總結(jié)
- php實現(xiàn)基于PDO的預(yù)處理示例
相關(guān)文章
使用apache模塊rewrite_module (轉(zhuǎn))
使用apache模塊rewrite_module (轉(zhuǎn))...2007-02-02PHP+ajax實現(xiàn)獲取新聞數(shù)據(jù)簡單示例
這篇文章主要介紹了PHP+ajax實現(xiàn)獲取新聞數(shù)據(jù),涉及php ajax交互獲取信息及json格式處理的相關(guān)操作技巧,需要的朋友可以參考下2018-05-05PHP實現(xiàn)的迪科斯徹(Dijkstra)最短路徑算法實例
這篇文章主要介紹了PHP實現(xiàn)的迪科斯徹(Dijkstra)最短路徑算法,簡單描述了迪科斯徹(Dijkstra)最短路徑算法的概念、功能并結(jié)合具體實例形式分析了php實現(xiàn)迪科斯徹(Dijkstra)最短路徑算法的相關(guān)步驟與操作技巧,需要的朋友可以參考下2017-09-09php實現(xiàn)將數(shù)組轉(zhuǎn)換為XML的方法
這篇文章主要介紹了php實現(xiàn)將數(shù)組轉(zhuǎn)換為XML的方法,實例分析了php操作數(shù)組及XML格式文件的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03PHP 計算代碼執(zhí)行耗時的代碼修正網(wǎng)上普遍錯誤
前幾天測試 SQLite 插入大數(shù)據(jù)量的時候, 找了一些關(guān)于計算執(zhí)行時間的代碼, 發(fā)現(xiàn)網(wǎng)上普遍流傳著這樣一份代碼2011-05-05