赞
踩
数据库主键包括自增和非自增,有时候新增一条数据不仅仅知道成功就行了,后边的逻辑可能还需要这个新增的主键,这时候再查询数据库就有点耗时耗力,我们可以采用selectKey来帮助我们获取新增的主键
查询数据库最简单的几步
- @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();
-
- }
-
- }

- @Service
- public class SelectKeyServiceImpl implements SelectKeyService {
-
-
- @Autowired
- SelectKeyMapper selectKeyMapper;
-
- @Override
- public int insert(Goods goods) {
-
- int insert = selectKeyMapper.insert(goods);
-
- return insert;
- }
- }
- public interface SelectKeyMapper {
-
- int insert(Goods goods);
-
- }
- @Data
- public class Goods {
-
- //自增主键
- private Integer id;
-
- private String mid;
-
- private String gname;
-
- private String price;
-
- private String amount;
-
- private String imageName;
-
- }

- <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 主键类型
查询数据库
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。