视频课堂 https://edu.csdn.net/course/play/8034

SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。

使用mybatis的selectKey就可以得到sequence的值,同时也会将值返回。不过对于不同的数据库有不同的操作方式。

属性 描述
keyProperty selectKey 语句结果应该被设置的目标属性。
resultType 结果的类型。MyBatis 通常可以算出来,但是写上也没有问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。
order 这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后是 selectKey 元素-这和如 Oracle 数据库相似,可以在插入语句中嵌入序列调用。
statementType 和前面的相 同,MyBatis 支持 STATEMENT ,PREPARED 和CALLABLE 语句的映射类型,分别代表 PreparedStatement 和CallableStatement 类型。

SelectKey需要注意order属性,像MySQL一类支持自动增长类型的数据库中,order需要设置为after才会取到正确的值。

像Oracle这样取序列的情况,需要设置为before,否则会报错。

下面是一个xml和注解的例子,SelectKey很简单,两个例子就够了:

<insert id="insert" parameterType="map">  insert into table1 (name) values (#{name})  <selectKey resultType="java.lang.Integer" keyProperty="id">  CALL IDENTITY()  </selectKey>  </insert>  

上面xml的传入参数是map,selectKey会将结果放到入参数map中。用POJO的情况一样,但是有一点需要注意的是,keyProperty对应的字段在POJO中必须有相应的setter方法,setter的参数类型还要一致,否则会报错。

对于oracle:

<insert id="insertUser" parameterClass="XXX.User"> <selectKey resultClass="long" keyProperty="id"order="BEFORE"> select SEQ_USER_ID.nextval as id from dual </selectKey> insert into user  (id,name,password) values (#{id},#{name},#{password}) </insert> 

这句话会在插入user之前执行(order="BEFORE"),该句话执行完之后,会生成一个ID,传进来的参数User对象里的id字段就会被赋值成sequence的值。

对于mysql

 <insert id="insertUser" parameterClass="XXX.User"> insert into user (name,password) values (#{id},#{name},#{password}) <selectKey resultClass="long" keyProperty="id" order="after">  SELECT LAST_INSERT_ID() AS ID  </selectKey>  </insert> 

将selectKey放在insert之后,通过LAST_INSERT_ID() 获得刚插入的自动增长的id的值。插入之后获得ID赋值到传进来的对象中(对象中必须有相应的属性)。

像如下本身是Mysql或SqlServer的数据库,没有必要这样使用,有点浪费。

<!--保存用户--><insert id="saveUser" parameterType="com.aaa.entity.User"><selectKey keyProperty="id" keyColumn="id" resultType="int" order="AFTER">select last_insert_id()</selectKey>insert user(id,name,birth,gender,address)values(#{id},#{name},#{birth},#{gender},#{address})</insert>

报错:Field 'id' doesn't have a default value

配置了SELECT LAST_INSERT_ID()后,需要把表结构的id字段设置为自增属性AUTO_INCREMENT
以上

mybatis的SelectKey属性的作用相关推荐

  1. Mybatis中selectKey 标签的作用,主键回填,找了好多文章没一个解释清楚。。

    (1)没有配置selectKey 标签时候插入数据: <insert id="addUser" parameterType="model.User"> ...

  2. 关于mybatis中selectKey的用法

    在使用MyBatis插入数据进入数据库的时候会用到sequence序列来生成自增的id 这时可以使用selectKey就可以得到sequence的值,同时也会将值返回.不过对于不同的数据库有不同的操作 ...

  3. mybatis的selectKey的用法

    Mybatis 示例之 SelectKey SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式. 不管SelectKey有多好, ...

  4. Mybatis中的jdbcType的作用

    2019独角兽企业重金招聘Python工程师标准>>> Mybatis中的jdbcType的作用 使用MyBatis框架做更新操作时,在该字段需要更新的内容为空时,就会出现1111错 ...

  5. 浏览器各个属性的作用

    作为前端程序员不可避免的会和浏览器打交道,所以要对浏览器的各个属性的作用进行了解,方便开发及调试,这里以谷歌浏览器为例进行简单的介绍.一是巩固对浏览器属性的认识,二是方便大家的学习. 首先打开谷歌浏览 ...

  6. html中属性的作用,html的标签中 unselectable=on 属性的作用

    在IE浏览器中,当input获得焦点时,点击有unselectable="on"属性的标签时,不会触发onblur事件. 加上该属性的元素不能被选中. < !DOCTYPE ...

  7. Vue中key属性的作用

    Vue中key属性的作用 在列表渲染时使用key属性 使用key属性强制替换元素 在列表渲染时使用key属性 相信大多数Vue开发者接触到key属性的时候是使用v-for进行列表渲染的时候,如果不使用 ...

  8. html中outline属性,css的outline属性的作用是什么

    css的outline属性的作用是什么 发布时间:2020-05-06 11:47:34 来源:亿速云 阅读:280 作者:小新 css的outline属性的作用是什么?相信有很多人都不太了解,今天小 ...

  9. SEO链接为什么要用nofollow,nofollow属性的作用是什么,nofollow的用法

    在SEO领域中,有很多SEO专业做了几年SEO优化,可能都不知道nofollow是干什么的,那么下面长沙seo搜遇网络顾问带大家了解一下nofollow.nofollow是如何运用的. nofollo ...

最新文章

  1. 基于springboot+vue实现外卖点餐系统
  2. 智能合约重构社会契约 (1)李嘉图合约
  3. [Qt教程] 第33篇 网络(三)FTP(一)
  4. Java基础---匿名对象的理解和使用
  5. centos中 npm install 被kill的解决方案
  6. 经典手眼标定算法之Tsai-Lenz的OpenCV实现
  7. java实现 GB35114 sip AuthorizationHeader遇到的一个小坑
  8. 手把手教你搭建微信小程序服务器(HTTPS)
  9. 1分钟快速实现高效的扫描二维码,急速识别手机相册二维码
  10. R_Studio(学生成绩)对数据缺失值md.pattern()、异常值分析(箱线图)
  11. 以下哪个函数不能选择mysql数据库_PHP使用以下哪个函数连接MySQL数据库服务器...
  12. pandas常用方法
  13. 【C语言】——C语言实现科赫雪花及科赫曲线
  14. 【面经】美团算法二面
  15. 关于自信,与自信的培养
  16. 批处理电脑右下角不显示网络音量图标
  17. AtmelStudio 7 ASF库学习笔记一:新建工程、配置时钟、下载程序和查看官方例程
  18. android输出日期格式,如何在Android中将“ yyyy-MM-dd'T'HH:mm:ss.SSSXXX”日期格式解析为简单格式?...
  19. python计算狗的年龄_狗的年龄和人的年龄换算!如何判断狗狗的年龄?
  20. 计算机应用类专业综合知识试题2019,湖南省2019年对口升学计算机应用综合试题(手打实图)...

热门文章

  1. 同步类的基础AbstractQueuedSynchronizer(AQS)
  2. 素数环-dfs回溯+二维数组记录(c++实现)
  3. Linux网络编程 之 套接字(四)
  4. kafka_consumer_消费原理介绍
  5. leetcode -- 1091. 二进制矩阵中的最短路径
  6. 为什么delete表,还会占磁盘空间?
  7. 批量ping脚本shell_30个Linux Shell脚本经典案例(上)
  8. 多维数组的索引与切片_Numpy库使用入门(二)数据的索引和切片
  9. mysql存储文件用什么类型_块存储、文件存储、对象存储的区别是什么?
  10. clistctrl 单机空白处 会取消选中_官方默许BUG:无法选中也能被控制?这些秘密很多玩家到现在都没发现!...