mysql 空格乱码_mysql怎么设置中文?一招解决乱码问题

由于中文的特殊性,关于乱码问题也随着出现,想知道怎么处理吗?几个步骤即可,一起跟着学习设置吧~

中文乱码现象演示:

Mysqldump导入乱码[root@ testserv mytest]#/usr/local/mysql/bin/mysqldump testdb t_app_control -pxxxxxx > bc_tpc.sql[root@testserv mytest]#/usr/local/mysql/bin/mysql -uroot -pxxxxxx mytest  selectFGame,FArea,FGroup from t_app_controllimit 5;+--------+----------------------+-------------+| FGame | FArea | FGroup |+--------+----------------------+-------------+| ð | | WS--MXD || ð | 1ţ2Ģ || ð | 1ţ3 || ð | 1ţ4ƯƯ || ð | 1ţ5С |+--------+----------------------+-------------+

Loaddata导入乱码mysql> load data infile'/tmp/gongzuoshi.ttt' into table chartest;mysql> select * from chartestlimit 5;+----------+----------+-------------+--------------+| game_eng | game_chs |game_center | game_chs_new |+----------+----------+-------------+--------------+| game_eng | game_chs |game_center | game_chs_new || 1000y | ǧ | | || 2c | ˫ | | || 8m | | | || 9yin | | | |+----------+----------+-------------+--------------+5 rows in set (0.00 sec)

程序及MySQL字符集配置情况

出现乱码情况,首先确认写入程序使用的字符集,MySQL使用的字符集

MySQL使用的字符集情况

通过SHOW VARIABLES LIKE ‘character%’,在上面例子中通过语句获得字符集设置情况如下:mysql> show variables like'character%';+--------------------------+----------------------------------------+| Variable_name | Value |+--------------------------+----------------------------------------+| character_set_client | gbk || character_set_connection |gbk || character_set_database | gbk || character_set_filesystem |binary || character_set_results | gbk || character_set_server |gbk || character_set_system | utf8 || character_sets_dir | /usr/local/mysql/share/mysql/charsets/|+--------------------------+----------------------------------------+

Mysqldump导入乱码原因 :

1、首先确认mysqldump –help或查看备份文件头部信息确认默认字符集

在上例中通过mysqldump –help查看character-sets-dir (No default value)

通过备份文件查看-- MySQL dump 10.13 Distrib 5.1.52, for unknown-linux-gnu(x86_64)---- Host: localhost Database:backupcenter-- -------------------------------------------------------- Server version 5.1.52-log/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;/*!40101SET NAMES utf8 */;

2、通过 mysql –help 确认导入字符集default-character-set gbk

导入的两种情况如下

1)不修改备份文件,导入由于sql文件中存在set names utf8,则导入后字符集使用的依然是utf8,在系统默认显示字符集为gbk的情况下,则显示为乱码,此时则需要使用set names utf8 才能正常显示字符

2)修改备份文件,导入前将sql中的set names utf8 去除,在mysql默认字符集为gbk的情况下导入后字符集为gbk,此时mysql显示字符集为gbk,两者一致,则显示正常

总结:

1、编译安装MySQL的时候指定DEFAULT_CHARSET=[charset] 与写入程序保持一致

2、my.cnf中字符集设置与写入程序保持一致

3、导入数据时,将导入程序与数据库的链接配置为与数据库字符集一致

小伙伴们还可以试试建库、建表、连接数据库的时候,统一使用一个码表,也不会出现乱码情况呢~

如需了解更多python实用知识,点击进入PyThon学习网教学中心。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值