插入返回ibatis 的selectKey 实现插入数据后获得id

在本篇文章中,我们主要介绍插入返回的内容,自我感觉有个不错的建议和大家分享下

  在用使ibatis插入据数进据数库的时候,会用到一些sequence的据数,有些情况下,在插入成完以后还需要将sequence的值返回,然后才能停止下一步的操纵。

      用使ibatis的selectKey以可就失掉sequence的值,同时也会将值返回。不过对于不同的据数库有不同的操纵方法。

      对于oracle:

      <insert id="insertUser" parameterClass="ibatis.User">

         

     <selectKey resultClass="long" keyProperty="id">

              select SEQ_USER_ID.nextval as id from dual

          </selectKey>

           insert into user

          (id,name,password)

          values

          (#id#,#name#,#password#)

      </insert>

    每日一道理
信念是巍巍大厦的栋梁,没有它,就只是一堆散乱的砖瓦;信念是滔滔大江的河床,没有它,就只有一片泛滥的波浪;信念是熊熊烈火的引星,没有它,就只有一把冰冷的柴把;信念是远洋巨轮的主机,没有它,就只剩下瘫痪的巨架。

       该句话执行完以后,传进来的数参User对象DO里的id字段就会被赋值成sequence的值。

     对于mysql

     <insert id="insertUser" parameterClass="ibatis.User">

          insert into user

          (name,password)

          values

          (#name#,#password#)

         

     <selectKey resultClass="long" keyProperty="id">  

             SELECT LAST_INSERT_ID() AS ID  

        </selectKey>  

      </insert>

       将selectKey放在insert以后,通过

    LAST_INSERT_ID() 得获刚插入的动自增加的id的值。

文章结束给大家分享下程序员的一些笑话语录: 程序语言综述
CLIPPER 程序员不去真的猎捕大象,他们只是购买大象部分的库然后花几年的时间试图综合它们。
DBASE 程序员只在夜间猎捕大象,因为那时没人会注意到他们还在使用石弓。
FOXPRO 程序员开始使用更新更好的步枪,这使他们花掉比实际狩猎更多的时间学习新的射击技术。
C 程序员拒绝直接购买步枪,宁可带着钢管和一个移动式机器车间到非洲,意欲从零开始造一枝完美的步枪。
PARADOX 程序员去非洲时带着好莱坞关于猎捕大象的电影剧本,他们认为照剧本行事就会逮到一头大象。
ACCESS 程序员在没有任何猎象经验的经验下就出发了,他们穿着华丽的猎装、带着全部装备,用漂亮的望远镜找到了大象,然后发觉忘了带扳机。
RBASE 程序员比大象还要稀少,事实上,如果一头大象看到了一个RBASE程序员,对他是个幸运日。
VISUAL ACCESS 程序员装上子弹、举起步枪、瞄准大象,这使大象感到可笑,究竟谁逃跑。他们无法抓住大象,因为由于他们对多重控制的偏爱,他们的吉普车有太多的方向盘因而无法驾驶。
ADA、APL和FORTRAN 程序员与圣诞老人和仙女一样是虚构的。
COBOL 程序员对和自己一样濒临灭绝的大象寄予了深切的同情。

posted @ 2013-04-24 21:30  坚固66  阅读(567)  评论(0编辑  收藏  举报