首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PDO::commit

(PHP 5 >= 5.1.0, PHP 7, PECL pdo >= 0.1.0)

PDO :: commit - 提交一个事务

Description

代码语言:javascript
复制
public bool PDO::commit ( void )

提交事务,将数据库连接返回到自动提交模式,直到下一次调用PDO :: beginTransaction()启动新的事务。

Return Values

返回TRUE成功或返回FALSE失败。

Errors/Exceptions

如果没有活动事务,则抛出PDOException。

注意:即使不是PDO::ATTR_ERRMODE属性,也会引发异常PDO::ERRMODE_EXCEPTION

Examples

示例#1提交基本事务

代码语言:javascript
复制
<?php
/*?Begin?a?transaction,?turning?off?autocommit?*/
$dbh->beginTransaction();

/*?Insert?multiple?records?on?an?all-or-nothing?basis?*/
$sql?=?'INSERT?INTO?fruit
????(name,?colour,?calories)
????VALUES?(?,??,??)';

$sth?=?$dbh->prepare($sql);

foreach?($fruits?as?$fruit)?{
????$sth->execute(array(
????????$fruit->name,
????????$fruit->colour,
????????$fruit->calories,
????));
}

/*?Commit?the?changes?*/
$dbh->commit();

/*?Database?connection?is?now?back?in?autocommit?mode?*/
?>

示例#2提交DDL事务

代码语言:javascript
复制
<?php
/*?Begin?a?transaction,?turning?off?autocommit?*/
$dbh->beginTransaction();

/*?Change?the?database?schema?*/
$sth?=?$dbh->exec("DROP?TABLE?fruit");

/*?Commit?the?changes?*/
$dbh->commit();

/*?Database?connection?is?now?back?in?autocommit?mode?*/
?>

注意:并非所有的数据库都允许事务在DDL语句上操作:有些会产生错误,而另一些(包括MySQL)会在遇到第一个DDL语句后自动提交事务。

代码语言:txt
复制
 ? 1997–2017 The PHP Documentation Group

根据知识共享署名许可证v3.0或更高版本授权。

扫码关注腾讯云开发者

领取腾讯云代金券

http://www.vxiaotou.com