摘要:
有一个程序在轮巡这个表每次取出select top 1 * from tbl where status=0 的记录,然后将这条记录的status置为1,问题是如果是多线程的情况下,就可能出现一个线程已经把这条记录取出来了,在它把这条记录置为1之前又有另外的线程把这条记录取出来,出现取出多条一样的数据记录了。请问一下各位怎么解决这个问题?select top 1 * from tbl with(RowLock,xLOCK,readpast) where status=0RowLock 表示将选择的那行锁住xLOCK 表示不让其他用户使用锁住的这一行readpast 表示其他用户跳过锁住的行读取下 阅读全文
摘要:
原来四舍五入也有个国际惯例,叫奇进偶舍,意思是当舍入位前面一位是奇数时,就进,为偶数时,就舍,这也是体现公平性的原理。可是国际惯例往往在国内很多企业行不通,为了应付他们的要求,采用Math.Round(price,2,MidpointRounding.AwayFromZero)就可以了。SELECT Sum([TradeNum]), Sum([Payment]), [TradeTime],(select sum([Payment]) from [Order] as o where [TradeStatus] =2 and o.ID=[Order].ID) as NoPaymentFROM [O 阅读全文