mybaits根据已有数据库数量判断是否插入

该博客介绍了如何使用MyBatis实现根据已有数据库记录数量进行条件插入。在Mapper.xml中,利用`insert into ... select from DUAL where 子查询`的SQL语句,结合Map参数传入插入实体类和判断数量。在测试类中创建Map,设置实体类和判断数量,并调用对应的DAO方法进行测试。
摘要由CSDN通过智能技术生成

目前有这一需求,在数据库按照某条件检索如果数量大于一个数,默认就不插入,返回影响数据条目数应该为0.。

这样在插入时,参数一共两个一个是要插入的实体类另一个就是要判断的数量,这里mybaits的参数类型就要用map来进行传入,同时根据key值来直接获取。针对在插入时判断,就要采用insert into 数据表 select 具体值 from DUAL where 条件,这种语句来实现。

这里mapper.xml代码如下:

<insert id="insertSealUnderCount" parameterType="java.util.Map">
        insert into tss(seal_id, seal_type)
        select #{seal.sealId}, #{seal.sealType}  from DUAL  where (select count(*) from tss where status=1 or status=2) &lt; #{count}
    </insert>

对应dao层如下:

public int insertSealUnderCount(Map<String, Object> map);

测试类如下:

import java.util.HashMap;
import java.util.Map;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.Con

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值