在web服务器上,我有一个php脚本,它解析一个.sql文件(直接存储在服务器上),并在mysql数据库上执行查询。我有很多法语字符没有很好地插入:变成。
当我用notepad++打开sql文件时,我看到编码是“uft-8 without BOM”。
我的剧本是这样的:
$handle = fopen("test.sql", "r") or die("couldn't get handle");
if ($handle)
{
while (!feof($handle))
{
$buffer = fgets($handle, 4096);
if (strlen ( $buffer ) < 3 ) // if we have a blank line
{
mysql_query($query);
$query = $buffer;
sleep(0.5);
}
else
{
$query .= $buffer;
}
}
mysql_query($query); // last insert
fclose($handle);
}
当我通过phpmyadmin打开数据库时,我看到在脚本执行之后特殊的字符已经被破坏了。
最佳答案
在插入之前,您可能需要运行“SET NAMES UTF8”,因为mysql在字符编码方面非常古怪。是的,即使您的整个数据库已经设置为使用UTF-8字符编码和general-utf8-ci排序规则。
http://forums.mysql.com/read.php?103,46870,46870#msg-46870
关于php - PHP-解析uft-8文件并将其插入数据库会弄乱é等特殊字符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3273006/