记忆力不好了,转来的记录下
一)不能显示中文解决办法:
参考:http://bbs3.chinaunix.net/thread-880131-1-1.html
1:windows平台,因为windows操作系统默认的是用了gb2312这个字符,而mysql在安装的时候,
默认的是客户端和服务器都用了latin1,所以这就导致一个字符集和字符校验不匹配的问题,
这个时候只需要找到mysql的配置文件my.ini 找到default-character_set ,把他的参数改
成gb2312就可以了,一共有两个这样的参数,一个是对客户的,一个是服务器的,我一般建
议是把服务器的设置成国际通用的字符utf8。
2: linux平台,在linux平台上安装mysql的时候,给于的自由度是很大的,你可以在安装
选项./configure中找到数据库的字符设置(这个还要麻烦你自己看readme安装文件 ),这个时
候最好是把字符设置成gbk,因为这个字符集也是linux平台默认安装的中文字符集,然后
在/etc下找到my.cnf文件(这个文件在安装mysql后要自己把他转移到/etc/下,除非你是
rpm安装).需要注意的是linux里的很多工具都是不支持中文的,哪怕是vi,你可以在startx
后执行命令kwrite,来编译文件,这个图形变异软件有一个选项是可以把你所写的东西转换
成任意的字符集,很不错,
二)不能插入中文解决办法:
参考:http://blog.csdn.net/ancky_zhang/archive/2008/10/15/3078540.aspx
查看表的结构:
mysql> show create users;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near 'users
' at line 1
mysql> show create table users;
+-------+-----------------------------------------------------------------------
------------------------------------------------------------------------------+
| Table | Create Table
|
+-------+-----------------------------------------------------------------------
------------------------------------------------------------------------------+
| users | CREATE TABLE `users` (
`userid` int(11) default NULL,
`username` char(20) character set latin1 default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gbk |
+-------+-----------------------------------------------------------------------
------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> desc users;
+----------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+----------+------+-----+---------+-------+
| userid | int(11) | YES | | NULL | |
| username | char(20) | YES | | NULL | |
+----------+----------+------+-----+---------+-------+
2 rows in set (0.02 sec)
这时向表中插入中文然后有错误。
mysql> insert into users values(88,'中文');
ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column 'usern
ame' at row 1
mysql> insert into users values(88,'中文');
ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column 'usern
ame' at row 1
还要更改users表的username的字符集。
mysql> alter table users modify username char(20) character set gbk;
ERROR 1366 (HY000): Incorrect string value: '\xC0\xEE\xCB\xC4' for column 'usern
ame' at row 1
mysql> alter table users modify username char(20) character set gbk;
ERROR 1366 (HY000): Incorrect string value: '\xC0\xEE\xCB\xC4' for column 'usern
ame' at row 1
因为表中已经有数据,所以更改username字符集的操作没有成功
清空users表中的数据
mysql> truncate table users;
Query OK, 3 rows affected (0.01 sec)
从新更改user表中username的字符集
mysql> alter table users modify username char(20) character set gbk;
Query OK, 0 rows affected (0.06 sec)
Records: 0 Duplicates: 0 Warnings: 0
这时再插入中文字符,插入成功。
mysql> insert into users values(88,'中文');
Query OK, 1 row affected (0.01 sec)
mysql> select * from users;
+--------+----------+
| userid | username |
+--------+----------+
| 88 | 中文 |
+--------+----------+
1 row in set (0.00 sec)
http://blog.sina.com.cn/s/blog_48f0f4da0100cktq.html
分享到:
相关推荐
个人总结了遇到使用Mysql数据库插入中文时产生乱码问题的解决方法
java插入mysql中文乱码解决
NULL 博文链接:https://441415.iteye.com/blog/986178
mysql插入数据中文报错问题,最全解决方式。 mysql 插入数据报错
NULL 博文链接:https://liyaxi.iteye.com/blog/467234
mysql 不能插入中文和显示中文,不能显示中文解决办法
mysql_不能插入中文的解决办法 mysql_不能插入中文的解决办法
已解决讨厌的乱码问题,这个问题让我头疼死了,终于解决了
JSP MySQL插入数据时出现中文乱码问题的解决方法.docx
主要介绍了JSP MySQL插入数据时出现中文乱码问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
用C#操作mysql时, 插入数据中文都是乱码,只显示问号,数据库本身使用的是utf-8字符
MySQL中文参考手册.chm 449kb <br/>0 译者序 1 MySQL的一般的信息 1.1 什么是MySQL? 1.2 关于本手册 1.2.1 本手册中使用的约定 1.3 MySQL的历史 1.4 MySQL的主要特征 1.5...
本文介绍了在mysql安装时选择了utf8编码方式,创建数据库时也选择了utf8,但是通过程序向数据库中插入数据时,仍存在乱码问题的解决方法
本文给大家介绍的是如何解决win平台下开发的项目移植到Linux平台后,向MySQL插入数据时中文出现乱码的问题,非常的简单实用,有需要的小伙伴可以参考下
登录MySQL,先做 set names latin1 ,然后在更新语句或者执行SQL语句 mysql> set names latin1; mysql> source test.sql; 方法二: 在SQL文件中指定set names latin1;然后登录MySQL,执行相应文件 [root@localhost ...
NULL 博文链接:https://gaojiewyh.iteye.com/blog/469371
+ 4.15.2 启动 MySQL 服务器的问题 + 4.15.3 自动启动和停止 MySQL + 4.15.4 选项文件 o 4.16 升级和降级(downgrading)时有什么特别要做的事情吗? + 4.16.1 从一个 3.22 版本升级到 3.23 + 4.16.2 从一个 ...
mac OSX 系统 MySQL中文乱码解决办法
本篇文章主要介绍了centOS7下mysql插入中文字符报错问题解决,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。