Windows 10家庭中文版,MySQL  5.7.20,2018-05-07

Part.1 查找数据库的字符集编码

查看MySQL字符集编码:status命令

使用命令行登录MySQL服务器,然后输入status命令,可以查看到服务器的字符集编码及其它信息。

从下图可以看到,我的服务器(Server characterset)、数据库(Db characterset)的字符集编码是latin1。

上图找到了四个字符集编码,它们各自代表什么意思呢?

-Server characterset

数据库服务器的默认字符集编码,在后续创建数据库时,若无指定字符集编码,则新建的数据库默认使用此字符集编码。

-Db characterset

当前没有选择数据库(use database_name)时,显示新建数据库的默认字符集编码,同Server character;若已选择数

据库,则显示数据库的真实字符集编码。下图显示了一个字符集编码为utf8的数据库的status信息。

-Client characterset、Conn. characterset

客户端本身的字符集编码 和 客户端和服务器此时建立连接所使用的字符集编码。

还可以使用show variables命令查看更多字符集编码信息:show variables like 'char%'

show variables还可以查看更多的数据库的信息,可以使用help show variables命令查看它的具体用法

说明,show variables命令可以显示数据库的所有系统变量——全部 或者 根据需要查找,里面的有些变量可以放到数据库的启动

配置文件my.ini中,从而修改数据库的配置信息。更多资料和权威信息,请参考官网链接Server System Variables

Part.2 修改数据库默认字符集编码

两个问题:

为什么要修改默认字符集编码?

默认的是latin1,不支持中文,而我要存储的数据包括中文,因此,要更改。

当然,不更改也可以,这样的话,每次创建新的数据库时就需要指定字符集编码,如下:

create database if not exists test2 default charset utf8 collate utf8_general_ci;

将默认字符集编码修改为什么?

utf8(是utf8,不是utf-8,没有短横线)!

两种方式:

1.在命令行客户端修改

set character_set_server=utf8;

警告,这种方式在命令行客户端重启后无效。

试验:修改后创建数据库,检查新建数据库的字符集编码,预期是utf8。

2.在数据库服务器配置文件my.ini中修改

在my.ini文件中添加下面两行中任意一行即可默认字符集编码设置为utf8(存在于[mysqld]下面):

character_set_server = utf8
character-set-server = utf8

两行有什么区别吗?第一行用下划线连接,第二行用短横线连接,但是,都有效。

再次强调,是utf8,不是utf-8(短横线)。

这种方式就没有第一种的问题了,但是呢,配置后需要重启数据库服务器才会生效。

Part.3 附录

1.show variables、show status(显示数据库服务器状态)显示的内容太多——一屏显示不完,怎么办呢?

输出到文件中!

方法如下:

mysql -uroot -p -e "show variables" > d:\mysql.txt

回车,输入root账号密码,再回车即可将结果保存到d盘的mysql.txt文件中(保存到csv文件中或许更好?)。

注意,show variables命令用双引号括起来,单引号不行。

2.可以使用show character set;查看MySQL数据库服务器支持的字符集

3.服务器、数据库、表的字符集编码关系

若在创建数据库时没有指定,则其字符集编码 同 服务器;

若在数据库中创建表时没有指定,则其字符集编码 同 所在数据库。

不过,服务器、数据库、表的编码都可以通过命令行进行修改(各个字段的字符集编码也可以单独指定)。

4.查看表Table的编码

使用show create table...命令,如下图所示。

5.遗留问题

my.ini配置文件中的[mysqld]、[client]、[mysql]分别意味着什么?

参考链接:

https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html

https://dev.mysql.com/doc/refman/8.0/en/charset-configuration.html

https://blog.csdn.net/hwhua1986/article/details/53431852

https://blog.csdn.net/enlyhua/article/details/79638776

https://www.cnblogs.com/jiangxiaobo/p/6110647.html

https://zhidao.baidu.com/question/539586616.html

https://www.2cto.com/database/201112/114418.html

https://www.cnblogs.com/candle806/archive/2013/01/14/2859721.html

