[SQL ] 多重條件下,重複值的問題

作者: ashin42 (Rock'n roll style)   2019-07-01 12:36:54
資料庫名稱: MS SQL SERVER 2017
資料庫版本: v17.9.1
內容/問題描述:
Hi 各位前輩早
我目前遇到了一個SQL的問題 , 我在資料表A定義了兩個參數的最大(C1和R1的Maximun)
與最小值(C1和R1的Minimum) , 資料表B則是實際的資料帶有參數實際值得資料 ,
我期望串出來的SQL有優先順序 , 滿足C1和R1的Maximun和Minimum的資料優先被找出 ,
如果沒有再找出滿足C1的Maximun和Minimum的資料 , 如果沒有再找出滿足R1的Maximun和
Minimum的資料
但如果SQL向下面這樣下會有重複的問題 , 會重複找到分別符合條件的資料 , 無法過濾
掉重複的
and (B.C1_Temp >= A.C1_Minimum and B.C1_Temp <= A.C1_Maximun and B.R1_Temp >=
A.R1_Minimum and B.R1_Temp <= A.R1_Maximun )
or (B.C1_Temp >= A.C1_Minimum and B.C1_Temp <= C1_Maximun)
or (B.R1_Temp >= A.R1_Minimum and B.R1_Temp <= R1_Maximun)
作者: ken218 (ken218)   2019-07-01 14:18:00
請問「優先」的定義是?重複的問題,如果單純從 B 抓資料,SELECT DISTINCT ...可以解決
作者: cutekid (可愛小孩子)   2019-07-01 14:29:00
要不要舉例一個sample input/output,比較好理解喔~
作者: konkonchou (卡卡貓)   2019-07-01 18:04:00
根據三個條件把三句SQL union起來給對應值1 2 3在整個()起來, 排序對應值就好了

Links booklink

Contact Us: admin [ a t ] ucptt.com