Mysql turns #39; into #226;€™?(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;
这篇关于Mysql 把 ' 变成了 '?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Mysql 把 ' 变成了 '?
基础教程推荐
- 带更新的 sqlite CTE 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
