插入PHP的MySQL编码

时间:2012-07-01 18:43:13

标签: mysql character-encoding

当我在mySQL表中插入名称时,我遇到编码问题,其中包含特殊字符,如“ö”,“ä”等。 例如,单词“Öl”变为“Ãl”。

我试图将名称写入文本文件然后它们正确显示。

我尝试使用SQL语句在phpMyAdmin中插入名称,这也很好。

现在我在插入查询之前找到了设置mysql_query('SET NAMES utf8;');的解决方案。 这是应该怎么做,还是有更好的方法?

1 个答案:

答案 0 :(得分:1)

是的,运行SET NAMES utf8;需要让MySQL知道客户端连接在发送数据时使用ut8。您现在可以在PDO连接中定义它(如果您使用PDO连接到MySQL)。

如果运行早于5.3.6的PHP版本,则可以使用以下代码:

$pdo = new PDO(
'mysql:host=mysql.example.com;dbname=example_db',
"username",
"password",
array(PDO::MYSQL\_ATTR\_INIT\_COMMAND => "SET NAMES utf8"));

否则请使用以下内容:

$pdo = new PDO("mysql:host=localhost;dbname=world;charset=utf8", 'my_user', 'my_pass');