必胜高考网 > 计算机类 > 计算机等级 > 资讯 >

数据库:多线程下不重复读取SQLServer的数据

时间: 家辉2 资讯

  在后端发送进程一般使用

  Select top 100 * From SMS Where Status=0;这样的SQL取出未被读取的数据。

  为了提高后端发送能力,需要部署多个进程同时从待发送表中取出数据进行发送,这样有时就会造成同一个记录被多个进程同时取出来,并发送的情况。

  今天查了一下SQL Server 的MSDN,发现可以通过先更新同时通过deleted表(就像是在触发器中使用一样)取出的方式,来保证每条记录只会被读取一次。

  declare @Rowid table(rowid int);

  BEGIN

  set rowcount 100; --一次读取的行数

  --先将要读取的记录状态更新

  update Sms set [status]= 1  output deleted.ID into @Rowid Where [status] = 0;

  --读取刚更新状态的记录

  select  * from Sms where ID in (select Rowid from @Rowid);

  END

56076