首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2EE开发 >

在spring+ibatis中应用LAST_INSERT_ID()是否安全

2013-08-09 
在spring+ibatis中使用LAST_INSERT_ID()是否安全?项目数据库要从oracle转为mysql。为了获取插入数据的id,or

在spring+ibatis中使用LAST_INSERT_ID()是否安全?
项目数据库要从oracle转为mysql。

为了获取插入数据的id,oracle中有sequence ,对mysql不是很熟悉,google得知一般都用自增字段去实现。

ibatis中这样写的:


<insert id="insertIssue" parameterClass="Issue">
         insert into issue (name,issue_user,status)
          values (#name#,#issueUser#,#status#)
    <selectKey resultClass="int" keyProperty="id"> 
            SELECT LAST_INSERT_ID() AS ID  
        </selectKey> 
</insert>


关于LAST_INSERT_ID() 看到文档提到是:

“产生的ID 每次连接后保存在服务器中。这意味着函数向一个给定客户端返回的值是该客户端产生对影响AUTO_INCREMENT列的最新语句第一个 AUTO_INCREMENT值的。这个值不能被其它客户端影响,即使它们产生它们自己的 AUTO_INCREMENT值。这个行为保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁或处理。”

请问大家这种方法在高并发状态下是否安全?

或者有没有其他好的方式模拟sequence ?

非常感谢! iBATIS MySQL Spring
[解决办法]
mysql不是有自增长字段吗?
字段属性:Auto Incr什么的。
设置主键自增长,然后IBATIS里我是这样写的:
<selectKey resultClass="Long" keyProperty="seqid">
SELECT @@IDENTITY AS seqid
</selectKey>
[解决办法]
我理解你的意思了,你是想在高并发时,插入数据想返回当前所插入记录的ID,是吧?
这个应该不会的,LAST_INSERT_ID是基于单个数据库连接的,它会返回的ID是当前连
接最后一次insert操作的ID,并不是整个数据库最后一次insert操作。

热点排行