新增、修改判断数据重复问题

本文介绍了如何通过SQL查询优化来处理数据新增与修改时的重复问题。在新增数据时,确保数据不存在于数据库中;在修改数据时,检查除当前数据外是否存在相同数据。通过在SQL查询中添加特定条件,避免了用户未修改数据时的错误提交。提供的SQL代码示例展示了如何在查询中加入判断,以确定数据是否重复。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【原创】新增、修改判断数据重复问题

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也到带过来,判断重复数量

欢迎来访小刘君公众号
阳光创意站

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值