mysql 字符集排查
mysql 字符集排查
库级别
SELECT
*
FROM
information_schema.schemata
WHERE
schema_name NOT IN ( 'information_schema', 'performance_schema', 'mysql', 'sys' )
AND ( default_character_set_name <> 'utf8' OR default_collation_name <> 'utf8_general_ci' );

表级别
SELECT
TABLE_SCHEMA,
TABLE_NAME,
TABLE_TYPE,
TABLE_ROWS,
TABLE_COLLATION,
CREATE_OPTIONS
FROM
information_schema.TABLES
WHERE
TABLE_TYPE = 'BASE TABLE'
AND TABLE_SCHEMA NOT IN ('information_schema' , 'performance_schema', 'mysql', 'sys')
AND TABLE_COLLATION <> 'utf8_general_ci';

字段级别
SELECT
TABLE_SCHEMA AS '库名',
DEFAULT_CHARACTER_SET_NAME AS '库的字符集',
DEFAULT_COLLATION_NAME AS '库的校对字符集',
TABLE_NAME AS '表名',
TABLE_COLLATION AS '表的校对规则',
COLUMN_NAME AS '字段名',
CHARACTER_SET_NAME AS '字段的字符集',
COLLATION_NAME AS '字段的校对规则'
FROM
(SELECT
C2.TABLE_SCHEMA,
C2.TABLE_NAME,
C2.CHARACTER_SET_NAME,
T2.TABLE_COLLATION,
C2.COLUMN_NAME,
C2.COLLATION_NAME,
S2.DEFAULT_CHARACTER_SET_NAME,
S2.DEFAULT_COLLATION_NAME,
CASE
WHEN
S2.DEFAULT_CHARACTER_SET_NAME = 'utf8'
AND S2.DEFAULT_COLLATION_NAME = 'utf8_general_ci'
AND (C2.CHARACTER_SET_NAME = 'utf8'
OR C2.CHARACTER_SET_NAME IS NULL)
AND (C2.COLLATION_NAME = 'utf8_general_ci'
OR C2.COLLATION_NAME IS NULL)
AND T2.TABLE_COLLATION = 'utf8_general_ci'
THEN
'true'
ELSE 'false'
END STATUS
FROM
information_schema.COLUMNS AS C2
JOIN (SELECT
TABLE_SCHEMA,
TABLE_NAME,
TABLE_TYPE,
TABLE_ROWS,
TABLE_COLLATION,
CREATE_OPTIONS
FROM
information_schema.TABLES
WHERE
TABLE_TYPE = 'BASE TABLE'
AND TABLE_SCHEMA NOT IN ('information_schema' , 'sys', 'performance_schema', 'mysql')) T2 ON C2.TABLE_NAME = T2.TABLE_NAME
AND C2.TABLE_SCHEMA = T2.TABLE_SCHEMA
JOIN (SELECT
SCHEMA_NAME,
DEFAULT_CHARACTER_SET_NAME,
DEFAULT_COLLATION_NAME
FROM
information_schema.SCHEMATA) S2 ON T2.TABLE_SCHEMA = S2.SCHEMA_NAME) charset_status
WHERE
STATUS = 'false'
ORDER BY TABLE_SCHEMA , TABLE_NAME;
- 表默认排序规则。输出未显式列出表默认字符集,但排序规则名称以字符集名称开头。

mysql 字符集排查的更多相关文章
- [转]关于Navicat和MYSQL字符集不统一出现的中文乱码问题
原文链接:关于Navicat和MYSQL字符集不统一出现的中文乱码问题 最近遇到一串关于MYSQL中文乱码的问题,问题背景是这样的: 在此之前,服务器上安装好MySQL之后就立马重新配置了字符集为ut ...
- 如何修改MySQL字符集
首先,MySQL的字符集问题主要是两个概念,一个是Character Sets,一个是Collations,前者是字符内容及编码,后者是对前者进行比较操作的一些规则.这两个参数集可以在数据库实例.单个 ...
- Mysql字符集设置
转 基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如’A'.’B'等:• 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encodi ...
- MySQL字符集
字符集的选择 1.如果数据库只需要支持中文,数据量很大,性能要求也很高,应该选择双字节定长编码的中文字符集(如GBK).因为相对于UTF-8而言,GBK"较小",每个汉字只占2个字 ...
- mysql5.5字符集设置的一点变化(对于中文乱码问题,需要设置mysql字符集)
工作中因为字符集问题没少头疼,还犯过一次错误,还好拯救及时,没有发生重大事故,唉,弄清楚点还是非常有必要的: 例如我的工作环境为CTR+redhat5+mysql5.5 在导入sql语句的时候必须要注 ...
- Mysql字符集知识总结
字符集&字符编码方式 字符集(Character set)是多个字符的集合,字符集种类较多,每个字符集包含的字符个数不同,这里的字符可以是英文字符,汉字字符,或者其他国家语言字符. 常见字符集 ...
- MySQL字符集的修改和查看
1.关于MySQL字符集 MySQL的字符集支持(Character Set Support)有两个方面: 字符集(Character set)和排序方式(Collation). MySQL对于字符集 ...
- MySQL字符集转换引发插入乱码问题
根据http://www.cnblogs.com/cchust/p/4601536.html进行验证测试 问题背景 在mysql上面执行一条普通的insert语句,结果报错: Incorrect st ...
- MySQL 字符集设置
/*************************************************************************** * MySQL 字符集设置 * 说明: * 数 ...
随机推荐
- Python int操作
a = 1 # 1 print(a.bit_length()) #计算一个数字的二进制长度.没啥用
- SWIFT中函数返回值为Tuple
在playgroundm内键入以下代码,求一个成绩数组内最大分值和最小分值 func maxminScore(scores:Array<Int>) -> (maxScore:Int, ...
- py安装以及配置pip环境变量
安装python,安装包链接:https://pan.baidu.com/s/1u4tA-FJMxtrtJTap-zFh3g 密码:gh1c 默然安装到了C盘 安装pycharm:安装包链接:链接:h ...
- CF1096. G. Lucky Tickets(快速幂NTT)
All bus tickets in Berland have their numbers. A number consists of n digits (n is even). Only k dec ...
- java语法基础练习
1.阅读示例: EnumTest.java,并运行.分析结果 代码: public class EnumTest { public static void main(String[] args) { ...
- read()/fread()/mmap()执行效率对比
一. read()/fread()/mmap()执行效率对比 系统调用read.c: #include <sys/types.h> #include <sys/stat.h> ...
- mysql 行号 获取指定行数据
mysql 行号的实现 Select id,(@rowNum:=@rowNum+1) as rowNo From first,(Select (@rowNum :=0) ) bOrder by fir ...
- 通过直接编码添加折线图到ChartControl
https://documentation.devexpress.com/#WindowsForms/CustomDocument2976 ChartControl lineChart = new C ...
- JS 检测浏览器中是否安装了特定的插件
1.检测非IE浏览器 可以使用plugins数组来达到这个目的,例: //检测插件(在IE中无效) function hasPlugin(name){ name = name.toLowerCase( ...
- Android getprop setprop watchprops用法
转载请注明出处:https://www.cnblogs.com/lialong1st/p/10172973.html 在安卓系统中,当你写了一个脚本,已经添加到开机启动 init.rc 中,即使脚本中 ...