有关php,pdo中的问题:setAttribute(PDO:ATTR_ERRMODE,PDO:ERRMODE_EXCEPTION)含义解释?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有关php,pdo中的问题:setAttribute(PDO:ATTR_ERRMODE,PDO:ERRMODE_EXCEPTION)含义解释?相关的知识,希望对你有一定的参考价值。

另外像$stmt->bindParam(';country',$country,PDO::PARAM_STR)怎么解释,有点难看懂
是连接数据库上面的问题,非smarty,不要乱讲可好

参考技术A 绑定变量,防SQL注入
‘:country’ 对应字段
$country 对变量
PDO::PARAM_STR 对类型字符串本回答被提问者采纳
参考技术B 去学习smarty
好像是这个里面的。
php模板。。

PHP PDO 在事务中创建多个表

【中文标题】PHP PDO 在事务中创建多个表【英文标题】:PHP PDO Creating multiple tables in a transaction 【发布时间】:2012-01-06 15:16:57 【问题描述】:

我有以下一段 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();

我希望这些表不会被创建,但确实如此。有什么想法吗?

【问题讨论】:

不是专家,但您不必在某处执行提交操作吗? 【参考方案1】:

manual answers这个问题。

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

【讨论】:

谢谢你,我很尴尬我错过了。

以上是关于有关php,pdo中的问题:setAttribute(PDO:ATTR_ERRMODE,PDO:ERRMODE_EXCEPTION)含义解释?的主要内容,如果未能解决你的问题,请参考以下文章

php和mysql pdo查询

PHP PDO 在事务中创建多个表

php使用PDO连接mysql数据库

php 预编译 解析

PDO应用

(PDO)从id收集特定数据