Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/275.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP—解析uft-8文件并将其插入数据库会弄乱特殊字符,如é;_Php_Mysql_Phpmyadmin - Fatal编程技术网

PHP—解析uft-8文件并将其插入数据库会弄乱特殊字符,如é;

PHP—解析uft-8文件并将其插入数据库会弄乱特殊字符,如é;,php,mysql,phpmyadmin,Php,Mysql,Phpmyadmin,在Web服务器上,我有一个php脚本,它解析.sql文件(直接存储在服务器上),并在mysql数据库上执行查询。我有很多法语字符插入不好:é变成了Ã) 当我用notepad++打开sql文件时,我看到编码是“uft-8,无BOM” 我的脚本如下所示: $handle = fopen("test.sql", "r") or die("couldn't get handle"); if ($handle) { while (!feof($handle)) { $

在Web服务器上,我有一个php脚本,它解析.sql文件(直接存储在服务器上),并在mysql数据库上执行查询。我有很多法语字符插入不好:é变成了Ã)

当我用notepad++打开sql文件时,我看到编码是“uft-8,无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);
}
$handle=fopen(“test.sql”、“r”)或die(“无法获取句柄”);
如果($handle)
{
而(!feof($handle))
{
$buffer=fgets($handle,4096);
if(strlen($buffer)<3)//如果我们有一个空行
{       
mysql\u查询($query);
$query=$buffer;
睡眠(0.5);
} 
其他的
{
$query.=$buffer;
}
}
mysql_query($query);//最后一次插入
fclose($handle);
}

当我通过phpmyadmin打开数据库时,我看到在执行脚本之后,特殊字符已经被破坏。

在插入之前,您可能需要运行“SET NAMES UTF8”,因为mysql在字符编码方面非常古怪。可以,即使您的整个数据库已设置为使用UTF-8字符编码和general-utf8-ci排序规则


相反,您应该使用
mysql\u set\u charset
函数,而不是set NAMES查询,如中所述

即使您的数据库使用UTF-8,PHP使用UTF-8进行交易,默认设置的连接可能是拉丁语-1连接,因此MySQL将尝试转换数据,尽管它不应该很好!如注释所述:“注意:这是更改字符集的首选方法。不建议使用mysql_query()执行集合名称.。”目前,我认为我没有足够的mysql最新版本,但在更新时我肯定会记住这一点。谢谢。