sql查找一个范围的值_销售需求丨查找问题
BOSS:?!!不是這個,我是說那個白茶啊!
白茶:......(懵)咋滴了,BOSS?
BOSS:哎,今年行情不行啊,能不能搞一個表,就是我選擇一個顏色,就能知道這個顏色售賣的所有商品?
白茶:......(咳,咳)BOSS,這個有點難啊!
——(支付寶到賬####元!)——
白茶:好嘞,馬上辦!
上面的都是白茶和大家開的小玩笑,但是實際上這種需求,是很普遍的一種情況。起初這個問題來源于群里小伙伴的提問,就是當我選擇A、B的時候,能不能出現同時包含A、B、AB的項目?白茶一尋思,可以做到。
最后要達到上圖的這種效果,該如何實現呢?
開始本期的問題—《銷售需求之查找問題》。
案例文件:
這是白茶隨機模擬的一份數據,一個維度表,一個銷售表。
那么當我們選擇維度中的數據,顯示出銷售表中對應顏色的銷售,這個問題屬于什么問題?很明顯,這個屬于查找問題,查找維度表中的顏色在事實表中的對應項目。
白茶翻閱了一下DAX中關于查找功能的函數,有兩個函數。
FIND函數與SEARCH函數
二者在語法上是一樣的:
DAX= FIND 或 SEARCH(查找內容,被查找,[開始位置],[找不到返回值])二者的語法結構是一致的,但是有所區別:
FIND函數區分大小寫,不支持通配符;
SEARCH函數不區分大小寫,支持通配符。
編寫如下代碼:
銷售顏色: = VAR SLL =VALUES ( '維度'[維度] ) VAR SQL =MAX ( '事實表'[顏色] ) RETURNIF ( SEARCH ( SLL, SQL,, 0 ) > 0, SQL, BLANK () )從結果中我們不難看出,當切片器無選擇時,以及多選時,其結果呈現的很明顯是有問題的。
做到這里的時候,白茶思考了很久,沒明白當選項為多選時,如何通過比較多個值進行結果的呈現。
感謝@冬哥。
冬哥提點了我一句,無法將多個值與查找范圍進行比較,那么可以把思路反過來啊,通過反計數的方式呈現。
編寫如下代碼:
銷售顏色 = VAR SLL =VALUES ( '維度'[維度] ) VAR SQL =MAX ( '事實表'[顏色] ) RETURNIF (COUNTROWS ( FILTER ( SLL, SEARCH ( [維度], SQL,, 0 ) > 0 ) ) > 0,SQL,BLANK ())當然,也可以使用FIND寫法:
FIND寫法 = VAR SLL =VALUES ( '維度'[維度] ) VAR SQL =MAX ( '事實表'[顏色] ) RETURNIF (COUNTROWS ( FILTER ( SLL, FIND ( [維度], SQL,, 0 ) > 0 ) ) > 0,SQL,BLANK ())其結果如下:
可以看得出來這次的結果沒有任何問題,這種情況下SEARCH和FIND的用途是一致的。
代碼含義:通過VALUES函數,去除重復值,來提取多個值,形成一個虛擬表;
SQL這里的作用單純的是為了將[顏色列]進行聚合,否則無法在查詢函數中使用;
通過IF語句進行判斷,符合條件顯示,否則顯示為空,內部利用FILTER函數進行上下文傳遞,將原本沒有聯系的維度和事實表中的顏色查詢鏈接在一起。
至于其他的項目,可以通過IF進行判斷決定是否顯示,這里就不贅述了,最終形成下面的動圖:
樣例鏈接:http://t.cn/A62FPa3i
小伙伴們?GET了么?
白茶會不定期的分享一些函數卡片
(文件在知識星球[PowerBI丨需求圈])
這里是白茶,一個PowerBI的初學者。
總結
以上是生活随笔為你收集整理的sql查找一个范围的值_销售需求丨查找问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hadoop没有datanode_Had
- 下一篇: linux下怎样看设备的中断号,Linu