Mysql系列-字符集
字符集
怎样选择合适的字符集
- 如果应用程序需要发布到很多国家和地区,需要支持各种各样的文字,则选择Unicode编码,Mysql中即UTF-8.q如果需要将数据导入数据库,这时候要注意数据库字符集对数据字符集的兼容性,最好一致。
- 如果数据库支持一般中文,数据量很大,性能要求高,那么应该选择双字节定长编码的中文字符集,比如GBK。因为相对于UTF-8而言GBK每个汉字只需要2个字节,而UTF8每个汉字需要3个字节。
- 如果数据库需要做大量的检索、比较、排序,应该选择定长字符集。
查看字符集
字符集和校对规则是一对多的关系
show character set; //查看数据库可用的所有字符集
show collation like '%gbk%'; //查看字符集的校对规则
校对规则命名约定:
_ci:大小写不敏感,_cs:大小写敏感,_bin:二进制值比较
MySQL字符集设置
MySQL的字符集和校对规则分四个级别的默认设置:
服务器级、数据库级、表级、字段级 服务器级:
在MySQL服务启动时来确定
1.在my.cnf中设置:[mysqld] character-set-server=gbk
2.在启动选项中指定:mysqld --character-set-server=gbk
3.在编译时指定:shell> cmake . -DDEFAULT_CHARSET=gbk
在没有指定校对规则的情况下,使用默认的校对规则。
//查询当前服务器的字符集
show variables like 'character_set_server';
//查询当前服务器的校对集
show variables like 'collation_server'; 数据库级:
在创建数据库的时候指定,也可以在创建完成之后通过alter database命令修改。推荐在创建数据库的时候显式指定字符集和校对规则,如果没有指定,则默认使用服务器字符集和校对规则。
show variables like 'character_set_database';
show variables like 'collation_database'; 表级:
在创建表的时候指定,如果没有指定则使用数据库的字符集和校对规则。
show create table t1; 列级:
列级别的字符集一般不适用,主要是针对不同字段需要使用不同字符集的情况,遇到的几率很小。 以上四种字符集设置确定的是数据保存的字符集和校对规则,对于实际的应用程序,还存在客户端和服务器之间交互的字符集和校对规则设置。
MySQL提供了三个参数:character_set_client、character_set_connection、character_set_results.分别代表客户端、连接、返回结果的字符集。通长情况下这三种字符集是相同的。
一般通过下面的命令设置这三个参数。
set names utf8; //应用程序每次连接数据库都需要执行。
字符集修改步骤
如果数据库中已经存在数据,此时想修改字符集不能通过 alter table 或者alter database这 两个命令都无法作用于已存在的数据。
一下模拟lantin1字符集数据库修改成GBK字符集数据库的过程 1.导出表结构:
mysqldump -uroot -p --default-character-set=gbk -d databasename> createtab.sql
--default-character-set=gbk:设置以什么方式连接
-d:表示只导出表结构,不导出数据
2.手工修改createtab.sql中表结构定义中的字符集为新的字符集。
3.确保记录不在更新导出所有记录。
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character- set=latin1 databasename> data.sql
--quick:该选项用于转储大的表
--extended-insert:使用包括几个values列表的多行insert语法,加速插入。
--no-create-info:不导出每个转储表的create table语句。
--default-character-set=latain1:按照原有的字符集导出数据。
4.打开data.sql,将set names latin1 手工修改为:set names gbk;
5.使用新的字符集创建新的数据库
create database databasename default charset gbk;
6.创建表,执行createtab.sql
mysql -uroot -p databasename < createtab.sql
7.导入数据,执行data.sql
mysql -uroot -p databasename < data.sql
Mysql系列-字符集的更多相关文章
- MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- MySQL 系列(一)安装
MySQL 系列(一)安装 以 Centos7 下安装 MySQL 5.6 为例. 一.环境准备 (1) 下载 下载地址: https://dev.mysql.com/get/Downloads/My ...
- MySQL系列(一)--基础知识(转载)
安装就不说了,网上多得是,我的MySQL是8.0版本,可以参考:CentOS7安装MySQL8.0图文教程和MySQL8.0本地访问设置为远程访问权限 我的MySQL安装在阿里云上面,阿里云向外暴露端 ...
- 为什么MySQL字符串不加引号索引失效?《死磕MySQL系列 十一》
群里一个小伙伴在问为什么MySQL字符串不加单引号会导致索引失效,这个问题估计很多人都知道答案.没错,是因为MySQL内部进行了隐式转换. 本期文章就聊聊什么是隐式转换,为什么会发生隐式转换. 系列文 ...
- MySQL 系列(四)主从复制、备份恢复方案生产环境实战
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- MySQL 系列(二) 你不知道的数据库操作
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网 ...
- MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决
一.简介 MySQL是最流行的开放源码SQL数据库管理系统,它是由MySQL AB公司开发.发布并支持的.有以下特点: MySQL是一种数据库管理系统. MySQL是一种关联数据库管理系统. MySQ ...
- 修改MySQL默认字符集编码
好记心不如烂笔头,很多东西当时没记下来,过了就忘了,下次用到时又得浪费好多时间才能解决.今天又遇到修改MySQL默认字符集编码的问题,折腾了半天解决了,赶快记录下来,以后就不用每次折腾了. 查看MyS ...
- MySQL设置字符集为UTF8(Windows版)
Windows版MySQL设置字符集全部为utf8的方式 MySQL安装目录下的my.ini文件 [client]节点 default-character-set=utf8 (增加) [mysq ...
随机推荐
- 记.gitignore的一次惊心动魄
git rm -r --cached . #清除缓存 git add . #重新trace file git commit -m "update .gitignore" #提交和 ...
- 什么是“光照度(Illuminance)”?
光照度是光度学的概念,了解光照度,要从人眼的特性说起. 人眼的光谱响应 传统的辐射度学的概念(如“功率”,单位为“瓦”)可以客观描述“能量”,但当其用来描述“光照”时却是不合适的,原因在于:人眼对不同 ...
- WPF 控件库——轮播控件
WPF 控件库系列博文地址: WPF 控件库——仿制Chrome的ColorPicker WPF 控件库——仿制Windows10的进度条 WPF 控件库——轮播控件 WPF 控件库——带有惯性的Sc ...
- 类型转换构造函数 及使用explicit避免类型自动转换------新标准c++程序设计
类型转换构造函数: 除复制构造函数外,只有一个参数的构造函数一般可以称作类型转换构造函数,因为这样的构造函数能起到类型自动转换的作用.例如下面的程序: #include<iostream> ...
- CentOS 6.9下PXE+Kickstart无人值守安装操作系统
一.简介 1.1 什么是PXE PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持 ...
- Docker安装FastDFS
什么是FastDFS? FastDFS 是用 c 语言编写的一款开源的分布式文件系统.FastDFS 为互联网量身定制, 充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高性能等指标,使用 ...
- Squid代理服务器(一)——大家所用的游戏代理软件到底为何物?
一.代理服务器应用场景分析 想当年大学时候宿舍控制网速,苦了我们这帮魔兽党,一到晚上工会活动我们就得和全校上万名学生抢网速,作为坦克的我总是因为网速问题导致团灭,咱也是有自尊的人,一怒之下花300元办 ...
- MongoDB集群配置笔记
firewall-cmd --query-port=27017/tcp yum install system-config-firewall-tui firewall-cmd --zone=publi ...
- 2019.3.7考试T2 离线数论??
$ \color{#0066ff}{ 题目描述 }$ 一天,olinr 在 luogu.org 刷题,一点提交,等了一分钟之后,又蛙又替. olinr 发动了他的绝招,说:"为啥啊???&q ...
- 《条目十八》避免使用vector<bool>
<条目十八>避免使用vector 先说结论: 一是:vector<bool>不是标准容器,因为标准容器的对于T *p = &c[0];必须是可编译的. 二是:vecto ...