mybatis查询字段为null设置为0的操作
使用mybatis查询(mysql)时,会使用多个double字段做相加,但是呢,其中几个字段有可能是null,会抛空指针。
解决方法自动生成的mybatis mapper文件长这样
<sql id='Base_Column_List'> ID, PREPAYMENT_FEE </sql>
修改它
<sql id='Base_Column_List'> ID, ifnull(PREPAYMENT_FEE,0) as PREPAYMENT_FEE </sql>
补充:mybatis中0和null关系处理
最近在项目开发中,mybatis遇到一个很奇怪的问题,因为想在后台传一个int型0插入到数据,却被识别成了null。
后面,排除问题时,查到mybatis源码对其进行了强制定义。
所以解决问题可以改造mybatis源码,或者简单的做以下处理:
<insert parameterType='java.util.Map'>INSERT INTO TABLE<trim prefix='(' suffix=')' suffixOverrides=','> <if test='importRow != null and importRow != ’’ or importRow ==0 '> IMPORT_ROW,</if></trim><trim prefix='values (' suffix=')' suffixOverrides=','> <if test='importRow != null and importRow != ’’ or importRow ==0 '> #{importRow}, </if></trim></insert>
增强判断添加 or importRow ==0
以上为个人经验,希望能给大家一个参考,也希望大家多多支持好吧啦网。如有错误或未考虑完全的地方,望不吝赐教。
相关文章:
1. Oracle Instr函数实例讲解2. 使用SQL语句创建触发器的实例3. mysql 判断是否为子集的方法步骤4. MySQL插入数据时,如果记录不存在则insert,如果存在则update5. Mysql故障排除:Starting MySQL. ERROR! Manager of pid-file quit without updating file6. MySQL存储引擎选择InnoDB还是MyISAM7. Windows下不能启动mysql服务--错误总结8. 启动MYSQL出错 Manager of pid-file quit without updating file.9. oracle触发器介绍10. MYSQL数据库存文本转存数据库问题

网公网安备