【原创】新增、修改判断数据重复问题
1、问题需求
操作 | 需求 |
---|---|
新增 | 新增的数据不能在数据库中存在,存在则不能新增 |
修改 | 修改的数据是提交的当前数据则提交成功、修改的数据排除它本身在其他数据中也不存在才可以修改 |
在遇到这个问题的时候小刘第一时间就想到了 select count(*) 判断数据库中某个数据存在的条数
- 返回行数 = 0 表示不存在该数据
- 返回行数 > 1 表示参在该数据
但是这样做就没有考虑到修改的时候用户什么也不修改就提交的问题,小刘也不想改太多代码来修复这个问题,就想用原来的 select ccount(*) 来解决这个问题,经过思考最后还是被小刘君解决了,这里附上解决方案
2、sql代码
<!--根据工号查询老师数量信息-->
<select id="queryCountTeacherInfoByJobNumber" resultType="int" parameterType="Teacher">
select count(*) from teacher where job_number = #{
jobNumber}
<if test="id!=null and id!=''">
and id !=#{
id}
</if>
</select>
在原有的基础上加上一个判断条件修改的时候就可以查询除开本身其他数据的重复数据信息
3、业务代码
//判断是否重复
int i = teacherDao.queryCountTeacherInfoByJobNumber(teacher);
if (i > 0) {
return Page.INFOERROR;
}
- i = 0 不存在重复数据
- i > 1 除开本身还存在重复数据
这里要注意
在修改的时候我们要把修改当前的数据的id也到带过来,判断重复数量
欢迎来访小刘君公众号