1. 将表test中,已有的num字段,设置默认值为0:

alter table test alter column num set default 0;

mysql怎么手动设置字段默认值 mysql设置字段默认值为0_mysql怎么手动设置字段默认值

此时设置为0成功。

2. 下面插入数据

insert into test values(null,"张三",18,null);

mysql怎么手动设置字段默认值 mysql设置字段默认值为0_默认值_02

此时我们发现num字段为插入的null,而并不是我们设置的默认值0

3. 此时只插入name

insert into test (name) values("李四");

mysql怎么手动设置字段默认值 mysql设置字段默认值为0_插入数据_03

此时我们可以看到“李四”的默认值变成了0。

结论:mysql 的默认值只有在insert语句中没有这个字段时才会生效,如果insert中有插入该字段而该字段取值又为null,null值将被插入到表中,默认值此时失效。