• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
一个具有上进心的码农
因为一篇文章中有很多是从很多篇文章中摘取的,请恕我没有一一说明摘取出处,如果没有说明,则该文章默认是摘取,如有侵犯您的权益,请与我联系,将会马上删除。
博客园    首页    新随笔    联系   管理    订阅  订阅

SQL锁

有一个程序在轮巡这个表每次取出select top 1 * from tbl where status=0 的记录,然后将这条记录的status置为1,问题是如果是多线程的情况下
,就可能
出现一个线程已经把这条记录取出来了,在它把这条记录置为1之前又有另外的线程把这条记录取出来,出现取出多条一样的数据记录了。请问一下各
位怎么解
决这个问题?
select top 1 * from tbl  with(RowLock,xLOCK,readpast) where status=0
RowLock  表示将选择的那行锁住
xLOCK    表示不让其他用户使用锁住的这一行
readpast 表示其他用户跳过锁住的行读取下面没有锁住的行
事务修改
begin tran
update lock_readpast set c3 = 'b' where c3 = 'b'
可以插入
但要使用noclock, readpast 来读取,
不能修改
事务新增
begin tran
insert into lock_readpast( c1,c2,c3 ) values(5,5,'e' )
可以插入
但要使用noclock, readpast 来读取,
不能修改
posted @ 2011-07-25 15:28  不若相忘于江湖  阅读(299)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3