MyBatis框架:第四章:插入记录并返回主键

简介: MyBatis框架:第四章:插入记录并返回主键

往数据库插入数据后,返回数据主键信息。有两种方法。

一种:使用insert标签中的useGeneratedKeys属性和keyProperty属性组合使用获取主键信息。

一种:使用子元素selectKey标签执行sql语句获取。

<!-- 插入用户
  useGeneratedKeys="true"
  表示返回生成的主键
  keyProperty 表示把返回的key注入到返回值的哪个属性中
  keyProperty="id" 表示把返回的id主键值注入到返回对象的id属性中
 -->
<insert id="saveUser" useGeneratedKeys="true" keyProperty="id" 
  parameterType="com.pojo.User">
  insert into t_user(last_name,sex) values(#{lastName},#{sex})
</insert>

<selectKey> 标签的使用

selectKey 通过前置或后置操作,返回数据的主键值。

插入记录并返回主键主要是在标签中添加一个<selectKey>


<selectKey>的作用主要就是为了返回插入记录后,自动生成的主键信息

order 表示执行的顺序。

AFTER 表示在插入之后执行。

BEFORE 在插入之前执行。

keyProperty 属性设置对象的哪个属性接收

resultType 属性设置返回值类型。

<!-- 插入用户 -->
<insert id="saveUser" parameterType="com.pojo.User">
  <!-- 
    selectKey标签主要用于插入数据后,获取生成的主键。
    order 表示执行的顺序,AFTER表示在插入之后执行。BEFORE在插入之前执行。
    keyProperty属性设置对象的哪个属性接收
    resultType属性设置返回值类型。
   -->
  <selectKey order="AFTER" keyProperty="id" resultType="int">
    SELECT LAST_INSERT_ID()
  </selectKey>
  insert into t_user(last_name,sex) values(#{lastName},#{sex})
</insert>

selectKey 返回Oracle的序列自增主键

<selectKey order="BEFORE" resultType="int" keyProperty="id"> 
     select 序列名.nextval as id from dual 
</selectKey> 
相关文章
|
2月前
|
SQL Java 数据库连接
持久层框架MyBatisPlus
持久层框架MyBatisPlus
50 1
持久层框架MyBatisPlus
|
3月前
|
缓存 Cloud Native 安全
探索阿里巴巴新型ORM框架:超越MybatisPlus?
【10月更文挑战第9天】在Java开发领域,Mybatis及其增强工具MybatisPlus长期占据着ORM(对象关系映射)技术的主导地位。然而,随着技术的发展,阿里巴巴集团推出了一种新型ORM框架,旨在提供更高效、更简洁的开发体验。本文将对这一新型ORM框架进行探索,分析其特性,并与MybatisPlus进行比较。
93 0
|
5月前
|
Java 数据库连接 Spring
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
文章是关于Spring、SpringMVC、Mybatis三个后端框架的超详细入门教程,包括基础知识讲解、代码案例及SSM框架整合的实战应用,旨在帮助读者全面理解并掌握这些框架的使用。
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
|
5月前
|
Java 数据库连接 mybatis
mybatis框架图
文章介绍了MyBatis框架的起源、发展和其作为持久层框架的功能,提供了MyBatis的框架图以帮助理解其结构和组件。
mybatis框架图
|
5月前
|
Java 数据库连接 mybatis
后端框架的学习----mybatis框架(9、多对一处理和一对多处理)
这篇文章介绍了在MyBatis框架中如何处理多对一和一对多的关联查询,通过定义`<resultMap>`和使用`<association>`与`<collection>`元素来实现对象间的关联映射。
|
5月前
|
Java 数据库连接 测试技术
后端框架的学习----mybatis框架(8、lombok)
这篇文章介绍了如何在MyBatis框架中使用lombok库来简化Java实体类的编写,包括在IDEA中安装Lombok插件、在项目中导入lombok依赖以及在实体类上使用Lombok提供的注解。
|
5月前
|
SQL Java 数据库连接
【Java 第十三篇章】MyBatis 框架介绍
MyBatis 原名 iBATIS,2001 年由 Clinton Begin 创建,以其简易灵活著称。2010 年更名以重塑品牌形象。MyBatis 通过 SQL 映射文件将 SQL 语句与 Java 代码分离,支持编写原生 SQL 并与方法映射。具备对象关系映射功能,简化数据库记录处理。支持动态 SQL 构建,灵活应对不同查询条件。内置缓存机制,提升查询效率。相比全功能 ORM,MyBatis 提供更高 SQL 控制度和更好的维护性,并易于与 Spring 等框架集成,广泛应用于 Java 数据访问层。
47 0
|
5月前
|
druid Java 数据库连接
SpringBoot项目整合MybatisPlus持久层框架+Druid数据库连接池,以及实现增删改查功能
SpringBoot项目整合MybatisPlus和Druid数据库连接池,实现基本的增删改查功能。
410 0
|
5月前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(5、分页)
这篇文章介绍了如何在MyBatis框架中实现分页功能,包括使用SQL的`limit`语句进行分页和利用MyBatis的`RowBounds`对象进行分页的方法。
|
5月前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(7、使用注解开发)
这篇文章讲述了如何使用MyBatis框架的注解方式进行开发,包括在接口上使用注解定义SQL语句,并通过动态代理实现对数据库的增删改查操作,同时强调了接口需要在核心配置文件中注册绑定。