转 mysqli 事务常用方法

原文:mysqli 事务常用方法

1、

//打开(true)或关闭(false)本次数据库连接的自动命令提交事务模式  
//参数如果设置为 FALSE,则表示关闭 auto-commit。如果设置为 TRUE,则表示开启 auto-commit(提交任何等待查询)。  
bool mysqli::autocommit ( bool $mode )  

2、

//回退当前事务  
bool mysqli::rollback ()  

3、

//提交一个事务  
bool mysqli::commit ()  

4、

//关闭先前打开的数据库连接  
bool mysqli::close ()  

5、

//对数据库执行一次查询  
//失败时返回 FALSE,通过mysqli_query() 成功执行SELECT, SHOW, DESCRIBE或 EXPLAIN查询会返回一个mysqli_result 对象,其他查询则返回TRUE  
//参数$resultmode可选。一个常量。可以是下列值中的任意一个:  
//MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个)  
//MYSQLI_STORE_RESULT(默认)  
mixed mysqli::query ( string $query [, int $resultmode = MYSQLI_STORE_RESULT ] )  

代码示例:

复制代码
<?php  
$mysqli = new mysqli("127.0.0.1","root","111111","test");  
if ($mysqli->connect_errno){  
    echo "Failed to connect to MySQL: " . $mysqli->connect_error;  
}  
//默认auto-commit 是打开的,可直接提交sql语句  
$b1 = $mysqli->query("INSERT INTO test (id,name) values (0,'000')");  
//若要执行事务,先关闭auto-commit  
//关闭 auto-commit  
$mysqli->autocommit(false);  
$res1 = $mysqli->query("INSERT INTO test (id,n1ame) values (1,'111')");  
$b2 = $mysqli->query("INSERT INTO test (id,name) values (2,'222')");  
//有一条失败则回滚,全部成功则提交  
if(!$res1 || !$b2){  
    echo '回滚!';  
    $mysqli->rollback();  
} else {  
    echo '提交!';  
    $mysqli->commit();  
}  
//若想再次自动提交非事务语句,要打开auto-commit  
$mysqli->autocommit(true);  
$b3 = $mysqli->query("INSERT INTO test (id,name) values (3,'333')");  
//关闭连接  
$mysqli->close();  
  
?>  
复制代码

 

posted @   jiafeng  阅读(175)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示