当我在mySQL表中插入名称时,我遇到编码问题,其中包含特殊字符,如“ö”,“ä”等。 例如,单词“Öl”变为“Ãl”。
我试图将名称写入文本文件然后它们正确显示。
我尝试使用SQL语句在phpMyAdmin中插入名称,这也很好。
现在我在插入查询之前找到了设置mysql_query('SET NAMES utf8;');
的解决方案。
这是应该怎么做,还是有更好的方法?
答案 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');