Mysql 把 ' 变成了 '?

2022-01-07 00:00:00 character-encoding mysql

如何在插入时阻止 mysql 将 ' 转换为 '?

How can I stop mysql from converting ' into ’ when I do an insert?

我相信它与字符集或什么有关?

i believe it has something to do with charset or something?

我正在使用 php 执行 mysql_insert.

I am using php to do the mysql_insert.

推荐答案

您发布的单引号称为 '重音',它经常被一些 Web 应用程序从通用单引号转换而来.它是一个 UTF8 字符,当插入到 Latin-1 数据库中时,它会转换为 '’'.这意味着您需要将 MySQL 的字符集更改为 UTF8,或者将您网站的字符集更改为 Latin-1.前者将是首选:

The single quotation mark you posted is called an 'acute accent', which is often converted from the generic single quotation mark by some web applications. It's a UTF8 character, which when inserted into a Latin-1 database translates to '’'. This means that you need to change MySQL's charset to UTF8, or alternatively change your website's charset to Latin-1. The former would be preferred:

ALTER DATABASE YourDatabase CHARACTER SET utf8;
ALTER TABLE YourTableOne CONVERT TO CHARACTER SET utf8;
ALTER TABLE YourTableTwo CONVERT TO CHARACTER SET utf8;
...
ALTER TABLE YourTableN CONVERT TO CHARACTER SET utf8;

相关文章