1. 问题描述
在制作填报模板时可能会遇到以下问题:数据库中的A字段为主键,在定义报表填报属性时设置别的字段为主键,数据库中有一条记录是某个报表主键对应的字段值为空,当对这条记录进行更新时,却进行了插入提交。
注:报表填报属性设置主键,即判断单元格中的值与数据库中是否相同,若有相同的则进行更新,若没有则进行插入。
2. 原因
当有空值时,那么在执行 update 语句时 where 条件后面是“某字段=null”,而在填报属性中若 where 某字段=null时,update 语句会失效然后便会转向 insert 语句,这样就造成了插入重复数据的现象。
3. 解决方案
首先要知道可能为空的报表主键对应数据库中的数据类型,然后在报表填报属性设置里面给对应的字段的值设置公式:以字符串为例,字符串对应的空值就是空字符串"",则公式为:if(单元格=null,"",单元格)。