一.设置表的字符编码
有时候MySQL中的表需要存储中文,需要设置表的字符编码为utf8,否则默认的字符编码有可能不能正确处理中文,那么在MySQL中,如何设置表的字符编码呢?如下:
方法一:创建表的时候指定编码形式和
// 改变整张表的编码
mysql> CREATE TABLE stu_test
(
-> id
int(11) NOT NULL,
-> name
varchar(10) DEFAULT NULL,
-> sex enum(‘男’,‘女’),
-> PRIMARY KEY (id
)
-> ) CHARSET=utf8;
Query OK, 0 rows affected (0.04 sec)
方法二:
CREATE TABLE student_tb2
(
Sname
varchar(10) CHARACTER SET utf8
);
在数据类型之后 + CHARACTER SET 编码
方法三:
还有一种方式是通过改变mysql编码的形式,是通过改变Mysql的配置文件,改变下面红框圈出来的为utf-8,记得操作之后一定要重新启动Mysql服务,需要新建数据库老的数据库还是之前的编码。
方法四:
如果定义的字符串类型想使用utf8编码,在定义的时候不适用char或者varchar来定义而是使用nchar或者nvarchar
例:
create table user(id int ,name nvarchar(10)));
create table user(id int,sex nchar(2));
方法五:
create table sex_tb2(
Ssex enum(‘m’,‘w’)
);
alter table sex_tb2 modify Ssex enum(‘男’,‘女’) character set utf8;
二.修改存储引擎
方法一:
可以在创建表的时候指定存储引擎,如下:
CREATE TABLE ai (
i BIGINT(20) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (i)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
方法二
也可以修改已存在表的存储引擎,如下:
ALTER TABLE user ENGINE = InnoDB;
方法三
还可以修改配置文件,MySQL Server启动的时候都会加载一个配置文件,windows下是my.ini文件,linux下是my.cnf文件,打开配置文件,在[mysqld]下面添加如下内容,保存,重启MySQL Server服务器,默认就采用配置项指定的存储引擎了。记得操作之后一定要保存再重新启动Mysql服务,需要新建数据库老的数据库用的还是老的存储引擎。