mysql乱码问题

简介:

原文:http://www.jb51.net/article/31181.htm

我在navicat中的测试:

mysql> use code;
Database changed
mysql> set names 'utf8';
Query OK, 0 rows affected

mysql> select * from t2;
+--------------+
| test         |
+--------------+
| 测试utf8     |
| 阿萨斯       |
| 测试sdsdsgbk |
+--------------+
3 rows in set

mysql> insert into t2 values('cat不不不utf8');
Query OK, 1 row affected

mysql> select * from t2;
+---------------+
| test          |
+---------------+
| 测试utf8      |
| 阿萨斯        |
| 测试sdsdsgbk  |
| cat不不不utf8 |
+---------------+
4 rows in set

mysql> set names 'gbk
';
Query OK, 0 rows affected

mysql> insert into t2 values('cat不不不gbk
');
Query OK, 1 row affected

mysql> select * from t2;
+---------------+
| test          |
+---------------+
| ����utf8      |
| ����˹          |
| ����sdsdsgbk  |
| cat������utf8 |
| cat不不不gbk  |
+---------------+
5 rows in set

mysql> set names 'utf8';
Query OK, 0 rows affected

mysql> select * from t2;
+-----------------+
| test            |
+-----------------+
| 测试utf8        |
| 阿萨斯          |
| 测试sdsdsgbk    |
| cat不不不utf8   |
| cat涓嶄笉涓峠bk |
+-----------------+
5 rows in set

mysql> select * from t2;
+-----------------+
| test            |
+-----------------+
| 测试utf8        |
| 阿萨斯          |
| 测试sdsdsgbk    |
| cat不不不utf8   |
| cat涓嶄笉涓峠bk |
| cmd积极gbk      |
+-----------------+
6 rows in set

mysql> show variables like 'character%';
+--------------------------+---------------------------------------------------------------+
| Variable_name            | Value                                                         |
+--------------------------+---------------------------------------------------------------+
| character_set_client     | utf8                                                          |
| character_set_connection | utf8                                                          |
| character_set_database   | utf8                                                          |
| character_set_filesystem | binary                                                        |
| character_set_results    | utf8                                                          |
| character_set_server     | utf8                                                          |
| character_set_system     | utf8                                                          |
| character_sets_dir       | D:\Program Files (x86)\MySQL\MySQL Server 5.0\share\charsets\ |
+--------------------------+---------------------------------------------------------------+
8 rows in set

mysql> 

在cmd中的测试:

mysql> set names 'utf8';
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t2 values('测试sdsdsutf8');
ERROR 1406 (22001): Data too long for column 'test' at row 1
mysql> set names 'gbk';
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t2 values('测试sdsdsgbk');
Query OK, 1 row affected (0.32 sec)

mysql> select * from t2;
+--------------+
| test         |
+--------------+
| 测试utf8     |
| 阿萨斯       |
| 测试sdsdsgbk |
+--------------+
3 rows in set (0.00 sec)

mysql> select * from t2;
+-----------------+
| test            |
+-----------------+
| 测试utf8        |
| 阿萨斯          |
| 测试sdsdsgbk    |
| cat不不不utf8   |
| cat涓嶄笉涓峠bk |
+-----------------+
5 rows in set (0.00 sec)

mysql> set names 'gbk';
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t2;
+-----------------+
| test            |
+-----------------+
| 测试utf8        |
| 阿萨斯          |
| 测试sdsdsgbk    |
| cat不不不utf8   |
| cat涓嶄笉涓峠bk |
+-----------------+
5 rows in set (0.00 sec)

mysql> set names 'utf8';
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t2;
+----------------------+
| test                 |
+----------------------+
| 娴嬭瘯utf8           |
| 闃胯惃鏂?           |
| 娴嬭瘯sdsdsgbk       |
| cat涓嶄笉涓島tf8     |
| cat娑撳秳绗夋稉宄燽k |
+----------------------+
5 rows in set (0.00 sec)





mysql> set names 'utf8';
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t2;
+----------------------+
| test                 |
+----------------------+
| 娴嬭瘯utf8           |
| 闃胯惃鏂?           |
| 娴嬭瘯sdsdsgbk       |
| cat涓嶄笉涓島tf8     |
| cat娑撳秳绗夋稉宄燽k |
+----------------------+
5 rows in set (0.00 sec)

mysql> insert into t2 values('cmd积极utf8');
ERROR 1406 (22001): Data too long for column 'test' at row 1
mysql> insert into t2 values('cmd积极utf8');
ERROR 1406 (22001): Data too long for column 'test' at row 1
mysql> set names 'gbk';
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t2 values('cmd积极gbk');
Query OK, 1 row affected (0.05 sec)

mysql> select * from t2;
+-----------------+
| test            |
+-----------------+
| 测试utf8        |
| 阿萨斯          |
| 测试sdsdsgbk    |
| cat不不不utf8   |
| cat涓嶄笉涓峠bk |
| cmd积极gbk      |
+-----------------+
6 rows in set (0.00 sec)

mysql> show variables like 'charcate%';
Empty set (0.00 sec)

mysql> show variables like 'character%';
+--------------------------+---------------------------------------------------------------+
| Variable_name            | Value                                                         |
+--------------------------+---------------------------------------------------------------+
| character_set_client     | gbk                                                           |
| character_set_connection | gbk                                                           |
| character_set_database   | utf8                                                          |
| character_set_filesystem | binary                                                        |
| character_set_results    | gbk                                                           |
| character_set_server     | utf8                                                          |
| character_set_system     | utf8                                                          |
| character_sets_dir       | D:\Program Files (x86)\MySQL\MySQL Server 5.0\share\charsets\ |
+--------------------------+---------------------------------------------------------------+
8 rows in set (0.00 sec)

mysql>




相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
关系型数据库 MySQL
MySQL实战基础知识入门(5):命令行汉字中文输出乱码的解决方案
MySQL实战基础知识入门(5):命令行汉字中文输出乱码的解决方案
225 0
|
关系型数据库 MySQL API
Mysql 8.0 C API连接和获取数据实例(附解决乱码的彩蛋)
Mysql 8.0 C API连接和获取数据实例(附解决乱码的彩蛋)
Mysql 8.0 C API连接和获取数据实例(附解决乱码的彩蛋)
|
JSON 数据库 数据格式
mysql-connector-java json数据乱码
经测试版本最低也5.1.40以上,于是升级到了5.1.40.现在的最新版本是5.1.49,果然数据库的json数据查询正常了,如果com.mysql.jdbc.Driver报错,删除scope,查询时候要使用json函数:json_extract(json字段名,’$’);
mysql-connector-java json数据乱码
|
关系型数据库 MySQL
Mysql输出中文显示乱码处理
Mysql输出中文显示乱码处理
532 0
Mysql输出中文显示乱码处理
|
SQL 关系型数据库 MySQL
MySQL - Navicat MySQL 乱码解决
MySQL - Navicat MySQL 乱码解决
303 0
MySQL - Navicat MySQL 乱码解决
|
关系型数据库 MySQL
最讨厌的乱码之 MySQL 乱码
乱码原因 解决方法 原因 总结
最讨厌的乱码之 MySQL 乱码
|
存储 SQL 关系型数据库
【肝了三天-建议收藏】实战-万字长文-带你刨析MySQL乱码、字符集和比较规则
【肝了三天-建议收藏】实战-万字长文-带你刨析MySQL乱码、字符集和比较规则
268 0
【肝了三天-建议收藏】实战-万字长文-带你刨析MySQL乱码、字符集和比较规则
|
关系型数据库 MySQL Java
【MySQL】SpringBoot数据库操作乱码问题
【MySQL】SpringBoot数据库操作乱码问题
622 0
|
关系型数据库
MySQL命令窗口下中文显示乱码的解决过程
MySQL命令窗口下中文显示乱码的解决过程在dos客户端输出窗口中查询表中的数据,还有项目部署到服务器上时前台的页面,中文数据都显示成乱码,如下图所示: 这个问题困扰了我一天,后来解决了才发现原来我的方向错了,一直我以为是SpringBoot项目的原因,因为之前我已经检查过数据库这边的字符集问题,...
1280 0
|
数据可视化 MySQL 关系型数据库
mysql命令框中向表中插入中文字符,在可视化工具MySQL Workbeach或phpMyAdmin中不显示或显示乱码的问题解决
mysql命令框中向表中插入中文字符,在可视化工具MySQL Workbeach或phpMyAdmin中不显示或显示乱码的问题解决一、问题导出     在刚刚开始学习MySQL数据库应用与开发这门课程的时候,老师建议我们使用可视化工具MySQL Workbeach进行数据库的相关管理,但是小编在mysql命令框使用insert命令向表中插入中文数据的时候发现出现了warnings警告,并且打开MySQL Workbeach查看输入数据的时候发现,输入的数据为空或者是?????几个问号,于是便想到了字符格式的问题。
1394 0

推荐镜像

更多