导入完成后,使用select查询后,发现大量数据未成功插入。
后来发现是enum字段没有加引号搞的鬼。
结论:
enum的字段,在插入的时候,必须带上引号。否则会出现不可预期的问题。...如果不带引号插入的话,实际上是插入的key(如上面的例子中 INSERT INTO t1 (b) VALUES (4),插入的是b列第四个default值,也就是取enum('4','3','2','1...,虽然插入的时候没有报错,但是实际上查询是没有结果的,(查出来后插入的2行的b是''空值,不是NULL)。...utm_source=tuicool&utm_medium=referral)
在建立enum类型的字段时,我们会给他规定一个范围比如 enum('a','b','c'),这时mysql内部会建立一张hash...同样,enum在mysql手册上的说明:
ENUM('value1','value2',...)
1或2个字节,取决于枚举值的个数(最多65,535个值)
除非enum的个数超过了一定数量,否则他所占的存储空间也总是