一、lampp环境下的数据库乱码问题

问题描述:

在做mysql练习的时候发现新创建的数据库中插入数据表中的记录中文出现乱码的问题,如下图:

经过多方查证,整里如下文挡:

前提:

我自己的环境是使用的lampp下的mysql,该配置文件是在/opt/lampp/etc/my.cnf;如果是自己安装的mysql,那么配置文件一般都在/etc/my.cnf

解决办法:

1、首先进入msyql,然后使用show variables like 'character%' ,执行编码显示,可以看到如下图所示:

默认的是客户端和服务器都用了latin1,所以会乱码。

2、修改/opt/lampp/etc/my.cof文件

[client]
#password = your_password
port = 3306
socket = /opt/lampp/var/mysql/mysql.sock
default-character-set=utf8 //添加该语句 [mysqld]
user = mysql
port=3306
socket = /opt/lampp/var/mysql/mysql.sock
skip-external-locking
key_buffer = 16M
max_allowed_packet = 1M
table_open_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
character_set_server=utf8 //添加该语句 [mysql]
no-auto-rehash
default-character-set=utf8 //添加该语句

在mysql,mysqld,client下分别添加如上语句

注意:如果修改后不能启动报错试试把default-character-set=utf8改为character_set_server=utf8;我这里遇到了该问题,所以去掉了default后就正常了 ,脚本中没有使用default-character-set=utf8。
3、使用命令drop database 数据库名,删除创建的数据库

4、重启mysql的服务:/opt/lampp/lampp restart

5、重新创建数据库及表结构,再次插入数据即可正常使用,如下图:

方法2:

网上还有另外一种使用SQL语句修改编码值的,但是我试了一下,通过SQL语句是可以修改编码值,但是重启mysql服务后还是会变回原来的值,而且即便使用SQL语句修改过来后在重新创建数据表在插入数据还是会产生乱码(也可能哪里操做不对,但是不我提倡这么修改)

使用SQL语句修改的方法:

1、首先进入mysql,然后在mysql下执行如下语句:

SET character_set_database = utf8;
SET character_set_server = utf8;

2、使用命令show variables like 'character%' ,执行编码显示,可以看到如下图所示:

3、在使用create database test;创建数据库,在该库中创建数据表,然后在插入数据,查看是否正常!

二、linux下yum自动安装MySQL乱码问题解决办法

******************************************************************************************************************************************************

如果使用yum方法自动安装的MySQL服务,则MySQL的配置文件是在/etc/my.cnf;修改该文件的时候可能出现该文件中只有[mysqld]、[mysqld_safe],如果我们只是在mysqld下边加入

default-character-set=utf8,无法将所有的选项都修改为utf8的格式,如下图:

所以这里我们需要在my.cnf文件下手动配置[client]选项并在该选项下加入:default-character-set=utf8即可,如下图:

添加完成后重启MySQL的服务,然后在重新创建数据库和数据表,之后在使用第三方管理工具连接就不会出现乱码的问题了,如下图。

总之遇到乱码的问题,可以通过show variables like 'character%' ; 该命令进行查看,将字符集设置成utf8后基本都会解决掉。

*******************************************************************************************************************************************************

参考文档:

http://www.pc6.com/infoview/Article_63586.html

http://blog.csdn.net/mengzhengjie/article/details/50040527

最新文章

  1. CGI, FastCGI, WSGI, uWSGI, uwsgi简述
  2. Tomcat口令猜解工具【Python脚本】
  3. CF453B Little Pony and Harmony Chest (状压DP)
  4. mgo中DBRef-数据查询测试
  5. 【转】dsadd user批量创建AD用户命令详解
  6. ylbtech-dbs:ylbtech-2,PAM(个人资产管理系统)
  7. iOS开发——实战OC篇&环境搭建之Xib(玩转UINavigationController与UITabBarController)
  8. vs2010 js代码折叠
  9. mydumper原理3
  10. Qt模拟C#的File类对文件进行操作
  11. linux网络编程:select()函数以及FD_ZERO、FD_SET、FD_CLR、FD_ISSET(转)
  12. Delphi Socket Demo
  13. python基础-------函数(二)
  14. 菜鸟先飞C#学习总结(一)
  15. 社团的CTF逆向题WriteUp
  16. JODA-TIME获取本月的第一天及最后一天
  17. C#中List按特定字段排序
  18. 12.Redis运维点
  19. 支付宝PC端单笔支付同步回调session失效问题
  20. 安装Window 10系统------计算机经验

热门文章

  1. python字典解析
  2. ASP.net-空白页的问题
  3. 二十、springboot之jpa开发@MappedSuperclass 注解说明
  4. No.12 selenium for python 截屏
  5. git —— 分支
  6. jersey 过滤器名称绑定的问题 NameBinding Provider
  7. Django render函数
  8. 好久没有写过SQL了,今天写了一句select in留存
  9. CCF CSP 201403-2 窗口
  10. Wpf使用Winform控件后Wpf元素被Winform控件遮盖问题的解决