溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何通過SQL Server的位運算功能巧妙解決多選查詢方法

發(fā)布時間:2021-11-29 11:38:47 來源:億速云 閱讀:244 作者:柒染 欄目:數(shù)據(jù)庫

本篇文章為大家展示了如何通過SQL Server的位運算功能巧妙解決多選查詢方法,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

無論使用int還是varchar,對于Status的多選查詢都是不易應對的。舉例,常規(guī)思維下對CustomerStatus的Enum設(shè)置如下:復制代碼 代碼如下: [Serializable] public enum CustomerStatus { New = 0, Active = 1, Overdue = 2, Suspended = 3, Closing = 4, Closed = 5 }

在數(shù)據(jù)庫中以int形式存儲了Status值。 如果我在頁面中想一次搜索狀態(tài)為Active,Overdue和Suspended狀態(tài)的Customer,該怎么辦?程序是不是得把這三個狀態(tài)值 拼成字符串傳遞給SQL去處理?雖然能實現(xiàn),但是相當?shù)托А?現(xiàn)在給出一個標準解決方案: (1). 所有可能被用作搜索條件的枚舉都應按如下位運算方式定義。復制代碼 代碼如下: public enum CustomerStatus { New = 1, Active = 1<<1, Overdue = 1<<2, Suspended = 1<<3, Closing = 1<<4, Closed = 1<<5 }

(2). 在數(shù)據(jù)庫設(shè)計時,Status的字段必須為int型。 這樣當我們做多選查詢時@Status的Value= CustomerStatus.Active | CustomerStatus. Overdue| CustomerStatus. Suspended (3). 查詢語句如下:復制代碼 代碼如下: Select * From Customer Where [Status] & @Status = [Status]

如果@Status可為null時,復制代碼 代碼如下: Select * From Customer Where ( @Status is null Or [Status] & @Status = [Status])

用這樣一條簡單的語句,就可以獲取到所有符合@Status要求的數(shù)據(jù)行。

上述內(nèi)容就是如何通過SQL Server的位運算功能巧妙解決多選查詢方法,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI