Mybatis 示例之 SelectKey
来源:互联网 发布:时尚杂志软件 编辑:程序博客网 时间:2024/05/17 04:52
SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。
不管SelectKey有多好,尽量不要遇到这种情况吧,毕竟很麻烦。
SelectKey需要注意order属性,像MySQL一类支持自动增长类型的数据库中,order需要设置为after才会取到正确的值。
像Oracle这样取序列的情况,需要设置为before,否则会报错。
另外在用spring管理事务时,SelectKey和插入在同一事务当中,因而Mysql这样的情况由于数据未插入到数据库中,所以是得不到自动增长的Key。取消事务管理就不会有问题。
下面是一个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);
1 0
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis 示例之 SelectKey
- Mybatis - SelectKey
- Mybatis之selectKey的运用改了一下
- MyBatis之主键自增——selectKey
- mybatis学习之路----insert主键返回 selectKey使用
- mybatis的selectKey功用
- MyBatis <selectKey>标签
- mybatis中的selectKey
- mybatis selectkey获取主键
- MyBatis中的selectKey
- H5学习之11(html中的浮动布局)
- pat-A 1095. Cars on Campus (30)
- 小鑫の日常系列故事(二)——石头剪子布
- poj3185 The Water Bowls 开关问题
- Gradle简介
- Mybatis 示例之 SelectKey
- Python 入门神书推荐 —— 500 lines or less
- java 提取公共方法
- <ul> 中 <li>元素的横排居中
- C++引用(左值引用,右值引用)
- IOS-OC 修改UITextField的Placeholder字体颜色
- 简单字符串排序
- ionic2的component中使用angular2中的管道使用(特别是number管道,小坑)
- MUI框架初学——子页面返回键设定