mysql数据库字符集学习总结

MYSQL数据库字符集包括字符集(CHARACTER)和校对规则(COLLATION)两个概念。

MYSQL 支持的字符集和校对规则可以通过命令showcharacter set;查看。

和字符集有关的变量

mysql> show VARIABLES  like ‘character_set%‘;+--------------------------+-------------------------------------------+| Variable_name            | Value                                     |+--------------------------+-------------------------------------------+| character_set_client     | utf8                                      || character_set_connection | utf8                                      || character_set_database   | utf8                                      || character_set_filesystem | binary                                    || character_set_results    | utf8                                      || character_set_server     | utf8                                      || character_set_system     | utf8                                      || character_sets_dir       |/application/mysql-5.5.32/share/charsets/ |+--------------------------+-------------------------------------------+8 rows in set (0.00 sec)

这几个字符集含义如下:

character_set_client       #客户端字符集

character_set_connectio    #链接字符集

character_set_database     #数据库字符集,配置文件指定或建库建表指定。

character_set_filesystem    #文件系统字符集

character_set_results       #返回结果字符集

character_set_server       #服务器字符集,配置文件指定货建库建表指定。

character_set_system       #系统字符集

要解决MYSQL 乱码问题 需要做到字符集6个统一

1、统一客户端字符集 可以通过 set names 命令修改 也可以单独修改以下几个变量

方法1:set names gbk  控制客户端的字符集

方法2:单独修改下面三个参数

set character_set_client gbk;

set character_set_connectio gbk;

set character_set_results gbk;

方法3:也可以在进入MYSQL的时候加 --default-character-set=gbk 参数。

mysql-uroot -p123456 -S /data/3306/mysql.sock --default-character-set=gbk;

方法4:永久生效需要修改my.cnf 配置文件在[client]模块中添加下面参数

[client]

default-character-set=gbk   如果是多实例配置需要修改/etc/my.cnf

2、统一MYSQL 服务端字符集

方法1:按如下要求更改my.cnf参数

[mysqld]

default-character-set=latin1  适合5.1之前的版本

character-set-server=latin1   适合5.5

对应变量中的以下两个参数:

character_set_database

character_set_server

方法2:编译的时候指定服务器端字符集:

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci \

-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \

3、字段、建表、建库字符集也要统一

指定字符集建库:

create database oldboy_utf8 DEFAULT CHARACTER SETUTF8 COLLATE utf8_general_ci;

修改数据库字符集命令:

alter database oldboy character set utf8 collate
utf8_general_ci;

指定字符集建表:

CREATE TABLE `test` (  `id` int(4)NOT NULL AUTO_INCREMENT,  `name`char(20) NOT NULL,  PRIMARY KEY(`id`),  KEY`index_name` (`name`)) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8

修改数据表字符集命令:

把表默认的字符集和所有字符列(CHAR,VARCHAR,TEXT)改为新的字符集

alter table test CONVERT TO character set utf8 collate
utf8_general_ci;

仅修表的默认字符集

alter table test DEFAULT character set utf8 collate utf8_general_ci;

修改字段的字符集

alter table test CHANGE name name varchar(16) character set utf8 collate utf8_general_ci;

相关查看命令

show create database oldboy;

show create table test;

show FULL COLUMNS from test;

4、程序所使用的字符集要和数据库 表 字段 的统一

5、LINUX系统字符集也要统一

cat /etc/sysconfig/i18nLANG="en_US.UTF-8"SYSFONT="latarcyrheb-sun16"

6、LINUX客户端 如 CRT  XSHELL 等的字符集也要统一 可以在软件属性里设置。

如果数据库有乱码 可按以上6点 逐一进行排查

如何选择适合的字符集?

1、如果是处理各种各样的文字,发布到不同语言国家地区,应选UNICODE字符集,对MYSQL来说就是UTF-8 (每个汉字三字节),如果应用需处理英文,仅有少量汉字UTF-8更好。

2、如只需支持中文,并且数据量很大,性能要求也很高,可选GBK(定长每个汉字占双字节,英文也占双字节),如果需大量运算,比较排序等,定长字符集,更快,性能更高。

3、处理移动互联网业务,可能需要使用utf8mb4字符集。

建议:没有特别需求,请选择UTF8.

很多开源程序都会有多种字符集版本的程序。

在数据库中执行sql语句的方法

1)操作习惯:尽量不在MYSQL命令行插入数据(SSH客户端影响)

2)sql文件的格式统一用“utf8没签名”。

3)导入文件的方式

a、可在MYSQL命令行中用source 执行sql文件。

b、命令方式导入数据 mysql -uroot -p123456oldboy<test.sql

4)sql文件里 set names utf8,或mysql -uroot -p123456 oldboy -default-character-set=utf8<test.sql。

更改数据库字符集的方法:

分两种情况:

1、空表无数据

直接通过以上命令修改即可

2、如果表里已经有数据了

此时不能直接修改表的字符集了,因为修改后的字符集只会对新插入的数据生效,之前库的数据并不起作用。此时我们可以按以下思路操作修改数据库字符集

1)导出表结构

mysqldump-uroot -p --default-character-set =latin -d dbname>alltable.sql

