温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

selectKey标签的作用是什么

发布时间:2021-06-26 09:55:32 来源:亿速云 阅读:186 作者:chen 栏目:大数据

这篇文章主要介绍“selectKey标签的作用是什么”,在日常操作中,相信很多人在selectKey标签的作用是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”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 主键类型

到此,关于“selectKey标签的作用是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI