亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

多線程下不重復讀取SQL Server的數據

添加時間:2014-2-28 16:46:17  添加: 思海網絡 

  在進行一些如發送短信、郵件的業務時,我們經常會使用一個表來存儲待發送的數據,由后臺多個線程不斷的從表中讀取待發送的數據進行發送,發送完成后再將數據轉移到歷史表中,這樣保證待發送表的數據一般情況下不會太多。如待發送表結構為:

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

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

  這樣設計的好處是,不會因為后端有時發送過慢導致前端接收發送消息的請求出現問題,如發送短信的業務,有時由于運營商的網關原因發送太慢,這樣前端可以先將用戶的發送請求全部放在待發送表中,由后端進行慢慢發送。

  在后端發送進程一般使用

  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

關鍵字:SQL Server、記錄、多線程

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站