2)编辑表结构语句alltable.sql 通过sed替换命令将所有原字符集的字符串改成新的字符集的。

3)锁表确保数据库不再更新,导出所有数据(不带表结构)

mysqldump-uroot -p --quick --no-create-info --extended-insert --default-character-set=latin dbname>alltable.sql

--no-create-info 不导出表结构

4)修改my.cnf 配置调整客户端及服务端字符集,重启生效

5)通过新字符集建库(可选)

删除原库,然后create database dbname default charset utf8;

6)导入表结构(更改过字符集的表结构)

mysql-uroot -p dbname <alltable.sql

7)导入数据

mysql-uroot -p dbname <alldata.sql

时间: 2024-08-27 17:07:12

mysql数据库字符集学习总结的相关文章

Mysql DBA 高级运维学习笔记-Mysql数据库字符集知识

1.2 Mysql数据库字符集知识 1.2.1 MySQL数据库字符集介绍 简单的说,一套文字符号及其编码.比较规则的集合. MySQL数据库字符集包括字符集(CHARACTER)和校对规则(COLLATION)两个概念.其中,字符集是用来定义MySQL数据字符串的存储方式,而校对规则则是定义比较字符串的方式.前面建库的语句中,CHARACTER SET latin1即为数据库字符集而COLLATE latin1_wedish_ci 为校对字符集,有关字符集详细内容参考mysql手册,第10张字

MySQL数据库开发学习教程

MySQL数据库开发学习教程 一.数据库设计 数据库设计(一)--数据库设计http://blog.51cto.com/9291927/2087925 二.MySQL数据库开发基础教程 MySQL数据库开发基础教程目录如下: MySQL数据库基础(一)--MySQL数据库简介http://blog.51cto.com/9291927/2087947MySQL数据库基础(二)--MySQL字符集与乱码解析http://blog.51cto.com/9291927/2088254MySQL数据库基础

linux下mysql数据库的学习

转载博客:http://freedomljtt.blog.163.com/blog/static/72294949201210145441701/ ubuntu12.04 卸载和安装mysql 卸载mysql 第一步 1 sudo apt-get autoremove --purge mysql-server-5.0 2 sudo apt-get remove mysql-server 3 sudo apt-get autoremove mysql-server 4 sudo apt-get r

MYSQL数据库基础学习笔记

一.mysql的安装与初始化: 安装mysql命令: yum install -y mysql-server mysql mysql-devel 初始化: service mysqld start   //第一次启动mysqld服务会自动初始化: 创建用户并初始化密码: mysqladmin -u root passwd '密码' 登陆mysql: mysql -u root -p 退出mysql: quit.exit 设置mysqld服务自启动: chkconfig mysqld on mys

修改mysql数据库字符集为UTF8的

第一种 一.修改my.ini配置文件(MySQL配置文件) character_set_server = utf8 #设置字符集 重启mysql数据库服务 查看当前数据库字符集 show VARIABLES like 'character%'; 二.修改数据库字符集 alter database 数据库名 character set utf8; ps:修改完数据库字符集,需要重启MySQL数据库. 三.修改表字符集 ALTER TABLE  表名 DEFAULT CHARACTER SET ut

Mysql数据库字符集设置

1.操作系统:CentOS6.6 2.数据库系统: Mysql 3.任务:解决数据乱码的问题 1)更改客户端的字符集gbk 客户端字符集设置,set names gbk;这样可以确保插入后的中文,不出现乱码,对执行set names gbk,前插入的中文无效. 说明:通常下面的几个字符集和数据库的字符集相同的和character_set_database,才能确保写入数据可以正确输出.  mysql> set names gbk;      #更改客户端的字符集gbk Query OK, 0 r

MySQL 数据库字符集的查看与设置

一.查看 MySQL 数据库服务器和数据库字符集 mysql> show variables like '%char%';+--------------------------+-------------------------------------+------| Variable_name            | Value                               |......+--------------------------+-----------------

mysql数据库存储过程学习

1.建立存储过程方式一: mysql中存储过程属于函数一栏中,点击新建函数会有让你选择是存储过程还是函数 接下来是存储过程中设置的参数: IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值 OUT 输出参数:该值可在存储过程内部被改变,并可返回 INOUT 输入输出参数:调用时指定,并且可被改变和返回 接下来就在BEGIN和END中填写需要的sql语句,和平时使用的相同 保存后存储在函数下,执行时可以直接运行,查看结果. 注:当没有参数或者只有

Mysql 数据库基础 学习笔记

数据库基础 数据库是存储数据的仓库,实现数据共享,减少数据冗余,采用特定的数据类型,具有较高的数据独立性,具有数据控制功能. 表 ,是一个二维数组,用来存储数据和操作数据的逻辑结构. 数据类型,整数数据类型,浮点数数据类型,精确小数类型,二进制数据类型,日期/时间数据类型,字符串数据类型. 主键 用于唯一标示表中的每条记录.可以定义一列或多了主键.主键不能相同. 数据库技术构成   硬件,软件共同构成 数据库系统,数据库,数据库管理系统(DBMS),数据库应用程序. SQL 语言  结构化查询语