mysql乱码问题

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

原文: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>




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL Java
【MySQL】SpringBoot数据库操作乱码问题
【MySQL】SpringBoot数据库操作乱码问题
379 0
|
存储 关系型数据库 MySQL
EF(EntityFramework)与mysql使用,乱码问题
原文:EF(EntityFramework)与mysql使用,乱码问题 1.中文乱码问题        利用ef更新数据到mysql数据库中,中文就会变成乱码"???",就算把mysql的数据库的编码设置为"utf8"也会变成乱码,从网上查询了下,   在数据连接字符串后面加上:Character Set=utf8;即可,这样插入mysql的中文就不会变成乱码了。
1177 0
|
关系型数据库 MySQL
解决MySQL Workbench导出乱码问题
1、导出数据 2、默认CSV格式 3、乱码 4、解决 文件->另存为,会发现编码为UTF-8,正是MySQL表的编码方式。我们选择编码方式为ANSI,保存类型为所有,覆盖源文件 知识在于点滴积累
3525 0
|
关系型数据库 MySQL Unix
mysql 5.7.22设置中文编码-解决乱码问题 Linux
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.
1432 0
|
关系型数据库 MySQL 数据库
|
存储 关系型数据库 MySQL
MySQL数据导入导出乱码问题
数据库数据导入导出是经常发生的操作,但是有的时候却眼看一个看的懂的数据导入或者导出来,发现看不懂了,成了乱码,这是什么情况?
5374 0
|
关系型数据库 MySQL Java
|
存储 编解码 关系型数据库