MySql5.7.18字符集配置图文详解

故事背景:

  很久很久以前(2017.6.5,文章有其时效性,特别是使用的工具更新换代频发,请记住这个时间,若已经没有价值,一切以工具官方文档为准),下了个mysql版本玩玩,刚好最新是mysql5.7.18,本机是win10、64位系统。大抵步骤分为:

  1、下载:以官网(https://www.mysql.com)为准,download响应系统版本;

  2、初始化:命令行(cmd)进入解压目录bin文件夹(下载下来后应该要解压吧?太久有点遗忘。还有下载下来是没有data这个文件夹以及ini等文件的),这里有两种初始化方式。一种叫不安全初始化,及输入: mysqld --initialize ,初始化使root这个用户没有密码(没密码所以不安全);一种就是所谓的安全初始化,输入: mysqld --initialize-insecure ,生成有密码的root用户,密码可以在生成后出现的日志文件里查看,就在初始化后生成的data文件里

  3、启动服务: 输入: net start mysql (关闭服务: 输入: net stop mysql),如果提示net不是内部命令,那么可能是net没安装,也可能是没配置环境变量 ,检查一下就行

  4、基本上应该是这样,其他的可以查询mysql命令大全去搞。

接下来说说配置字符集的问题。

起因:

  就是昨天,首先对着mysql命令行查看数据太过抽象,所以先下载了个Navicat for mysql(可视化界面),看起来就好多了。如图:

  然后在表中插入数据时会报错“Incorrect string value”,百度了一下说是要将字符集改为utf8mb4,这是因为其他编码存不了一些特殊字符的关系,详情可以百度。

经过:

  修改字符集首先进入mysql: mysql -uroot  (用户登录,因为初始化选了没密码的那种),show variables like 'char%'  (查看字符编码),如图:

  可以在命令行里输入例如: set character_set_server=utf8mb4  来改变字符集,但仅限当次有效,重启服务时会恢复默认值。接下来试试其他方法,网上众说纷纭,含糊不清,真假难以分辨 。于是上官网看了一下(官网也很水,没有例子可以参照,就像告诉瞎子白色是白色一样,而我就是那个瞎子),看了文档里有个查看变量的指令:mysqld --verbose --help,查看的变量都可以配置在选项文件里,每次启动服务就会按选项文件里的自动去配置,然后这里出现一句:

      Default options are read from the following files in the given order

  我想应该是选项文件可能存在的地方,也就是说我们新建出的选项文件要以它显示出来的名字命名,放到它显示出的该放的地方。如图:

  新建一个my.ini文件,放在D:\mysql下,刚好就是它显示出来位置的其中一个,如上图。my.ini内容如下:

  基本上就是以这样的形式来配,这里只拿了个罪魁祸首character_set_server,当然关联的字符集配置要统一,否则可能会乱码,可以去百度看看每一个字符集都代表什么意思。

  然后关闭mysql服务,开始配置(输入 mysqld --install):

  1、如果非管理员打开cmd输入 mysqld --install会报如下信息,说是命令被拒绝:

  2、改用管理员打开,说是服务已存在(那么先把它删了就好了):

  3、查询mysql服务: sc query mysql(也可以在控制面板-管理工具-服务中找到,或直接搜索服务)

  4、删了它:(也可以在控制面板-管理工具-服务中卸载,或直接搜索服务)

  5、当然重装前要停止mysql,即使先行删了它,否则会出现:

  6、我们停了它,这次是在控制面板停掉的,因为之前把它卸了,停掉后就消失不见(命令行: net stop mysql),重新执行,成功的同时启动mysql服务:

  7、重启成功,登上去上看看有没有改动成功:

  8、然后到此就可以了,之后又试了几次,只要改了my.ini后,关闭在重新启动mysql服务,它每次都会按my.ini来改,也就是说以后如果不满意不用从头走一遍,只要改my.ini后重启服务就好了。如图:

  我再改:

以上所述是小编给大家介绍的MySql5.7.18字符集配置图文详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

时间: 2017-06-04

mysql字符集和校对规则(Mysql校对集)

简要说明 字符集和校对规则 字符集是一套符号和编码.校对规则是在字符集内用于比较字符的一套规则. MySql在collation提供较强的支持,oracel在这方面没查到相应的资料. 不同字符集有不同的校对规则,命名约定:以其相关的字符集名开始,通常包括一个语言名,并且以_ci(大小写不敏感)._cs(大小写敏感)或_bin(二元)结束 校对规则一般分为两类: binary collation,二元法,直接比较字符的编码,可以认为是区分大小写的,因为字符集中'A'和'a'的编码显然不同. 字符集

修改mysql默认字符集的两种方法详细解析

(1) 最简单的修改方法,就是修改mysql的my.ini文件中的字符集键值,如 default-character-set = utf8    character_set_server = utf8 修改完后,重启mysql的服务,service mysql restart使用 mysql> SHOW VARIABLES LIKE 'character%';查看,发现数据库编码均已改成utf8 复制代码 代码如下: +--------------------------+-----------

mysql安装后添加gbk字符集的方法

1.查看当前字符集: 复制代码 代码如下: SHOW CHARACTER SET; 2.删除mysql相关目录 复制代码 代码如下: rm -rf /usr/local/mysql/*     安装目录rm -rf /var/lib/mysql/mysql   数据库目录 3.重新编译 复制代码 代码如下: ./configure --prefix=/usr/local/mysql --sysconfdir=/etc --localstatedir=/var/lib/mysql --with-c

基于mysql 5.5 设置字符集问题的详解

在虚拟机上安装了一个mysql,修改其my.cof文件,发现这个配置文件好强大,但是,遇到一个问题: 设置字符集时,分别在 [client].[mysql] 和 [mysqld] 下设置 default-character-set=utf8 ,但是出现以下问题: 一个个排查,发现是在 [mysqld] 下设置 default-character-set=utf8  导致的.查看/var/lib/mysql/${hostname}.err 文件: 问题是mysqld不识别 default-char

mysql修改数据库编码(数据库字符集)和表的字符编码的方法

mysql将表的字符编码转换成utf-8 复制代码 代码如下: alter table tb_anniversary convert to character set utf8; 修改数据库mysql字符编码为UTF8 步骤1:查看当前的字符编码方法 复制代码 代码如下: mysql> show variables like'character%'; +--------------------------+----------------------------+ |Variable_name 

MySQL字符集 GBK、GB2312、UTF8区别 解决MYSQL中文乱码问题

MySQL中涉及的几个字符集 character-set-server/default-character-set:服务器字符集,默认情况下所采用的. character-set-database:数据库字符集. character-set-table:数据库表字符集. 优先级依次增加.所以一般情况下只需要设置character-set-server,而在创建数据库和表时不特别指定字符集,这样统一采用character-set-server字符集. character-set-client:客户

MySQL skip-character-set-client-handshake导致的一个字符集问题

今天帮同事处理一个棘手的事情,问题是这样的: 无论在客户机用哪个版本的mysql客户端连接服务器,发现只要服务器端设置了 复制代码 代码如下: character-set-server = utf8 之后, 复制代码 代码如下: character_set_client. character_set_connection.character_set_results 就始终都是和服务器端保持一致了,即便在mysql客户端加上选项 复制代码 代码如下: --default-character-set

深入Mysql字符集设置 图文版

在mysql客户端与mysql服务端之间,存在着一个字符集转换器. character_set_client          =>gbk:转换器就知道客户端发送过来的是gbk格式的编码 character_set_connection=>gbk:将客户端传送过来的数据转换成gbk格式 character_set_results        =>gbk: 注:以上三个字符集可以使用set names gbk来统一进行设置 例子: create table test( name varc

MySQL的字符集操作命令总结

以下均在mysql 5.5命令行中运行通过: 查看MySQL支持的字符集: 复制代码 代码如下: show charset; 查看字符集: 复制代码 代码如下: status 下面的更具体: 复制代码 代码如下: SHOW VARIABLES LIKE 'character_set_%'; 查看排序方式: 复制代码 代码如下: SHOW VARIABLES LIKE 'collation_%'; 数据库建立时候一般会使用默认的字符集,除非在建立的时候指定: 复制代码 代码如下: CREATE D

关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况

mysql链接建立之后,通过如下方式设置编码: 复制代码 代码如下: mysql_query("SET character_set_connection=" . $GLOBALS['charset'] . ",character_set_results=" . $GLOBALS['charset'] . ",character_set_client=binary", $this->link); 然而建立出来的表结构描述竟然是乱码: 复制代码

深入Mysql字符集设置[精华结合]

基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如'A'.'B'等: • 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encoding).例如,我们给字符'A'赋予数值0,给字符'B'赋予数值1,则0就是字符'A'的编码: • 给定一系列字符并赋予对应的编码后,所有这些字符和编码对组成的集合就是字符集(Character Set).例如,给定字符列表为{'A','B'}时,{'A'=>0, 'B'=>1}就是一个字符集: •

深入Mysql字符集设置分析

基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如'A'.'B'等: • 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encoding).例如,我们给字符'A'赋予数值0,给字符'B'赋予数值1,则0就是字符'A'的编码: • 给定一系列字符并赋予对应的编码后,所有这些字符和编码对组成的集合就是字符集(Character Set).例如,给定字符列表为{'A','B'}时,{'A'=>0, 'B'=>1}就是一个字符集: •

带你5分钟读懂MySQL字符集设置

一.内容概述 在MySQL的使用过程中,了解字符集.字符序的概念,以及不同设置对数据存储.比较的影响非常重要.不少同学在日常工作中遇到的"乱码"问题,很有可能就是因为对字符集与字符序的理解不到位.设置错误造成的. 本文由浅入深,分别介绍了如下内容: 字符集.字符序的基本概念及联系 MySQL支持的字符集.字符序设置级,各设置级别之间的联系 server.database.table.column级字符集.字符序的查看及设置 应该何时设置字符集.字符序 二.字符集.字符序的概念与联系 在

mysql字符集乱码问题解决方法介绍

character-set-server/default-character-set:服务器字符集,默认情况下所采用的. character-set-database:数据库字符集. character-set-table:数据库表字符集. 优先级依次增加.所以一般情况下只需要设置character-set-server,而在创建数据库和表时不特别指定字符集,这样统一采用character-set-server字符集. character-set-client:客户端的字符集.客户端默认字符集.

MySQL字符集的基本类型与统一字符集分析

以下的文章主要介绍的是MySQL字符集的基本类型, 统一字符集的实际操作方法,等相关内容的介绍,以下就是MySQL字符集的相关内容的描述,希望你会在以后的学习或是工作中带来很大的帮助. 一. MySQL字符集类型 MySQL服务器中有六个关键位置使用了字符集的概念,他们是:client .connection.database.results.server .system. a.其中client是客户端使用的字符集,相当于网页中的字符集设置如下<meta http-equiv="Conte

mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip

设置mysql监听外网ip 复制代码 代码如下: sudo vi /etc/my.cnfbind-address = 127.0.0.1 设置mysql 字符集 charset 复制代码 代码如下: sudo vi /etc/my.cnf在[mysqld]下面加入一行character_set_server = utf8在[mysql]下面加入一行default-character-set = utf8sudo /usr/local/mysql/support-files/mysql.serve

mysql odbc字符集设置(中文显示乱码)

1.将mysql安装目录下的my.ini中的[client]项中添加default-character-set=gb2312 [client] default-character-set=gb2312 port=3306 2.将my.ini拷贝到c盘根目录,并修改名字为my.cnf 3.在配置odbc源时,选上Read Options From my.cnf这一项 MySQL ODBC字符集设置 mysql数据库字符集为utf8,使用delphi7的adoquery查询出的结果显示乱码 odbc