1. 将表test中,已有的num字段,设置默认值为0:
alter table test alter column num set default 0;
此时设置为0成功。
2. 下面插入数据
insert into test values(null,"张三",18,null);
此时我们发现num字段为插入的null,而并不是我们设置的默认值0
3. 此时只插入name
insert into test (name) values("李四");
此时我们可以看到“李四”的默认值变成了0。
结论:mysql 的默认值只有在insert语句中没有这个字段时才会生效,如果insert中有插入该字段而该字段取值又为null,null值将被插入到表中,默认值此时失效。