MySQL字符集编码相关的更多相关文章

  1. MySQL字符集编码

    MySQL字符集编码总结 之前内部博客上凯哥分享了一篇关于mysql字符集的文章,之前我对mysql字符集一块基本没有深究过,看到凯哥文章后有些地方有点疑惑,遂自己去看了mysql的官方文档,并參考了 ...

  2. 从一个慢查询到MySQL字符集编码

    从一个慢查询到MySQL字符集编码 目录 从一个慢查询到MySQL字符集编码 1. 问题起源 2. MySQL字符集和字符集排序规则 2.1 字符集相关概念 2.2 MySQL中的字符集和字符集排序规 ...

  3. linux下mysql字符集编码问题的修改

    安装完的MySQL的默认字符集为 latin1 ,为了要将其字符集改为用户所需要的(比如utf8),就必须改其相关的配置文件:由于linux下MySQL的默认安装目录分布在不同的文件下:不像windo ...

  4. mysql字符集编码乱码测试如下

    创建三个表tb_latin1,tb_utf8,tb_gbk,编码分别为latin1/utf8/gbk “你好a”字符串编码如下GBK : %C4%E3 %BA%C3 %61UTF-8 : %E4%BD ...

  5. MySQL字符集编码的理解分析

    今天帮同事处理一个棘手的事情,问题是这样的: 无论在客户机用哪个版本的mysql客户端连接服务器,发现只要服务器端设置了 character-set-server = utf8之后, characte ...

  6. mysql字符编码相关

    mysql> show variables like '%character%'; +--------------------------+--------------------------- ...

  7. mysql 查看编码方式

    一. 查看数据库的字符集 show variables like 'character\_set\_%'; 输出: +--------------------------+--------+ | Va ...

  8. Mysql查看编码方式

    查看数据库的字符集 show variables like 'character\_set\_%'; 输出: +--------------------------+--------+ | Varia ...

  9. {MySQL数据库初识}一 数据库概述 二 MySQL介绍 三 MySQL的下载安装、简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 初识sql语句

    MySQL数据库初识 MySQL数据库 本节目录 一 数据库概述 二 MySQL介绍 三 MySQL的下载安装.简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 ...

随机推荐

  1. 团体程序设计天梯赛 L1-049. 天梯赛座位分配(测试数据+不同方法)

    Data: /*33 2 1#11 4 7 10 13 16 19 22 25 2831 33 35 37 39 41 43 45 47 4951 53 55 57 59 61 63 65 67 69 ...

  2. 团体程序设计天梯赛 L2-016. 愿天下有情人都是失散多年的兄妹

    同时也要记录父母的性别,输出询问时要用到 #include <stdio.h> #include <stdlib.h> #include <string.h> #i ...

  3. 用R做时间序列分析之ARIMA模型预测

    昨天刚刚把导入数据弄好,今天迫不及待试试怎么做预测,网上找的帖子跟着弄的. 第一步.对原始数据进行分析 一.ARIMA预测时间序列 指数平滑法对于预测来说是非常有帮助的,而且它对时间序列上面连续的值之 ...

  4. 【Asp.net入门04】第一个ASP.NET 应用程序-如何添加Web窗体到网站中

    添加Web窗体 本部分内容: 什么是web form 怎样添加web form 1.添加Web窗体到项目中 Web 窗体是一项 ASP.NET 功能,您可以使用它为 Web 应用程序创建用户界面.We ...

  5. 使用MyEclipse 2014创建项目

    1. 打开MyEclipse 2014,如果是第一次运行,会提示设置workspace路径,如图: WorkSpace路径是指日后你自己利用MyEclipse创建项目时,项目文件的存放路径.通常不要放 ...

  6. NATS_08:NATS客户端Go语言手动编写

    NATS客户端    一个NATS客户端是基于NATS服务端来说既可以是一个生产数据的也可以是消费数据的.生产数据的叫生产者英文为 publishers,消费数据的叫消费者英文为 subscriber ...

  7. GO_09:GO语言基础之reflect反射

    反射reflection 1. 反射可以大大的提高程序的灵活性,使得 interface{} 有更大的发挥余地 2. 反射使用 TypeOf 和 ValueOf 函数从接口中获取目标对象信息 3. 反 ...

  8. CF916E Jamie and Tree

    CF916E Jamie and Tree 题意翻译 有一棵n个节点的有根树,标号为1-n,你需要维护以下三种操作 1.给定一个点v,将整颗树的根变为v 2.给定两个点u, v,将lca(u, v)所 ...

  9. android中倒计时控件CountDownTimer分析

    android中倒计时控件CountDownTimer分析 1 示例代码 new CountDownTimer(10000, 1000) { public void onTick(long milli ...

  10. Excel 之 字符串截取、拼接、和透视表

    假设有表如下: 如何得到E列的数据(格式为模式名.表名,如PDM_DATA.T05_GMS_NAV_SPV_PCH_RDM_TRX_EVT)?如何由E列得到F列数据(从E类中截取表名)? 1. 字符串 ...