selectKey标签详解

1.为什么要使用selectKey

数据库主键包括自增和非自增,有时候新增一条数据不仅仅知道成功就行了,后边的逻辑可能还需要这个新增的主键,这时候再查询数据库就有点耗时耗力,我们可以采用selectKey来帮助我们获取新增的主键

2.具体实现demo

查询数据库最简单的几步 

2.1 controller

@Controller
public class SelectKeyController {


    @Autowired
    SelectKeyServiceImpl selectKeyService;

    public Integer String(){

        Goods goods = new Goods();
        goods.setAmount("100");
        goods.setGname("红烧肉");
        goods.setMid("666666");
        goods.setPrice("25");

        int insert = selectKeyService.insert(goods);
        System.out.println("执行成功条数: " + insert);
        System.out.println(goods.getId());
        return goods.getId();

    }

}

2.2 service

@Service
public class SelectKeyServiceImpl implements SelectKeyService {


    @Autowired
    SelectKeyMapper selectKeyMapper;

    @Override
    public int insert(Goods goods) {

        int insert = selectKeyMapper.insert(goods);

        return insert;
    }
}

2.3 mapper

public interface SelectKeyMapper {

    int insert(Goods goods);

}

2.4 实体类(根据自己数据库表来写)

@Data
public class Goods {

    //自增主键
    private Integer id;

    private String mid;

    private String gname;

    private String price;

    private String amount;

    private String imageName;
    
}

3.mapper.xml 文件

<mapper namespace="com.example.wjtweb.mapper.SelectKeyMapper">
   
    <insert id="insert" parameterType="com.example.wjtweb.pojo.Goods">
    
        <selectKey keyProperty="id" order="AFTER" resultType="Integer">
            SELECT LAST_INSERT_ID()
        </selectKey>
        INSERT INTO Goods (MID,GNAME,PRICE,AMOUNT,imageName)
        VALUES (#{mid},#{gname},#{price},#{amount},#{imageName});
    </insert>

</mapper>

selectKey 会将 SELECT LASTINSERTID()的结果放入到传入的model的主键里面,keyProperty 对应的model中的主键的属性名,这里是 Goods 中的id,因为它跟数据库的主键对应order AFTER 表示 SELECT LASTINSERTID() 在insert执行之后执行,多用与自增主键,BEFORE表示SELECT LASTINSERTID() 在insert执行之前执行,这样的话就拿不到主键了,这种适合那种主键不是自增的类型resultType 主键类型 

4.输出结果

查询数据库

  • 14
    点赞
  • 50
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值