一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

一個(gè)基于PDO的數(shù)據(jù)庫(kù)操作類(新) 一個(gè)PDO事務(wù)實(shí)例

復(fù)制代碼 代碼如下:
<?php
/*
* 作者:胡睿
* 日期:2011/03/19
* 電郵:hooray0905@foxmail.com
*
* 20110319
* 常用數(shù)據(jù)庫(kù)操作,如:增刪改查,獲取單條記錄、多條記錄,返回最新一條插入記錄id,返回操作記錄行數(shù)等
* 20110630
* 整體修改方法,合并部分參數(shù)
* 規(guī)范代碼,一個(gè)方法里只有1個(gè)return語(yǔ)句
*/
/*
參數(shù)說(shuō)明
int $debug 是否開啟調(diào)試,開啟則輸出sql語(yǔ)句
int $mode 0 返回?cái)?shù)組
1 返回單條記錄
2 返回行數(shù)
string $table 數(shù)據(jù)庫(kù)表
string $fields 需要查詢的數(shù)據(jù)庫(kù)字段,允許為空,默認(rèn)為查找全部
string $sqlwhere 查詢條件,允許為空
string $orderby 排序,允許為空,默認(rèn)為id倒序
*/
function hrSelect($debug, $mode, $table, $fields="*", $sqlwhere="", $orderby="id desc"){
global $pdo;
if($debug){
if($mode == 2){
echo "select count(*) from $table where 1=1 $sqlwhere order by $orderby";
}elseif($mode == 1){
echo "select $fields from $table where 1=1 $sqlwhere";
}else{
echo "select $fields from $table where 1=1 $sqlwhere order by $orderby";
}
exit;
}else{
if($mode == 2){
$rs = $pdo->query("select count(*) from $table where 1=1 $sqlwhere order by $orderby");
$return = $rs->fetchColumn();
}elseif($mode == 1){
$rs = $pdo->query("select $fields from $table where 1=1 $sqlwhere");
$return = $rs->fetch();
}else{
$rs = $pdo->query("select $fields from $table where 1=1 $sqlwhere order by $orderby");
$return = $rs->fetchAll();
}
return $return;
}
}
/*
參數(shù)說(shuō)明
int $debug 是否開啟調(diào)試,開啟則輸出sql語(yǔ)句
int $mode 0 默認(rèn)insert,無(wú)返回信息
1 返回執(zhí)行條目數(shù)
2 返回最后一次插入記錄的id
string $table 數(shù)據(jù)庫(kù)表
string $fields 需要插入數(shù)據(jù)庫(kù)的字段
string $values 需要插入數(shù)據(jù)庫(kù)的信息,必須與$fields一一對(duì)應(yīng)
*/
function hrInsert($debug, $mode, $table, $fields, $values){
global $pdo;
if($debug){
echo "insert into $table ($fields) values ($values)";
exit;
}else{
if($mode == 2){
$return = $pdo->lastInsertId("insert into $table ($fields) values ($values)");
}elseif($mode == 1){
$return = $pdo->exec("insert into $table ($fields) values ($values)");
}else{
$pdo->query("insert into $table ($fields) values ($values)");
exit;
}
return $return;
}
}
/*
參數(shù)說(shuō)明
int $debug 是否開啟調(diào)試,開啟則輸出sql語(yǔ)句
int $mode 0 默認(rèn)update,無(wú)返回信息
1 返回執(zhí)行條目數(shù)
string $table 數(shù)據(jù)庫(kù)表
string $set 需要更新的字段及內(nèi)容,格式:a='abc',b=2,c='2010-10-10 10:10:10'
string $sqlwhere 修改條件,允許為空
*/
function hrUpdate($debug, $mode, $table, $set, $sqlwhere=""){
global $pdo;
if($debug){
echo "update $table set $set where 1=1 $sqlwhere";
exit;
}else{
if($mode==1){
$return = $pdo->exec("update $table set $set where 1=1 $sqlwhere");
}else{
$pdo->query("update $table set $set where 1=1 $sqlwhere");
exit;
}
return $return;
}
}
/*
參數(shù)說(shuō)明
int $debug 是否開啟調(diào)試,開啟則輸出sql語(yǔ)句
int $mode 0 默認(rèn)delete,無(wú)返回信息
1 返回執(zhí)行條目數(shù)
string $table 數(shù)據(jù)庫(kù)表
string $sqlwhere 刪除條件,允許為空
*/
function hrDelete($debug, $mode, $table, $sqlwhere=""){
global $pdo;
if($debug){
echo "delete from $table where 1=1 $sqlwhere";
exit;
}else{
if($mode == 1){
$return = $pdo->exec("delete from $table where 1=1 $sqlwhere");
}else{
$pdo->query("delete from $table where 1=1 $sqlwhere");
exit;
}
return $return;
}
}
?>

另外一段代碼是基于我這個(gè)數(shù)據(jù)庫(kù)操作類的事務(wù)實(shí)例:
復(fù)制代碼 代碼如下:
/*
注意,數(shù)據(jù)庫(kù)操作表類型必須為InnoDB,其他類型不支持事務(wù)
PDO事務(wù)機(jī)制
$pdo->beginTransaction(); --開啟事務(wù)
$pdo->commit(); --結(jié)束事務(wù)
$pdo->rollBack(); --回滾操作

示例,用try/catch包住db操作,當(dāng)事務(wù)內(nèi)的db操作出現(xiàn)中斷,則執(zhí)行回滾并拋出異常信息。
*/
try{
$pdo->beginTransaction();
hrInsert(0,1,"class","name,parentid","'god',0"); //可以正常執(zhí)行
hrInsert(0,0,0,"tb_searchlog","userid,code","4"); //出錯(cuò)
$pdo->commit();
}catch(Exception $e){
$pdo->rollBack();
echo "Failed: " . $e->getMessage();
}

代碼下載:點(diǎn)擊下載

php技術(shù)一個(gè)基于PDO的數(shù)據(jù)庫(kù)操作類(新) 一個(gè)PDO事務(wù)實(shí)例,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 99热国产在线观看 | 国产在线毛片 | 国产福利写真视频在线观看 | 日韩三级中文 | 四虎影视永久免费视频观看 | 亚洲短视频在线观看 | 久久www免费人成看片色多多 | 国内成人免费视频 | 精品久久久影院 | 国产在线一区二区三区四区 | 999精品视频在线 | 日本韩国欧美一区 | 亚洲一区www | 免费看国产视频 | 九色综合伊人久久富二代 | 一区二区高清视频 | 五月婷婷六月丁香综合 | 久久国产精品只做精品 | 免费视频一区二区三区四区 | 色多多免费视频 | 亚洲精品美女久久久久网站 | 国产视频网站在线 | 福利视频免费 | 亚洲国产一区视频 | 国产激情视频在线播放 | 一区二区日韩 | 97成人精品 | 亚洲精品综合久久 | 国产精品第一页第一页 | 狠狠五月深爱婷婷网 | 一级做性色a爰片久久毛片免费 | 麻豆国产精品免费视频 | 最新97超级碰碰碰碰久久久久 | 久久精品国产在热久久2019 | 天天做天天爽爽快快 | 国产福利小视频在线播放 | 亚洲成年 | 激情图片激情小说激情视频 | 综合久久综合久久 | 91专区在线观看 | 加勒比色久综合在线 |