resultType : 正常的返回值。...也就是 PRSP_CRM_ENTERP_ID.nextval 的返回值类型 order : 这个oracle 必须写BEFORE ,mysql 是after 。...如果执行了上面一个新增语句,那么这个 ID 就会映射到实体类中了。。直接取得就好了。。 注意:不能直接取 retID 不然这个永远都是 1。。。...="java.lang.Integer" order="AFTER" keyProperty="id"> SELECT LAST_INSERT_ID() AS ID... INSERT INTO S_T_LOGS ( ID, USER_ID, USER_NAME,
最近开发全栈项目时,前端有个数据行可以被随便修改,所以必须给他一个标识记录该数据行,即向MySQL数据库中插入一条记录后,需要获取此条记录的主键id值返回给前端。...articleCreateDate},#{articleContent},#{addName}) 关键属性 useGeneratedKeys 仅适用于 insert 和 update,这会令 MyBatis...使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如MySQL的自动递增主键字段),默认值:false。...所以要打开设为 true keyProperty 仅适用于 insert 和 update,指定能够唯一识别对象的属性,MyBatis 会使用 getGeneratedKeys 的返回值或 insert...这里我们要开启就需要指定为Article对象的id。
使用mybatis时,insert方法如何返回主键?...selectKey resultType="java.lang.String" order="AFTER" keyProperty="user.id"> SELECT LAST_INSERT_ID...( #{user.name},#{user.age},#{user.address}) 下面这个是关键:order的值是after,表示先执行insert语句,然后再选择最后一个主键...,返回到实体类中。 ...的get set方法,添加方法执行完后id会被塞回到user对象中。
有时候使用mybatis插入数据后,需要用到记录在数据库中的自增id,可以利用keyProperty来返回,赋值给实体类中的指定字段。...单条记录插入并返回 First, if your database supports auto-generated key fields (e.g....id为实体类中的字段名称 多条记录插入并返回 If your database also supports multi-row insert, you can pass a list or an array...没有返回的情况。...检查以下几点: 1、Mybatis版本3.3.1及其以上。 2、在Dao中不能使用@param注解。 3、Mapper.xml中使用list变量接受Dao中的集合。
除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。...添加单一记录时返回主键ID 添加一条记录时返回主键值,在xml映射器和接口映射器中都可以实现。...-- 插入数据:返回记录主键id值 --> id="insertOneTest" parameterType="org.chench.test.mybatis.model.Test...需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键id。...获取主键ID实现原理 需要注意的是,不论在xml映射器还是在接口映射器中,添加记录的主键值并非添加操作的返回值。实际上,在MyBatis中执行添加操作时只会返回当前添加的记录数。
这是最近在实现perfect-ssm中的一个功能时碰到的一个小问题,觉得需要记录一下,向MySQL数据库中插入一条记录后,需要获取此条记录的id值,以生成对应的key值存入到redis中,id为自增int...主键。...add_name) values(#{articleTitle},#{articleCreateDate},#{articleContent},#{addName}) 这种方式只是返回一个影响行数值...,并不能满足此次需求,于是做了如下修改: id="insertArticle" useGeneratedKeys="true" keyProperty="id" parameterType...=null); System.out.println("insert后article的id:"+article.getId()); } 结果如下: ?
1.1 xml 配置主键返回 <!...-- last_insert_id() : 查询刚插入数据自增 id order : 执行的时机: after 之前执行; before 之后执行...}, #{total}, #{uid}) 1.2 注解配置主键返回 @Options(useGeneratedKeys = true, keyProperty = "id", keyColumn...orders); 1.3 获取主键 // 实体类对象,属性值省略 Orders orders; // 插入,返回值为影响的行数 Integer rows = sqlSession.getMapper(...OrdersDao.class).insert(orders); // id 需要通过实体类对象获取 Long id = orders.getId()
Mybatis映射文件深入 - 新增数据后返回主键ID - 动态SQL - SQL片段 前言 在前面的篇章中,我们已经认识了如何使用 resultMap标签 映射查询的结果集字段、多条件查询、模糊查询。...下面我们继续来深入认识一下 MyBatis 的映射文件。 新增数据后,返回主键 ID 应用场景 向数据库保存一个user对象后, 然后在控制台打印此新增user的主键值(id) # 点外卖 1....需要返回这条记录的主键, 然后给第三方配送平台, 送外卖 实现案例一:基于MyBatis 框架自带的主键返回功能 ① UserMapper接口 /* * # 复杂操作:插入一条数据返回对应的主键...MyBatis框架自动的主键返回功能,而有些时候,我们的主键有可能不是自增 ID,有可能是自己生成的 UUID。...2.4 知识小结 MyBatis映射文件配置 :查询 :插入 :修改 :删除 :插入返回主键 <where
1.场景介绍: 开发过程中我们经常性的会用到许多的中间表,用于数据之间的对应和关联.这个时候我们关联最多的就是ID,我们在一张表中插入数据后级联增加到关联表中.我们熟知的mybatis在插入数据后返回的是插入成功的条数...,那么这个时候我们想要得到相应的这条新增数据的ID,该怎么办呢?...2.插入数据返回自增主键ID方法(一) 在映射器中配置获取记录主键值 xml映射: 在xml中定义useGeneratedKeys为true,返回主键id的值,keyProperty和keyColumn...(name,age) values (#{name},#{age})") void insert(Student stu); 获取新添加记录主键字段值 需要注意的是,在MyBatis中添加操作返回的是记录数并非记录主键...System.out.println("id = " + student.getId()); // 执行添加操作之后通过Java对象获取主键属性值 添加批量记录时返回主键ID 如果希望执行批量添加并返回各记录主键字段值
XML方式 返回自增主键 id="insert1" useGeneratedKeys="true" keyProperty="id"> insert into sys_user(...values(#{userName},#{password},#{email},#{info},#{createTime}) 使用useGeneratedKeys设置为true后 , MyBatis...获得主键值之后将其赋给keyProperty配置的 id 属性 ....由于要使用数据库返回的主键值 , 所以SQL上下两部分的列中去掉了 id 列和对于的 #{id} 属性 返回非自增主键 采用标签获取主键的值 , 这种方式对提供和不提供主键自增功能的数据库同样适用...useGeneratedKeys的用法和含义一样 , 这里的resultType用于设置返回值类型. order 属性和数据库相关 , 在MYSQL 中 , order是AFTER , 因为当前及记录的主键值在
SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。...="java.lang.String" order="BEFORE" keyProperty="id"> select wxsh_seq.nextval as id from dual... INSERT INTO WXSH_LOG_OUT (ID, OUT_NO, USER_ID, FILE_NAME,...); } catch (Exception e) { logger.error(e.getMessage()); } return 0; } **map中会增加返回的主键...id**
这样就有一个问题,我们怎么才能将user与role两者关联起来呢,要知道我们关联user与role就是将user的主键userId与role的主键roleId插入到user-role这个关联表中,之前因为我们是先创建在分配...id" order="AFTER" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID()... 主要有这几个注意点: keyProperty,这里面填写的是你自己定义的主键名称,比如说你的是userId,里面就填userId,否则会报错 order,order有两个值before...,after,这两个值分别表示一个是在执行插入操作之前再取出主键id,一个是执行插入操作之后再取出主键Id.前者使用与自己定义的自增长规则的id,后者就是用与我们的情况即自增长的id 小栗子: Id"> .............................
", user); session.commit(); return user.getUserId();//返回插入数据库后得到的用户id } 这里总结一下mybatis...插入数据时返回主键的4种情况:mysql环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。 ...,查询并返回刚插入数据的主键(但是单独执行这条语句只会返回0)。...最小值=1 NOCYCLE; -- 不循环 利用USER_ID_SEQ.NEXTVAL 获得要插入数据的主键: id="insertUser" parameterType="com.danny.mybatis.po.User...UUID时 用oracle自带的SYS_GUID()方法获得随机的GUID作为主键: id="insertUser" parameterType="com.danny.mybatis.po.User
SQL Server中命令: select newId() ,可以得到SQL server数据库原生的UUID值,因此我们可以将这条指令写到 Mybatis的主键生成策略配置selectKey中。...如下: 在 mapper.xml 类型映射配置文件中 id="insert" parameterType="com.hqdl.xiaoyi.bean.SpUser"> id" resultType="String" order="BEFORE"> select newId() ...insert into sp_user_list (id, name, full_name, password, category, user_type, company_id..., depart_id, code, locked, wrong_pwd_count, last_login_time, lock_reason, create_user_id
代码直接放在Github仓库【https://github.com/Damaer/Mybatis-Learning/tree/master/mybatis-05-CURD 】 需要声明的是:此Mybatis...1.useGeneratedKeys 设置主键自增 2.使用selectKey 查询主键 我们知道很多时候我们有一个需求,我们需要把插入数据后的id返回来,以便我们下一次操作。..."设置主键的字段 3.parameterType="Student"设置传入的类型 4.注意:虽然有返回类型,但是我们不需要手动设置返回的类型,这个是由框架帮我们实现的,所以对应的接口方法也是没有返回值的...5.实体类中id属性字段一定需要set以及get方法 2.使用selectKey 查询主键 id="insertStudentCacheId" parameterType="Student...其实,我们的接口中可以有返回值,但是这个返回值不是id,而是表示插入后影响的行数,此时sql中仍和上面一样,不需要写返回值。
加上这句: id"> ID() AS trade_id ]]> 例如: ?
在整合mybatis-plus后,使用他自带的insert新增方式,不需要手动设置id,可以采用他自己的算法设置id,如下: ps:这两个注解一定不要忘了,不然他找不到对应的表和字段,Idtype...Auto:让id自增,需要在数据库新建表时就设置好id自增,不然会报错。
一、Mybatis执行插入语句后可以返回主键ID吗? 在想写什么内容的时候,正好看到一个基础面试题上有这个问题,就把它记录下来了。 面试官:你说Mybatis执行插入语句后可以返回主键ID吗??...()返回的是最后一个ID值意思。...keyProperty属性,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中,也就是你实体类中,对应数据库的主键id。...最后在实体类中,要有主键的get与set方法,满足后,在impl层controller层,直接实体类.getId() 即可获取本次插入后的主键ID,返回前端即可。...二、Mybatis-Plus在执行插入语句后返回自定义ID 面试官:那你会用Mybatis-Plus吗?Mybatis-Plus如何做这件事情啊,有简单的方式吗?
首先你要确定几点 1: 你数据表的ID 是不是 设置了自增?如果没有,那么一切都是徒劳 2: 必须的几个属性你添加了么?...useGeneratedKeys="true"(默认是false) keyProperty="id" 3: keyProperty 这个设置的是 你传入对象的属性名,不是你数据表的字段 如果以上情况都满足...,那么你很有可能犯了一个和我一样的错误 网上大部分教程在写 insert对象并返回自增主键的 demo 的时候,都是直接传入对象,而没有用@Param注解 其实他们的区别在这里 keyProperty...="id" 如果你不用 @Param注解 ,那么你在 #{xxx}里写的是 对象的属性 如果你使用 @Param注解,那么相当于你给参数对象 命名了,那么你在#{xxx}里写的就是 命名参数.属性 但是你忘了
下面记录MyBatis关于INSERT操作的笔记,以便日后查阅。...对特定数据库(如PostgreSQL),若自动生成的主键不是第一个字段则必须设置 keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中... 手段②: id="add" parameterType="EStudent"> // 下面是SQLServer获取最近一次插入记录的主键值的方式 返回值依然是成功插入的记录数,但不同的是主键值已经赋值到领域模型实体的id中了。...八、参考 http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html