zoukankan      html  css  js  c++  java
  • sqlserver锁应用

    +----+----------+---------+
     |  id |   item     |  status |
    +----+----------+---------+
     | 1  |    a     |    1    |
    +----+----------+---------+
     | 2  |    b     |    0    |
    +----+----------+---------+
     | 3  |    c     |    0    |
    +----+----------+---------+
      4  |    d     |    0    |
    +----+----------+---------+
    | 5  |    e     |    0    |
    +----+----------+---------+
     | 6  |    f     |    0    |
    +----+----------+---------+
     | 7  |    g     |    0    |
    +----+----------+---------+

    有一个程序在轮巡这个表每次取出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 表示其他用户跳过锁住的行读取下面没有锁住的行
  • 相关阅读:
    c++命名规范与代码风格
    subline的多行游标快捷键
    selenium中的action
    Fiddler 教程(转)
    java.util.NoSuchElementException解决办法
    http协议中的URI
    深入研究java.lang.Runtime类(转)
    深入研究java.lang.Process类(转)
    java调用autoit3脚本
    AutoIT转
  • 原文地址:https://www.cnblogs.com/cxd4321/p/1352124.html
Copyright © 2011-2022 走看看