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

BOSS:茶,那个,什么茶来着?(递过一杯茶...)
BOSS:?!!不是这个,我是说那个白茶啊!
白茶:......(懵)咋滴了,BOSS?
BOSS:哎,今年行情不行啊,能不能搞一个表,就是我选择一个颜色,就能知道这个颜色售卖的所有商品?
白茶:......(咳,咳)BOSS,这个有点难啊!
——(支付宝到账####元!)——
白茶:好嘞,马上办!

8499932debf4c5bdb4431f889565ed4a.png

上面的都是白茶和大家开的小玩笑,但是实际上这种需求,是很普遍的一种情况。起初这个问题来源于群里小伙伴的提问,就是当我选择A、B的时候,能不能出现同时包含A、B、AB的项目?白茶一寻思,可以做到。

c3ebc579fceec3b8d8ca35d47513787d.png

最后要达到上图的这种效果,该如何实现呢?

开始本期的问题—《销售需求之查找问题》。

f3116be68278a53ad2bdbf9f202ec5fe.gif

案例文件:

b51a5f8c2fcea5580434e6bd7117461c.png

19a76ed09edd1b801add91d5226e0a99.png

这是白茶随机模拟的一份数据,一个维度表,一个销售表。


那么当我们选择维度中的数据,显示出销售表中对应颜色的销售,这个问题属于什么问题?很明显,这个属于查找问题,查找维度表中的颜色在事实表中的对应项目。

白茶翻阅了一下DAX中关于查找功能的函数,有两个函数。

FIND函数与SEARCH函数

二者在语法上是一样的:

DAX=
FIND 或 SEARCH(查找内容,被查找,[开始位置],[找不到返回值])

二者的语法结构是一致的,但是有所区别:

FIND函数区分大小写,不支持通配符;

SEARCH函数不区分大小写,支持通配符。


编写如下代码:

销售颜色: =
VAR SLL =VALUES ( '维度'[维度] )
VAR SQL =MAX ( '事实表'[颜色] )
RETURNIF ( SEARCH ( SLL, SQL,, 0 ) > 0, SQL, BLANK () )

90051472775921bb01a326b9341611c1.png

从结果中我们不难看出,当切片器无选择时,以及多选时,其结果呈现的很明显是有问题的。

做到这里的时候,白茶思考了很久,没明白当选项为多选时,如何通过比较多个值进行结果的呈现。

感谢@冬哥。

冬哥提点了我一句,无法将多个值与查找范围进行比较,那么可以把思路反过来啊,通过反计数的方式呈现。

编写如下代码:

销售颜色 =
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 ())

其结果如下:

213ecf7b6f20ad34692dedc2c56c81bd.png

可以看得出来这次的结果没有任何问题,这种情况下SEARCH和FIND的用途是一致的。

代码含义:
通过VALUES函数,去除重复值,来提取多个值,形成一个虚拟表;
SQL这里的作用单纯的是为了将[颜色列]进行聚合,否则无法在查询函数中使用;
通过IF语句进行判断,符合条件显示,否则显示为空,内部利用FILTER函数进行上下文传递,将原本没有联系的维度和事实表中的颜色查询链接在一起。

至于其他的项目,可以通过IF进行判断决定是否显示,这里就不赘述了,最终形成下面的动图:

c3ebc579fceec3b8d8ca35d47513787d.png

8499932debf4c5bdb4431f889565ed4a.png

样例链接:http://t.cn/A62FPa3i

小伙伴们❤GET了么?

白茶会不定期的分享一些函数卡片

(文件在知识星球[PowerBI丨需求圈])

a97d8e9f4b80cb0ba3d323b383996497.png

这里是白茶,一个PowerBI的初学者。

9d68f209d1cba1f7d7544bf7c5dfd660.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/561265.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎样用c语言算平均成绩,用C语言编程平均分数

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼当个反面典型,让大家见识下丑陋无比的程序好了,主要是想练练打字,HOHO。应该用二维数组且全部函数化的,rand的%后面或是101或是100,可能和编译器有关,TC2下应写…

