日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

sql查找一个范围的值_销售需求丨查找问题

發布時間:2025/3/12 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql查找一个范围的值_销售需求丨查找问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
BOSS:茶,那個,什么茶來著?(遞過一杯茶...)
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查找一个范围的值_销售需求丨查找问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。