做一个包含越南文的网站,用户说在保存包含越南文的文章时,乱码了。
我自己测试一下,很多字符变成了 ‘?’。
数据库连接已经是使用了 utf8 字符集:
define("MYSQL_ENCODE", "UTF8");
mysql_query('SET NAMES '.MYSQL_ENCODE,$conn) or die('字符集设置错误'.mysql_error());
搞了大半小时,没有搞定。
insert 的数据都是仍然乱码,突然想,是不是字段不能保存这些越南文。
我看一下数据库字符集,默认都是 gbk,这个对中文是没有问题的,一碰到越南文,就乱码了。
于是,我将可能用到越南文的字段的字符集修改为 utf8,校对修改为:utf8_unicode_ci。(这里一定要具体修改某个字段,修改整个表的字符集,不起作用,字段还是保留着原来的字符集)
问题解决。
我的数据库为:php_college_web
表:city_article
用到越南文的字段:title,content
于是执行如下sql:
ALTER TABLE city_article CHANGE title title VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci
ALTER TABLE city_article CHANGE content content text CHARACTER SET utf8 COLLATE utf8_unicode_ci
分享到:
相关推荐
以下是解决 MySQL 保存越南文等非中文字符乱码的详细步骤和相关知识点: 1. **字符集与校对规则**: - 字符集(Character Set)定义了可以存储在数据库中的字符范围。例如,GBK 字符集主要支持简体中文,而 UTF-8 ...
默认情况下,SQL Server可能采用拉丁文的排序规则,这并不适合处理中文字符。当用户在创建数据库或插入中文数据时,如果没有指定正确的排序规则,就会遇到中文乱码的现象。 解决方法一涉及到在创建数据库时指定中文...
此外,处理越南语数据时,可能需要注意Excel的编码设置,以避免乱码问题。 学习如何在Excel 2003中使用UniKey,用户可能需要了解以下几点: 1. **安装UniKey**:首先,需要在Windows XP系统上安装UniKey,并确保其...
在使用西门子博途(TIA Portal)的WinCC人机界面进行项目开发时,可能会遇到一些常见的问题,如“内部错误”提示或屏幕显示乱码。这些问题可能会影响项目的正常运行和调试,但通常都有相应的解决策略。下面将详细...
8. **文件上传与编码**: 如果项目涉及上传包含越南语文本的文件,需要确保在保存或处理文件内容时正确处理编码,以避免乱码。 9. **错误处理与日志记录**: 在编码转换过程中可能出现错误,Laravel 的异常处理机制和...