国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

多線程下不重復(fù)讀取SQL Server的數(shù)據(jù)

2024-08-31 00:53:38
字體:
供稿:網(wǎng)友

在進(jìn)行一些如發(fā)送短信、郵件的業(yè)務(wù)時,我們經(jīng)常會使用一個表來存儲待發(fā)送的數(shù)據(jù),由后臺多個線程不斷的從表中讀取待發(fā)送的數(shù)據(jù)進(jìn)行發(fā)送,發(fā)送完成后再將數(shù)據(jù)轉(zhuǎn)移到歷史表中,這樣保證待發(fā)送表的數(shù)據(jù)一般情況下不會太多。如待發(fā)送表結(jié)構(gòu)為:

Create Table SMS(ID int not null identity(1,1),Content varchar(1024),Status int not null,CreateTime datetime);

Status 取值:0未讀取 1已讀取

這樣設(shè)計(jì)的好處是,不會因?yàn)楹蠖擞袝r發(fā)送過慢導(dǎo)致前端接收發(fā)送消息的請求出現(xiàn)問題,如發(fā)送短信的業(yè)務(wù),有時由于運(yùn)營商的網(wǎng)關(guān)原因發(fā)送太慢,這樣前端可以先將用戶的發(fā)送請求全部放在待發(fā)送表中,由后端進(jìn)行慢慢發(fā)送。

 

在后端發(fā)送進(jìn)程一般使用

Select top 100 * From SMS Where Status=0;這樣的SQL取出未被讀取的數(shù)據(jù)。

為了提高后端發(fā)送能力,需要部署多個進(jìn)程同時從待發(fā)送表中取出數(shù)據(jù)進(jìn)行發(fā)送,這樣有時就會造成同一個記錄被多個進(jìn)程同時取出來,并發(fā)送的情況。

 

今天查了一下SQL Server 的MSDN,發(fā)現(xiàn)可以通過先更新同時通過deleted表(就像是在觸發(fā)器中使用一樣)取出的方式,來保證每條記錄只會被讀取一次。

declare @Rowid table(rowid int);
BEGIN
 set rowcount 100; --一次讀取的行數(shù)
 --先將要讀取的記錄狀態(tài)更新
 update Sms set [status]= 1  output deleted.ID into @Rowid Where [status] = 0;
 --讀取剛更新狀態(tài)的記錄
 select  * from Sms where ID in (select Rowid from @Rowid);
END

http://www.cnblogs.com/qijun/archive/2010/07/16/sqlserver20100716.html


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 睢宁县| 宁陵县| 陕西省| 堆龙德庆县| 泰顺县| 理塘县| 通许县| 洞口县| 崇信县| 永仁县| 海阳市| 施秉县| 元朗区| 临洮县| 台湾省| 湟中县| 视频| 土默特右旗| 漳州市| 醴陵市| 土默特右旗| 黑龙江省| 女性| 吉安县| 鄂伦春自治旗| 阿拉尔市| 淄博市| 甘谷县| 永宁县| 阜城县| 孝感市| 阳江市| 龙山县| 阿城市| 仁布县| 仙游县| 新民市| 神池县| 定南县| 临高县| 九龙坡区|