Mybatis 示例之 SelectKey
来源:互联网 发布:淘宝外国模特 编辑:程序博客网 时间:2024/06/06 22:49
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);
0 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
- Unix环境高级编程(阅读笔记)-----kill、raise、alarm、pause函数
- Android读取系统mp3文件
- 实现一个固定长度的集合,每个1s中刷新一次,第一个元素去掉,从最后面添加一个元素。
- 项目二 实现复数类中的运算符重载(2)
- 求二进制中1的个数
- Mybatis 示例之 SelectKey
- python里面的tuple与list对比
- 接口测试之旅
- nth-child的正确理解
- Python字符串编码详解
- java变量初始化
- Error:Execution failed for task ':app:processDebugManifest'. > Manifest merger failed with multiple
- 【ORACLE】oracle的一些操作记录
- Docker题外话