网站首页 > 开源技术 正文
今天早上又是美好的一天,进公司刚落座。
隔壁部门的Tony哥直接杀了过来, “米高米高,我们组开发了一个PBI报告,但是现在有点小问题,帮我们看下怎么解决?”
- 是否有方法非常灵活把PBI报告里面的基础数据导出成平面文件分享给其他同事?
- 是否有方法非常方便的查询和验证PBI报告中的数据准确性?
Power BI desktop软件里面查看Measure预计太不友好了,核对和导出数据也很蛮烦,很是烦人。
我回复“今天你来的还真是时候,我今天正好要给一些同事分享POWER BI外挂级别的辅助工具,叫做DAX Studio,正好可以解决你这些头疼的问题。今天的培训分享你准时来参加吧~”
进入正题:
DAX语言在使用上,主要分成两大类,一类以DAX计算为核心,另一类以DAX查询为核心。DAX Studio,其主要就是用于DAX代码的编辑开发和查询。 这次主要介绍DAX查询功能。
DAX Studio下载地址:
请登录DAX Studio官网:https://daxstudio.org/进行下载。
DAX Studio的界面区域介绍:
借助DAX Studio,我们可以完成:
- DAX查询编辑开发
- DAX代码自动排版
- 数据模型元数据查看
- DAX函数查询
- DAX查询结果查看
- DAX查询结果导出
- DAX引擎运行监控
- DAX代码性能优化等
编写DAX查询仅仅是DAX Studio支持的基础功能,DAX Studio的深度使用,将在后续的进阶分享中说明。
下面我们将通过DAX Studio 的8个功能,让大家快速入门掌握DAX Studio的使用技巧。
1,连接Power BI数据集
成功安装DAX Studio后,打开一个你要查验数据的Power BI Desktop文件,点击【外部工具】(External tools) ->【DAX Studio】即可打开DAX Studio进入工作窗口;
2, 查询Power BI模型源表数据
DAX Studio有两种方法支持用户查询模型源表数据,
Solution 1,
DAX查询需要用到EVALUATE函数,来查询需要访问的源表。
- EVALUATE <table>
例如,查询区域表Area表的数据: EVALUATE Area
有同学问,如果我要filter其中Province='上海'的信息,但是我对DAX语句不熟,写不出来怎么办?
这是个好问题,这里我们就可以用到马上讲到的Solution 2,使用DAX Studio功能区的Query Builder功能灵活拖拽帮你实现。
Query Builder界面如下,主要由Query Builder
只需把想要查询数据表的字段拖放到Columns/Measures区域,需要filter信息的字段拖放到Filters区域,设定好过滤条件,最后点击Run Query,即可在结果区找到要查询的信息。
又有一位同学询问,虽然得到了想查询的结果,但是我还想知道这段DAX查询代码。方便以后直接用这段DAX代码查询数据/或者分享给其他同事直接使用?
这又是一个好问题,其实这个问题比较普遍,大家想保存一些自己常用的查询代码,方便以后快速查询数据。可以继续使用Query Builder来完成,上面说了大家再执行完毕Run Query后,会得到查询结果。 然后再点击Edit Query 即可在查询编辑区得到对应的DAX代码。
3, Functions 查询DAX函数用法及样例
Functions是DAX Studio查询DAX函数的字典,通过Functions功能,可以非常便捷的获得任何DAX函数的信息。
例如,查询DAX函数Calculate用法,在 DAX Studio工作窗口的底部,单击 Functions选项卡。
在搜索框搜索,找到Calculate并双击,查询编辑区会自动出现Calculate函数公式。
如果觉得还是看不懂怎么公式怎么使用,可以把鼠标悬停到编辑区的Calculate公式上面,然后即可得到公式说明和一个链接,点击链接可跳转到单独的页面,可查看当前函数的定义,表达式,以及代码样例。
其中代码样例非常有助于理解函数公式的用法。
4, DMV查询
DMV(动态管理视图)是从模型数据源查询信息的一种方法,通过查询DMV中的各个DAX Studio预设的视图,可以获得有关数据结构的信息。
例如,可以非常方便的解决工作中的一个经典场景。
当我们完成一个Power BI项目后,需要整理Power BI模型里面的度量值信息列表,需要包含度量值名称,代码实现等。在没有使用DAX Studio前,需要查询数据模型中所用到的全部度量值,并一一记录,是一个耗时并繁琐的过程。
现在只需要在DAX Studio工作窗口的底部,单击 DMV选项卡。向下滚动DMV列表,在搜索框搜索,找到TMSCHEMA_MEASURES并双击,查询窗口区会自动出现查询语句,将光标放在此行,然后点击【执行】(Run),这样在输出窗口就可以看到查询结果。
现在有的同学又有新的问题了,“现在我们有了POWER BI模型的全部度量值信息后,如果把查询结果导出呢?”下面就可以进入查询结果导出部分。
5,查询结果导出
在DAX Studio中查询的结果不仅可以在结果区查看,同时还可以导出为EXCEL或CSV等其他平面文件。
例如,导出我们在第4点中查询的模型中的所有度量值,在查询窗口输入查询语句后,将默认输出方式改为EXCEL,再点击【执行】(Run),然后选择本机文件夹路径保存即可。
同学的新问题又来了,“是否可以批量的导出POWER BI模型中的维度表,事实表或者度量值表?这样可以方便分享相关数据给其他同事”.
DAX Studio的批量导出功能正好解决这个问题。
6,批量导出Power BI模型表数据
在DAX Studio中我们可以使用批量导出模型表数据为.CSV文件或导出到SQL中。
例如,我们以导出.CSV文件为例,点击【Advanced】->【Export Data】,在弹出的Export Data Wizard窗口,点击【CSV Files】;
选择导出路径,然后选择分隔符类型,最后点击下一步;
选择要导出的表,在表前面?。然后点击【导出】(Export)。
等待导出任务结束后,就可以在前面选择的导出路径找到所有导出列表的文件。
7,查看Power BI模型信息
在DAX Studio中我们还可以查看Power BI整个模型的信息,方便对当前模型的设计进行详细的分析。
点击【Advanced】->【View Metrics】,我们在结果区看到当前模型的表(Table)、列(Columns)、关系(Ralationships)、划分(Partitons)和汇总(Summary)的详细信息。
8,性能测试
首先在查询窗口输入查询语句,然后点击功能区【Server Timings】->【Run】->结果区【Server Timings】,
就可以得到运行结果了。
这个功能非常方便我们对边DAX代码的运行效率。
例如,以下是计算判定销售>7000000的省份销售业绩评价为"优秀"小于等于的省份销售业绩评价为"一般"的两种不同代码的运行结果对比;
通过If函数进行判断:
通过Switch函数进行判断:
针对当前查询,通过对比结果可知,使用If时所用时间比Switch短,所以使用If的DAX查询的性能更好。
最后总结,通过了解和学习本文介绍的8个知识点就可以满足大家大部分的日常工作需要。
DAX Studio还有很多使用强大的功能,大家可以在今后的使用中慢慢体会和探索。
- 上一篇: Android数据库相关整理
- 下一篇: 一套前后台全部开源的H5商城送给大家
猜你喜欢
- 2024-12-14 ES的searchAfter使用详解
- 2024-12-14 Spring Boot Data Elasticsearch 通用工具类
- 2024-12-14 SpringBoot+Vue+ES 实现仿百度全文搜索
- 2024-12-14 Spring Data JPA——多表设计、一对多、多对多、多表查询
- 2024-12-14 一文读懂SpringBoot整合Elasticsearch
- 2024-12-14 ElasticSearchRepository和ElasticSearchTemplate的使用
- 2024-12-14 Elasticsearch 在地理信息空间索引的探索和演进
- 2024-12-14 Java微服务-一套前后台全部开源的H5商城送给大家(全部开源)
- 2024-12-14 android使用greendao来保存数据
- 2024-12-14 纯干货,Spring-data-jpa详解,全方位介绍
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)