selectKey标签详解(*)

selectKey标签详解(*)文章浏览阅读6.9k次,点赞7次,收藏24次。1.为什么要使用selectKey数据库主键包括自增和非自增,有时候新增一条数据不仅仅知道成功就行了,后边的逻辑可能还需要这个新增的主键,这时候再查询数据库就有点耗时耗力,我们可以采用selec

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

2.具体实现demo
查询数据库最简单的几步
(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)service

@Service
public class SelectKeyServiceImpl implements SelectKeyService { 
   
 
    @Autowired
    SelectKeyMapper selectKeyMapper;
 
    @Override
    public int insert(Goods goods) { 
   
 
        int insert = selectKeyMapper.insert(goods);
 
        return insert;
    }
}

(3)mapper

public interface SelectKeyMapper { 
   
 
    int insert(Goods goods);
 
}

(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 主键类型

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/37293.html

(0)

相关推荐

  • mysql安全管理免费PPT_MySQL 修改密码

    mysql安全管理免费PPT_MySQL 修改密码数据库服务器通常包含关键的数据,确保这些数据的安全和完整需要利用访问控制。一、访问控制MySQL服务器的安全基础:用户应该对他们需要的数据具有适当的访问权,既不能多也不能少。访问控制:你需要给用户提供

    2023-01-24
    143
  • 2020 还不会泡 Github 你就落伍了「建议收藏」

    2020 还不会泡 Github 你就落伍了「建议收藏」回想起两年前刚接触 GitHub 那会儿,就发现网上完全搜不到一篇关于 github 使用的文章,虽然自己倒腾几下慢慢的也就上手了,但毕竟花费了不少时间。 GitHub 作用:借助 github 托管项目代码。 对别人的代码进行了改进,向作者发出修改请求,作者同意后可以合并到它…

    2023-08-01
    122
  • 谷歌硬件产品_谷歌应用商店镜像

    谷歌硬件产品_谷歌应用商店镜像前几天举行的谷歌2022年度全球开发者大会(谷歌I/O大会)看点颇多,有沉浸式搜索地图,有24个小语种翻译,有更新后的Android 13操作系

    2023-07-01
    132
  • 使用time.sleep(1)进行Python编程休眠操作

    使用time.sleep(1)进行Python编程休眠操作在进行Python编程过程中,我们常常需要进行休眠操作,即程序暂停一段时间。这时,我们可以使用Python中的time模块中的sleep()函数来实现。休眠操作在处理网络请求、爬虫、文件读写等领域都有广泛应用。

    2024-05-30
    65
  • java sql server增删改查_java连接sql数据库项目

    java sql server增删改查_java连接sql数据库项目写个例子方便以后直接拿过来测试。 随便个springboot的maven项目都可以。 pom.xml 配置

    2023-02-15
    154
  • MYSQL语法 笔记总结

    MYSQL语法 笔记总结1.增加数据 2.删除数据 3.更新数据 4.查询数据 5.模糊查询 6.交集查询 7.排序查询 8.分组查询 9.连接查询

    2023-02-03
    156
  • fastpitch和fastspeech2_模型检验的方法

    fastpitch和fastspeech2_模型检验的方法本文件主要是定义Variance Adaptor,其中主要包括Duration Predictor、Length Regulator、Pitch

    2022-12-14
    158
  • 汇总数据库信息的存储过程[通俗易懂]

    汇总数据库信息的存储过程[通俗易懂]问题: mysql日常开发过程中,数据库、表的很多信息分散在不同的工具和不同的界面中,来回切换查找非常麻烦。 解决方式: 基于这个问题,写了一个存储过程,将这些日常需要的信息集合在一个存储过程中,查询

    2023-05-05
    160

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注