服务器之家

服务器之家 > 正文

Mybatis示例之SelectKey的应用

时间:2021-06-25 13:41     来源/作者:isea533

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

不管selectkey有多好,尽量不要遇到这种情况吧,毕竟很麻烦。

Mybatis示例之SelectKey的应用

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

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

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

?
1
2
3
4
5
6
<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的参数类型还要一致,否则会报错。

?
1
2
3
@insert("insert into table2 (name) values(#{name})")
@selectkey(statement="call identity()", keyproperty="nameid", before=false, resulttype=int.class)
int inserttable2(name name);

上面是注解的形式。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接

原文链接:https://blog.csdn.net/isea533/article/details/21153791

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部