mysql字符集
2018-06-17 22:49:36来源:未知 阅读 ()
- 各种文字和符号的集合,包括各国家文字,标点符号,图形符号,数字等。
- 字符的编码方式,即二进制数据与字符的映射规则;
- ASCII:美国信息互换标准编码;英语和其他西欧语言;单字节编码,7位(bits)表示一个字符,共128字符。
- GBK:汉字内码扩展规范;中日韩汉字、英文、数字;双字节编码;共收录了21003个汉字,GB2312的扩展。
- utf-8:Unicode标准的可变长度字符编码;Unicode标准(统一码),业界统一标准,包含世界上数十种文字的系统;utf-8使用一至4个字节为每一个字符编码。
- 其他常见字符集:utf-32,utf-16,big5(繁体字),latin1()
mysql> SHOW CHARACTER SET ; +----------+-----------------------------+---------------------+--------+ | Charset | Description | Default collation | Maxlen | +----------+-----------------------------+---------------------+--------+ | big5 | Big5 Traditional Chinese | big5_chinese_ci | 2 | | dec8 | DEC West European | dec8_swedish_ci | 1 | | cp850 | DOS West European | cp850_general_ci | 1 | | hp8 | HP West European | hp8_english_ci | 1 | | koi8r | KOI8-R Relcom Russian | koi8r_general_ci | 1 | | latin1 | cp1252 West European | latin1_swedish_ci | 1 | | latin2 | ISO 8859-2 Central European | latin2_general_ci | 1 | | swe7 | 7bit Swedish | swe7_swedish_ci | 1 |
新增字符集:
mysql> SHOW COLLATION ;
- 以_ci(表示大小写不敏感)
- 以_cs(表示大小写敏感)
- 以_bin(表示用编码值进行比较)
- 使用命令直接设置
- 配置文件中设置:mysqld,
create database db_name character set latin1 collate latin1_swedish_ci;
mysql>create table tbl(...) default charset=utf-8 default collate=utf8_bin
- 使用列集的character set 设定值
- 若列级字符集不存在,则使用对应表级的default character set 设定值;
- 若表级字符集不存在,则使用数据库级的default character set 设定值
- 若数据库字符集不存在,则使用服务器级character_set_server设定值
mysql> SHOW VARIABLES LIKE '%CHARACTER%'; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec) mysql> SHOW VARIABLES LIKE '%collation%'; +----------------------+-------------------+ | Variable_name | Value | +----------------------+-------------------+ | collation_connection | utf8_general_ci | | collation_database | latin1_swedish_ci | | collation_server | latin1_swedish_ci | +----------------------+-------------------+
set global character_set_server=utf8; (全局)
mysql> alter table stu convert to character set utf8;
msyql>set names utf8;
- 数据存储字符集不能正确编码(不支持)client发来的数据:client(utf8)->storage(latin1)
- 程序连接使用的字符集与通知mysql的character_set_client,character_set_conection,character_set_results 等不一致或不兼容。(告诉mysql:set names gbk ;程序连接使用的字符集一致)
aiapple@ubuntu:~$ file test.t test.t: UTF-8 Unicode text aiapple@ubuntu:~$ cat test.t 你好 mysql> show variables like '%char%'; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | gbk | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec) mysql>load data infile '/home/aiapple/test.t' into table t;
此时会出现乱码,即告知数据库的character_set_database 的字符集与程序使用的文件test.t 不一样;
- 创建数据库/表时显示的指定字符集,不使用默认
- 连接字符集与数据存储字符集设置一致,推荐使用utf8
- 驱动程序连接时显示指定字符集(set names xxx)
mysqldump -uroot -p --default-character-set=gbk -d WY_yun >createtab.sq
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 WY_yun > data.sql
mysql> create database na default charset gbk;
mysql -uroot -p na <createtab.sql
mysql -uroot -p na < data.sql
总结
- 字符集与字符序是1:N
- 字符序是字符的排序与比较规则及字符的精度和性能;
- 表级别字符集修改:alter table stu convert to character set utf8;
- 三个连接相关字符集统一设置:set names utf8;
- 常见乱码原因
- load数据时,因让数据库级别的字符集与文件相同;
- 三要素:
- 程序驱动或客户端的字符集(在客户端设置)
- 告知mysql的字符集(set names xxx)
- 数据存储的字符集(表结构的字符集alter table tbl convert to character set xxx)
- 运行一段时间后发现数据乱码,如何保存数据;
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:mysql数据对象
下一篇:SQL业务审核与优化
- MySQL replace函数怎么替换字符串语句 2020-03-09
- PHP访问MySQL查询超时怎么办 2020-03-09
- mysql登录时闪退 2020-02-27
- MySQL出现1067错误号 2020-02-27
- mysql7.x如何单独安装mysql 2020-02-27
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash