本文转自:http://289972458.iteye.com/blog/1001851
http://hi.baidu.com/zim_it/blog/item/8a2bd11205f5b56ecb80c4b7.html
在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数;如果业务层需要得到记录的主键时,可以通过配置的方式来完成这个功能
针对Sequence主键而言,在执行insert sql前必须指定一个主键值给要插入的记录,如Oracle、DB2,可以采用如下配置方式:
使用Oracle时之前要执行一下 创建sequence语句 mysql就不用了,看下面
<insert >
insert into category (
name_zh, parent_id, show_order, delete_status, description
) values (
#{nameZh,jdbcType=VARCHAR}, #{parentId,jdbcType=SMALLINT}, #{showOrder,jdbcType=SMALLINT},
#{deleteStatus,jdbcType=BIT}, #{description,jdbcType=VARCHAR}
)
</insert>
或
<insert >
SELECT LAST_INSERT_ID() AS id
</selectKey>
insert into category (
name_zh, parent_id, show_order, delete_status, description
) values (
#{nameZh,jdbcType=VARCHAR},
#{parentId,jdbcType=SMALLINT},
#{showOrder,jdbcType=SMALLINT},
#{deleteStatus,jdbcType=BIT},
#{description,jdbcType=VARCHAR}
)
</insert>
在插入操作完成之后,参数category的id属性就已经被赋值了
如果数据库表的主键不是自增的类型,那么就需要应用层生成主键的方式··········这个就不多说了,需要的朋友,可以留言交流··
-----------------------------------------
下面是针对Oracle的写法,Oracle没有autoincrement,而是用触发器实现的 CURRVAL是在触发器中定义的.
<insert >
SELECT LAST_INSERT_ID()
</selectKey>
INSERT INTO P_PERMISSION (
PERMISSIONID, PERMISSIONINFO, PERMISSIONNAME, PERMISSIONENNAME, URL
) VALUES (
#permissionId#, #permissionInfo#, #permissionName#, #permissionEnName#, #url#
)
</insert>
在插入操作完成之后,参数category的id属性就已经被赋值了
eg:
resourcesDao.insertSelectiveAndReturnId(res);
long newID = res.getResid();