本文转自: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();

相关文章: