插入语句不适用于 PDO


INSERT statement does not work with PDO

编辑:PDO似乎与列名Unité中的法语字符有问题。是否有解决方案,或者我是否需要重命名数据库中的列?

SELECT 语句适用于 PDO,但 INSERT 语句不适用于。

连接字符串:

$dbCon = new PDO("mysql:host=".$host.";dbname=".$dbName.";charset=utf8", $username, $password);

工作选择语句:

$sql = 'SELECT * FROM availability WHERE event_id=:postID';
$stmt = $dbCon->prepare($sql);
$stmt->execute(array(':postID'=>$postID));
$result = $stmt->fetchAll();

不起作用的插入语句:

$sql = 'INSERT INTO `availability` (`event_id`,`Nom`,`Address`,`Address2`,`Tel1`,`Tel2`,`Tel3`,`Classement`,`Soleil`,`Unité`,`Dispo`,`Ville`,`Type`,`URL`,`Jour1`,`Jour2`,`Jour3`,`Jour4`,`Jour5`,`Jour6`,`Jour7`,`Jour8`,`Jour9`,`Jour10`,`Jour11`,`Jour12`,`Jour13`,`Jour14`,`Jour15`,`visible`) (SELECT :postID,`Nom`,`Address`,`Address2`,`Tel1`,`Tel2`,`Tel3`,`Classement`,`Soleil`,`Unité`,`Dispo`,`Ville`,`Type`,`URL`,`Jour1`,`Jour2`,`Jour3`,`Jour4`,`Jour5`,`Jour6`,`Jour7`,`Jour8`,`Jour9`,`Jour10`,`Jour11`,`Jour12`,`Jour13`,`Jour14`,`Jour15`,`visible` FROM `default_hotels`)';
$stmt = $dbCon->prepare($sql);
$stmt->execute(array(':postID'=>$postID));
$result = $stmt->fetchAll();

另一个有效的 SELECT 语句:

$sql = 'SELECT post_title FROM wp_posts WHERE id=:postID';
$stmt = $dbCon->prepare($sql);
$stmt->execute(array(':postID'=>$postID));
$records = $stmt->fetchAll();

所有语句都按此顺序出现在我的脚本中。变量被重用且不会清除。

我提供的SQL INSERT语句在通过phpmyadmin提交时有效,但不能通过PDO提交。

PHP 5.3.6 开始支持连接字符串中的 PDO charset 参数。在此之前,它什么也没做。所以问题在于与数据库的连接实际上不是在 utf8 中运行的,而是可能是 latin1。因此,PHP 和 MySQL 中列名的编码不匹配,因此 MySQL 误解了列名,因此找不到您要求的列。

有关指定连接编码、升级 PHP 版本或仅使用 ASCII 作为列名的替代方法,请参阅 https://stackoverflow.com/a/279279/476(无论如何,这是一个好主意,特别是因为它使兼容性问题变得不那么严重)。