错误案例
现象描述:
在DO中有一属性imageSize,定义成Long(Java的普通类)和long(Java里面的基本数据类型)在update操作时会有区别,
<isNotNull property="imageSize" prepend=","> <![CDATA[ IMAGE_SIZE = #imageSize# ]]> </isNotNull>
如果Do中没有传imageSize的值,希望该值保持数据库的值,定义成Long可以,但是定义成long时每次都会更新为0
错误分析
由于IBatis的<isNotNull>会对传入的值进行null的检查,如果DO里面的属性是long类型的时候,不显示设置的时候默认初始为0,所以就会导致IMAGE_SIZE被修改为不正确的值,而如果是Long类型的话,就不会产生这样的错误。
正确用法
正确代码:正确使用long和Long,一般涉及到数据库更新操作的时候,使用Long,否则显示的设置属性类型为long的值