首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

函数周期表丨筛选丨表丨VALUES

VALUES函数

VALUES函数,隶属于“筛选”类函数。当参数为列时,返回结果会去除重复值,保留空项;当参数为表时,结果不会进行去重复操作。

用途:适用于度量值计算。

语法

参数

VALUES函数的参数可以是列,也可以是表,但不能是表达式。

返回结果

去除重复值的列或者返回一个完整的表。当表为单列单行时,可以作为值使用。

例子

模拟数据:

这是白茶随机模拟的数据,红色框为重复数据,蓝色框为维度不存在的数据。坦白说,其实单个的VALUES函数没什么好说的,甚至不用枚举太多的例子,小伙伴们都是了解的,因为使用度非常高。

白茶会将VALUES函数、DISTINCT函数、ALL函数做一个比较,让大家明白三者的区别。

例子1:表函数模式

代码1:

代码2:

代码3:

结果:

1、表函数模式下,DISTINCT会对表进行去重操作;而VALUES和ALL函数相当于复制操作,并不会对源文件进行去重。

2、DISTINCT参数可以是表达式,而VALUES和ALL的参数不能是表达式。

例子2:参数列模式

代码1:

代码2:

代码3:

1、三个函数的参数如果都是列的话,在表函数模式下,都会进行去重复操作。

2、ALL函数的列参数可以有多个,类似于笛卡尔积的效果;而DISTINCT和VALUES函数列参数只能有一个。

例子3:度量值情况

代码1:

代码2:

代码3:

代码4:

结果:

在例子和维度上下文中,DISTINCT函数排除掉因扩展表原因导致的空值项目,将其排除在计算范围之内;进行的是去除重复,排除空值计算。

无论在例子上下文还是维度上下文中,VALUES函数的计算都包含空值项目。

ALL函数在例子上下文中的计算,没有屏蔽掉例子的筛选效果,其计算结果包含空值项目;而在维度上下文中,清除了维度表的筛选效果,计算结果包含空值项目,每个返回值均为总计行数37。

以上,就是关于VALUES、DISTINCT、ALL三个函数之间的主要区别了。可能在一些场合,三者返回的结果是一致的,就给我们造成了三者效果差不多的错觉,实际上三者之间的差距还是蛮大的。

小伙伴们GET了么?

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

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

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

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20201212A0376300?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券