背景:
在部署完成了mysql5.7.4数据库服务之后创建了mydb数据库,然后创建了如下的表:
CREATE TABLE department(
did int (4) NOT NULL PRIMARY KEY,
dname varchar(20)
);
CREATE TABLE employee (
eid int (4) NOT NULL PRIMARY KEY,
ename varchar (20),
eage int (2),
departmentid int (4) NOT NULL
);
创建表完成之后去插入数据:
-- 向department表插入数据
INSERT INTO mydb.department(did,dname)VALUES(1001,'财务部'); INSERT INTO mydb.department(did,dname)VALUES(1002,'技术部'); INSERT INTO mydb.department(did,dname)VALUES(1003,'行政部'); INSERT INTO mydb.department(did,dname)VALUES(1004,'生活部');
-- 向employee表插入数据
INSERT INTO employee VALUES(1,'张三',19,1003);
INSERT INTO employee VALUES(2,'李四',18,1002);
INSERT INTO employee VALUES(3,'王五',20,1001);
INSERT INTO employee VALUES(4,'赵六',20,1004);
报错现象:
但是在执行插入的时候提示报错:
1366 - Incorrect string value: '\xE8\xB4\xA2\xE5\x8A\xA1...' for column 'dname' at row 1
故障原因:
出现这个问题的原因是mydb数据库的字符集编码、排序类型不是utf-8,所以创建时会报1366
检查mydb数据库的字符集和排序规则,确实不是utf-8的,所以需要将nydb数据库的字符集和排序规则修改为utf-8,就可以了。
切记,将已经创建的表,重新drop,再create一下就可以插入数据了。