Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/235.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP PDO在事务中创建多个表_Php_Mysql_Transactions_Pdo - Fatal编程技术网

PHP PDO在事务中创建多个表

PHP PDO在事务中创建多个表,php,mysql,transactions,pdo,Php,Mysql,Transactions,Pdo,我有下面的PHP代码,它创建了三个数据库表,然后尝试回滚事务 $dbh = new \PDO("mysql:host=localhost;dbname=dbname", 'usernamehere', 'passwordhere'); $dbh->setAttribute(\PDO::ATTR_AUTOCOMMIT,FALSE); $dbh->beginTransaction(); $sql = "CREATE TABLE IF NOT EXISTS `a` (`id` int(11

我有下面的PHP代码,它创建了三个数据库表,然后尝试回滚事务

$dbh = new \PDO("mysql:host=localhost;dbname=dbname", 'usernamehere', 'passwordhere');
$dbh->setAttribute(\PDO::ATTR_AUTOCOMMIT,FALSE);
$dbh->beginTransaction();
$sql = "CREATE TABLE IF NOT EXISTS `a` (`id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=latin1;";
$dbh->exec($sql);
$sql = "CREATE TABLE IF NOT EXISTS `b` (`id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=latin1;";
$dbh->exec($sql);
$sql = "CREATE TABLE IF NOT EXISTS `c` (`id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=latin1;";
$dbh->exec($sql);
$dbh->rollBack();
我希望这些表不会被创建,但它们确实是。有什么想法吗?

老师回答了这个问题

一些数据库(包括MySQL)在事务中发出DROP TABLE或CREATE TABLE等数据库定义语言(DDL)语句时会自动发出隐式提交。隐式提交将阻止您回滚事务边界内的任何其他更改


不是专家,但你不需要在某个地方执行提交操作吗?谢谢,我很不好意思我错过了。