我只想說以下是很基礎的sql知識,但是很容易犯錯。所以睜大我們的眼睛,屏住我們的呼吸,小心的檢查吧!
?
案例1
if not exists (select OrderID from CorpEmailSendQueue where orderid=600643425)
begin
??? exec sp3_CorpEmailSendQueue_i @ID=NULL,@OrderID=600643425, @OrderType='F', @EmailType='-2',@ResendTime=0,@SendTime=NULL,@CurrentStatus='u',@GenerateTime=NULL
end
上面這個是最終正確的寫法,看上去很簡單吧,但是有些地方是容易犯錯的。
?
錯誤1
if not exists select count(1) from CorpEmailSendQueue where orderid=600643425
begin
??? exec sp3_CorpEmailSendQueue_i @ID=NULL,@OrderID=600643425, @OrderType='F', @EmailType='-2',@ResendTime=0,@SendTime=NULL,@CurrentStatus='u',@GenerateTime=NULL
end
看上去沒問題吧,但是就會報錯,錯誤提示如下:
Msg 156, Level 15, State 1, Line 1
Incorrect syntax near the keyword 'select'. 需要使用園括號把select count(1) from CorpEmailSendQueue where orderid=600643425包起來。
?
錯誤2
if not exists (select count(1) from CorpEmailSendQueue where orderid=600643425)
begin
??? exec sp3_CorpEmailSendQueue_i @ID=NULL,@OrderID=600643425, @OrderType='F', @EmailType='-2',@ResendTime=0,@SendTime=NULL,@CurrentStatus='u',@GenerateTime=NULL
end
看上去也沒有問題吧,但是把OrderID換成count(1)之后exists就不起作用了,select count(1) from CorpEmailSendQueue where orderid=600643425 在任何情況下都是有值的,我的意思是即使是0也是exists的,所以任何情況下都不會執行下面的存儲過程。
案例2
select datediff(hh,'2013-11-21 16:50','2013-11-21 17:35') 這個得到的結果居然是1,我再想sql server是不是抽風了,這兩個時間之間相差45分鐘,還不到1小時,無奈只能使用select datediff(mi,'2013-11-21 16:50','2013-11-21 17:35')得到的結果是45。
還有個小知識,如果要得到當前時間可以用getdate(),如果是utc時間呢,就是當前時間減8,可以使用getutcdate()。
?
?
?
?
?
?
?
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
