【发布时间】:2012-02-23 12:49:12
【问题描述】:
我在将带有特殊字符的单词插入数据库时遇到问题。这个词似乎在特殊字符处被截断。
我使用的是 MySQL 5.1.41,我的数据库上的排序规则是 utf8_general_ci。我正在使用 PDO 来促进数据库交互。
这是我正在做的一个例子。
//$db is a PDO object
$db->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES 'utf8'");
//word with a special character
$word = "pépite";
$sql = "INSERT INTO keyword(key_name) VALUES(?)";
$stmt = $db->prepare($sql);
$stmt->execute(array($word));
执行此操作时,我的数据库中只出现“p”,似乎字符 é 以及它被截断后的所有内容。我不确定我在这里做错了什么。如果有人可以建议我做错了什么,将不胜感激。谢谢!
【问题讨论】:
-
您是否正在使用
mysqliPHP 客户端而不是mysql客户端? -
是每次只截掉一个字符,还是只存储直到特殊字符的所有内容?