linux下插入的mysql数据乱码问题及第三方工具显示乱码问题
一、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
linux下插入的mysql数据乱码问题及第三方工具显示乱码问题的更多相关文章
- linux下如何安装mysql和redis
linux下如何安装mysql(mariadb) linux下如何安装软件? 1. yum安装软件也得注意,一个是配置yum源 1.我们当前的是阿里云的yum源(下载速度特别快) 通过 yum ins ...
- Linux下定时备份MySQL数据库的Shell脚本
Linux下定时备份MySQL数据库的Shell脚本 对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间 ...
- Linux下mongodb安装及数据导入导出教程
Linux下mongodb安装及数据导入导出教程 #查看linux发行版本 cat /etc/issue #查看linux内核版本号 uname -r 一.Linux下mongodb安装的一般步骤 1 ...
- Linux下yum安装MySQL
写这篇文章的原因是:在刚开始使用Linux操作系统时想要搭建LAMP环境,于是开始在Google和百度上各种寻找资料,碰到了不是很多的问题后,我决定写这篇文章总结一下在Linux下yum安装MySQL ...
- Linux下Rsync+sersync实现数据实时同步
inotify 的同步备份机制有着缺点,于是看了sersync同步,弥补了rsync的缺点.以下转自:http://www.osyunwei.com/archives/7447.html 前言: 一. ...
- (转载)Linux下安装配置MySQL+Apache+PHP+WordPress的详细笔记
Linux下安装配置MySQL+Apache+PHP+WordPress的详细笔记 Linux下配LMAP环境,花了我好几天的时间.之前没有配置过,网上的安装资料比较混乱,加上我用的版本问题,安装过程 ...
- linux下如何查看mysql、apache是否安装,并卸载
--linux下如何查看mysql.apache是否安装,并卸载? http://blog.163.com/dengxiuhua126@126/blog/static/1186077720137311 ...
- Linux下自动备份MySQL数据库并上传到远程FTP服务器
Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...
- linux下彻底卸载mysql 图解教程
linux下彻底卸载mysql 图解教程 1.查找以前是否装有mysql 命令:rpm -qa|grep -i mysql可以看到如下图的所示: 说明之前安装了:MySQL-client-5.5.25 ...
随机推荐
- C#里partial关键字的作用
1. 什么是局部类型?C# 2.0 引入了局部类型的概念.局部类型允许我们将一个类.结构或接口分成几个部分,分别实现在几个不同的.cs文件中.局部类型适用于以下情况: (1) 类型特别大,不宜放在一个 ...
- Add custom daemon on Linux System
Ubuntu add custom service(daemon) Task 需要在系统启动的时候自动启动一个服务(后台程序),在系统关闭的时候关闭服务. 比如在部署某个应用之前,需要将某个任务设置成 ...
- VM虚拟机和主机互传文件,使用xshell连接Ubuntu
安装虚拟机后,有时需要在window和Ubuntu互传文件,安装VMwave tooles比较麻烦,干脆直接用xshell连接Ubuntu即可 1,已经安装Ubuntu和xshell 2,在Ubunt ...
- springquartz的LocalDataSourceJobStore
spring 为quartz 提供了一个 继承 JobStoreCMT的 LocalDataSourceJobStore,主要是为了和spring更好的集成. public class LocalDa ...
- Code Conventions for the JavaScript Programming Language
This is a set of coding conventions and rules for use in JavaScript programming. It is inspired by t ...
- MyBatis3.4.0以上的分页插件错误:Could not find method on interface org.apache.ibatis.executor.statement.StatementHandler named prepare. Cause: java.lang.NoSuchMethodException: org.apache.ibatis.executor.stateme
错误: Could not find method on interface org.apache.ibatis.executor.statement.StatementHandler named p ...
- Codeforces 798C - Mike and gcd problem(贪心+数论)
题目链接:http://codeforces.com/problemset/problem/798/C 题意:给你n个数,a1,a2,....an.要使得gcd(a1,a2,....an)>1, ...
- C++之构造函数的继承
#include<iostream> usingnamespace std; classBase1 { public: Base1()=default; Base1(const strin ...
- Linux 相关
一.WCHAN的含义 WCHAN 进程正在睡眠的内核函数名称:该函数的名称是从/root/system.map文件中获得的. 参考:解析ANDROID ps命令执行后各项参数的含义 二.查看线程 ps ...
- CI框架整合UEditor编辑器上传功能
最近项目中要使用到富文本编辑器,选用了功能强大的UEditor,接下来就来讲讲UEditor编辑器的上传功能整合. 本文UEditor版本:ueditor1_4_3_utf8_php版本 第一步:部署 ...