首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MyBatis魔法堂:Insert操作详解(返回主键、批量插入)

一、前言                                      数据库操作怎能少了INSERT操作呢?下面记录MyBatis关于INSERT操作的笔记,以便日后查阅。...对特定数据库(如PostgreSQL),若自动生成的主键不是第一个字段则必须设置 keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中...into TStudent(id, name, age) values(#{id}, #{name}, #{age}) insert   注意:mapper接口返回值依然是成功插入的记录数,但不同的是主键值已经赋值到领域模型实体的...接口的add方法返回值将是最一条INSERT语句的操作成功的记录数目(就是0或1),而不是所有INSERT语句的操作成功的总记录数目 2....八、参考                                       http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html

8.6K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Mybatis 中的主键返回

    XML方式 返回自增主键 insert id="insert1" useGeneratedKeys="true" keyProperty="id"> insert into sys_user(...> 使用useGeneratedKeys设置为true后 , MyBatis会使用JDBC的getGeneratedKeys方法取出由数据库内部生成的主键 ....由于要使用数据库返回的主键值 , 所以SQL上下两部分的列中去掉了 id 列和对于的 #{id} 属性 返回非自增主键 采用标签获取主键的值 , 这种方式对提供和不提供主键自增功能的数据库同样适用...() insert> selectKey标签的 keyProperty和上面useGeneratedKeys的用法和含义一样 , 这里的resultType用于设置返回值类型.... order 属性和数据库相关 , 在MYSQL 中 , order是AFTER , 因为当前及记录的主键值在insert语句执行成功之后才能拿到 , 而在ORACLE中 ,oder是BEFORE ,

    81020

    MyBatis插入数据后返回主键id

    最近开发全栈项目时,前端有个数据行可以被随便修改,所以必须给他一个标识记录该数据行,即向MySQL数据库中插入一条记录后,需要获取此条记录的主键id值返回给前端。...,name) values(#{articleTitle},#{articleCreateDate},#{articleContent},#{addName}) insert> 这种方式只是返回一个影响行数值...},#{articleContent},#{addName}) insert> 关键属性 useGeneratedKeys 仅适用于 insert 和 update,这会令 MyBatis 使用 JDBC...的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如MySQL的自动递增主键字段),默认值:false。...所以要打开设为 true keyProperty 仅适用于 insert 和 update,指定能够唯一识别对象的属性,MyBatis 会使用 getGeneratedKeys 的返回值或 insert

    1.8K10

    深入浅出mybatis之返回主键ID

    除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。...-- 插入数据:返回记录主键id值 --> insert id="insertOneTest" parameterType="org.chench.test.mybatis.model.Test...,在MyBatis中添加操作返回的是记录数并非记录主键id。...-- 批量添加数据,并返回主键字段 --> insert id="insertBatchTest" useGeneratedKeys="true" keyProperty="id"> INSERT...获取主键ID实现原理 需要注意的是,不论在xml映射器还是在接口映射器中,添加记录的主键值并非添加操作的返回值。实际上,在MyBatis中执行添加操作时只会返回当前添加的记录数。

    3.5K20

    MyBatis的Insert方法一直返回-2147482646?

    前几天在做项目demo的时候,发现有一个很奇怪的现象,就是MyBatis发现更新和插入返回值一直为"-2147482646",无论怎么改,这个值一直不变......"; int res= sqlSession.insert(sql, "1");// 4、SqlSession.insert()方法: public interface SqlSession extends...Closeable { int insert(String var1); int insert(String var1, Object var2); } SqlSession是一个接口...,里面有insert方法,我们再来看一下这个接口的实现类: ?...阿里面试:“说一下从 url 输入到返回请求的过程” 千呼万唤始出来,这个奇怪的数字原来在这里出来的,其中可以看到它是固定返回的,没有任何判断逻辑...这样就证明了一点,只要你的insert方法在配置文件中配置的是

    1.3K30

    mybatis插入数据后返回自增主键ID详解

    1.场景介绍: ​ 开发过程中我们经常性的会用到许多的中间表,用于数据之间的对应和关联.这个时候我们关联最多的就是ID,我们在一张表中插入数据后级联增加到关联表中.我们熟知的mybatis在插入数据后返回的是插入成功的条数...2.插入数据返回自增主键ID方法(一) 在映射器中配置获取记录主键值 xml映射: 在xml中定义useGeneratedKeys为true,返回主键id的值,keyProperty和keyColumn...-- 插入数据:返回记录主键id值 --> insert id="insert" useGeneratedKeys="true" keyProperty="id" keyColumn="id">...需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键id。...-- 批量添加数据,并返回主键字段 --> insert id="insert" useGeneratedKeys="true" keyProperty="id"> insert into

    12.4K30

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

    往数据库插入数据后,返回数据主键信息。有两种方法。 一种:使用insert标签中的useGeneratedKeys属性和keyProperty属性组合使用获取主键信息。...-- 插入用户useGeneratedKeys="true"表示返回生成的主键keyProperty 表示把返回的key注入到返回值的哪个属性中keyProperty="id" 表示把返回的id主键值注入到返回对象的...>insert into t_user(last_name,sex) values(#{lastName},#{sex})insert>12345678910标签的使用 selectKey 通过前置或后置操作...,返回数据的主键值。...插入记录并返回主键主要是在标签中添加一个的作用主要就是为了返回插入记录后,自动生成的主键信息 order 表示执行的顺序。 AFTER 表示在插入之后执行。 BEFORE 在插入之前执行。

    64400

    Mybatis 手撸专栏|第15章:返回Insert操作自增索引值

    Mybatis 手撸专栏第15章:返回Insert操作自增索引值本文是《Mybatis 手撸专栏》的第15章,我们将深入学习如何在Insert操作中返回自增索引值。...本章将详细介绍如何在Mybatis中实现返回Insert操作的自增索引值,并给出示例和实践指导。...但是,对于Insert操作而言,我们通常需要获取新插入记录的自增索引值,以便于后续的操作和处理。在本章中,我们将深入探讨如何在Mybatis中实现返回Insert操作的自增索引值。...返回自增索引值的配置和使用在Mybatis中,我们可以通过配置和使用一些特定的技术来实现返回Insert操作的自增索引值。下面,我们将分别对每种生成方式进行详细介绍和示例展示。...总结本章我们深入学习了如何在Mybatis中实现返回Insert操作的自增索引值。我们详细介绍了几种常见的数据库自增索引值的生成方式,并给出了在Mybatis中配置和使用的示例代码。

    45940
    领券