<insert id="addOneBlog" parameterType="main.Blog"> insert into blog(title,author,content) values(#{title},#{author},#{content}) </insert>
原以为有这么一个insert语句就万事大吉了,我们以为,以后做插入操作的时候,无论有多少个字段,都使用这一个insert语句,如果字段没有值,就会被赋值为mysql字段的默认值。。。
但事实证明,根本不是这样的。
当我们只给title字段赋值,然后执行一个insert语句时,mybatis马上报出这样的异常:
Caused by: com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Column 'content' cannot be null
显然,所有字段规定了not null,看来按照这种insert的方法,未赋值的字段并没有赋值为mysql的默认值。
那么如果把数据库字段的not null限制去掉呢?
再次执行刚才的insert操作,这次没有抛出异常,但查看数据库后,我们发现,新插入的表记录中,没有赋值的字段仍然不是mysql的默认值,而是null值。
所以,按照上面所谓的通用insert语句,是无法让未赋值字段的值变为mysql默认值的。这种insert语句无法做到通用。具体解决方案将在下一篇中介绍。