pandas输出到excel_学Python还不会处理Excel数据?带你用pandas玩转各种数据处理

开场白以前学习 Python 的 pandas 包时,经常到一些 excel 的论坛寻找实战机会。接下来我会陆续把相关案例分享出来,还会把其中的技术要点做详细的讲解。本文要点:使用 xlwings ,如同 vba 一样操作 excel使用 pandas 快速做透视表注…

cadence设计运算放大器_21.比较器的原理与特性,它与运算放大器的本质区别总结归纳...

1.电压比较器的工作原理电压比较器,顾名思义,就是两个输入端的其中一个作为基准,另外一个与基准作比较,输出只存在高电平和低电平两种状态。通过电压比较器,可以将模拟信号转变为数字信号。输入引脚的电位 > -输入引…

在c语言程序中无论是整数还是实数,C语言基础题及参考答案

C第一单元程序设计和C语言一、选择题1.C语言的基本构成单位是: A 。A. 函数B. 函数和过程C. 超文本过程D. 子程序2.一个C语言程序总是从 B 开始执行。A. 主过程B. 主函数C. 子程序D.主程序3.C语言的程序一行写不下时&a…

插入排序最优_排序专题插入排序

今天开始,我计划用几篇专题来集中练习下有关排序的算法,排序算法是算法中最基础的算法了,所以这部分我们是要尽可能的全都掌握了。排序算法最常见的有如下几种:插入排序(Insertion Sort)选择排序(Selection Sort)希尔排序(Shell S…

c语言设计指导实训,C语言程序设计实训指导

与《c语言程序设计(第2版)》配套,给出所有习题及参考答案。按知识点,精选12个典型实训,给出实训目的与要求、实训内容及实训参考程序。附有自测(考试)样卷及参考答案,供读者自测。提供Turbo C 2.0上机环境介绍及常见的Turbo C 2.0…

python程序代码_python基础二

Python基础-注释的引入注释的分类:<1>单行注释:以#开头&#xff0c;#右边的所有文字当作说明&#xff0c;而不是真正要执行的程序&#xff0c;起辅助说明作用多行注释用三个单引号 ‘’’ 或者三个双引号 “”" 将注释括起来&#xff0c;例如:1、单引号&#xff08;…

电气自动化c语言实践操作论文,项目实践论文,关于独立学院电气工程其自动化专业基于CDIO的实践模式相关参考文献资料-免费论文范文...

导读:本文关于项目实践论文范文,可以做为相关论文参考文献,与写作提纲思路参考。(广州大学松田学院 广东广州 511370)摘 要&#xff1a;独立学院作为培养应用型人才的新生力量,要与地方经济社会发展相衔接,培养满足地方经济社会发展需要的、高素质的应用型人才.如何培养符合广东…

c语言 系统 dome,订餐系统(Dome)

import java.util.Scanner;public class OrderingMsg {public static void main(String[] args) throws Exception {Scanner scanner new Scanner(System.in);String[] names new String[6]; // 订餐人姓名String[] dishMsgs new String[6];// 选择菜品int[] numbers new i…

linux里用c实现cat_【案例】用T云做了什么能让企业在工业自动化控制系统行业里实现逆向增长?...

从制造至“智”造&#xff0c;工业正在逐步向自动化、智能化方向深入发展。行业背景&#xff1a;受疫情影响&#xff0c;2020年&#xff0c;上半年雪虐风饕&#xff0c;自动化市场需求下滑&#xff0c;随着后期政策红利推出&#xff0c;市场回暖&#xff0c;上半年的自动化需求…

qt android程序联网死机,qt android开发出现致命错误

启动远端进程。D/dalvikvm( 1387): Late-enabling CheckJNID/dalvikvm( 1387): GC_CONCURRENT freed 256K, 10% free 9307K/10272K, paused 2ms2ms, total 21msD/dalvikvm( 1387): WAIT_FOR_CONCURRENT_GC blocked 11msW/Bundle ( 1387): Key android.app.lib_name expected S…

微软符号服务器 2020年_微软介绍了2020年后它将如何淘汰Edge中的Flash支持

Microsoft Edge微软(通过Bleeping Computer)提供了更多关于它将如何放弃对Flash in Edge的支持以符合Adobe的计划的细节&#xff0c;包括一些值得注意的例外。正如所料&#xff0c;默认情况下&#xff0c;Edge将从2020年12月起禁用闪存。2020年6月之前发布的Flash版本将被完全屏…

android fragment 抽屉,android – 更改Fragment中的导航抽屉项目

我有一个MainActivity启动导航抽屉.也有一些碎片.我需要从片段内部更改导航抽屉列表的标题.我尝试了这个内部片段&#xff1a;navMenuTitles getActivity().getResources().getStringArray(R.array.nav_drawer_items);navMenuTitles[1] username;但到目前为止没有运气.这是我…

深入jvm虚拟机第三版源码_深入JVM虚拟机,阿里架构师直言,这份文档真的是JVM最深解读...

作为一名优秀的 Java 开发程序员&#xff0c;以及想那些想要学习 Java 更深层一点的知识的同学&#xff0c;对 JVM 的熟悉与熟练使用是必不可缺的核心技能了&#xff0c;也是每个 Java 程序员应该要做到的。深入学习 JVM 可以有助于我们掌握 Java 应用程序是如何运作的&#xf…

android 信鸽 自动重启,Android简单集成信鸽推送

添加项目的buid.gradlendk {//选择要添加的对应cpu类型的.so库abiFilters armeabi, armeabi-v7a, arm64-v8a// 还可以添加 x86, x86_64, mips, mips64}manifestPlaceholders [XG_ACCESS_ID:"2100332371",XG_ACCESS_KEY : "ABRD93KT147K",]依赖//采集安装列…

python颜色表_Python+matplotlib绘制不同大小和颜色散点图实例

具有不同标记颜色和大小的散点图演示。 演示结果&#xff1a; 实现代码&#xff1a; import numpy as np import matplotlib.pyplot as plt import matplotlib.cbook as cbook # Load a numpy record array from yahoo csv data with fields date, open, close, # volume, adj_…

android的充电线,充电线和数据线的区别

买安卓手机&#xff0c;一般配件都会有数据线&#xff0c;数据线可以当充电线使用&#xff0c;这我们都知道。充电线和数据线又有什么区别呢?下面是小编给大家整理的&#xff0c;供大家参阅!一般我们的数据线和充电线都是用USB接口的一般都会有四根线&#xff0c;充电线用到时…

python画方波_今天学会傅里叶画画,明天就是初音未来 - 如何用Python和Blender画任意图形...

前言&#xff1a; 最近在【编程德鲁伊】的【傅里叶级数可视化】章节中&#xff0c;练习了傅里叶级数基础原理的可视化&#xff0c;演示了周期方波曲线&#xff0c;可以分解为一系列正弦波曲线&#xff1a; 这次拿学到的知识做个实验&#xff0c;试试喜闻乐见的【用傅里叶级数画…

mtk android 5.1 logo,Android ROM DIY之MTK平台手机通用移植

在之前的文章中&#xff0c;我们讨论过ROM刷机原理&#xff0c;修改ROM包以及如何让ROM包获取root权限。那么接下来&#xff0c;我们谈谈MTK平台手机ROM移植的话题。如果你是ROM小白&#xff0c;那么建议可以先看看之前的文章。ROM刷机原理修改ROM包ROM包获取root权限好了请注意…

python变量类型是动态的_python内存动态分配过程详解

一、前言 大多数编译型语言&#xff0c;变量在使用前必须先声明&#xff0c;其中C语言更加苛刻&#xff1a;变量声明必须位于代码块最开始&#xff0c;且在任何其他语句之前。其他语言&#xff0c;想C和java,允许“随时随地”声明变量&#xff0c;比如&#xff0c;变量声明可以…