gpt4 book ai didi

PHP - 解析 uft-8 文件并将其插入数据库会弄乱像 é 这样的特殊字符

转载 作者:行者123 更新时间:2023-11-29 01:47:24 25 4
gpt4 key购买 nike

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

当我用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 - 解析 uft-8 文件并将其插入数据库会弄乱像 é 这样的特殊字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3273006/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com