Mybatis示例之SelectKey的应用
程序员文章站
2024-03-03 17:14:40
selectkey在mybatis中是为了解决insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。
不管selectkey有多好,尽量不要遇到这...
selectkey在mybatis中是为了解决insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。
不管selectkey有多好,尽量不要遇到这种情况吧,毕竟很麻烦。
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的参数类型还要一致,否则会报错。
@insert("insert into table2 (name) values(#{name})") @selectkey(statement="call identity()", keyproperty="nameid", before=false, resulttype=int.class) int inserttable2(name name);
上面是注解的形式。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
上一篇: Android基础开发小案例之短信发送器
推荐阅读
-
Mybatis示例之SelectKey的应用
-
史上最简单的MyBatis动态SQL入门示例代码
-
Android入门教程之ListView的应用示例
-
Android编程仿Iphone拖动相片特效Gallery的简单应用示例
-
Android编程基础之获取手机屏幕大小(DisplayMetrics应用)示例
-
Android编程基础之简单Button事件响应综合提示控件Toast应用示例
-
AES加解密在php接口请求过程中的应用示例
-
Python学习笔记之if语句的使用示例
-
Spring Boot整合Mybatis并完成CRUD操作的实现示例
-
Android应用开发中使用GridView网格布局的代码示例