mysql_query是否提交了所有内容

时间:2013-02-08 22:20:57

标签: php mysql commit

我在php中使用mysql扩展,我知道它从PHP 5.5.0开始就被弃用了,但我已经使用这个扩展编写了很多代码。 在我看来像mysql_query提交查询,如果是这样意味着它设置为自动提交,如何设置所以它不自动提交。

1 个答案:

答案 0 :(得分:5)

旧的mysql扩展没有专门用于事务控制的函数,但您可以发出SQL语句来执行您想要的操作。

只需启动一个事务,您就可以在一个事务的持续时间内隐式关闭自动提交:

mysql_query("START TRANSACTION");

一旦COMMIT或ROLLBACK,自动提交模式将返回默认值。

mysql_query("COMMIT"); // or ROLLBACK

您可以通过设置会话变量来关闭整个会话的自动提交:

mysql_query("SET autocommit=0");

或者在MySQL实例上全局更改它,以便更改所有会话的默认值:

mysql_query("SET GLOBAL autocommit=0");

或者通过编辑/etc/my.cnf:

将其设置为在MySQL服务启动时更改全局设置
[mysqld]
autocommit=0

如果使用MySQL 5.1,则必须略有不同:

[mysqld]
init_connect='SET autocommit=0'

您可能已经知道了,但重复的是,如果您使用InnoDB表,事务只会意味着什么。 MyISAM表不支持事务,因此无论您的设置如何,它们始终都是自动提交的。与其他几个存储引擎相同,包括MEMORY和CSV。