eltable刷新整个表格方法_利用SSAS实现PBI报表增量刷新

b17e03b8e8923cb4e72a421ff2ee81d9.png

欢迎访问我的博客网站阅读最新BI文章

对于经常处理大量数据且其Power BI报表不需要每次都刷新整个数据集的用户而言,增量刷新一直都是个问题,特别是对于那些没有条件使用Premium空间的用户以及在本地报表服务器发布报表的用户。一个稳定可靠的方法是利用SSAS表格模型的既有功能去突破Power BI本身的局限性,具体实现的方法,简而言之,就是让Power BI以实时连接的方式连接到SSAS表格模型数据库,因此刷新数据时不需要依赖Power BI本身,而依赖于数据处理功能更强大的SSAS--利用分区策略解决增量刷新。

本文将使用SSDT (Visual Studio 2017)作为演示, 如果你还没有安装可以点此到达下载页面。对于使用Visual Studio 2019的用户同样适用,如果你的SQL Server版本较低且使用SSDT(Visual Studio 2012), 本文亦提供了相应的代码。

案例介绍:

本案例需要完成一个可以动态展示近90天的销售数据的PBI报表,但总数据量多达几千万行,每次都对数据集进行全量刷新是不现实的,下文演示会说明如何做到每天只刷新最新一天的数据,实现增量刷新。

方案演示:

首先打开SSDT2017新建表格模型项目,刚开始你需要先连接到表格模型实例。注意,理论上同一个SQL Server实例的多维数据集实例与表格模型实例不能并存,如果你的SSAS是多维数据集,你可以查看此文章以了解如何将多维数据集实例转换为表格模型实例。(这样做的原因是Power BI连接表格模型在性能上要好得多)

另一个要注意的一点是,如下图所示,就是该表格模型项目的兼容级别。就我个人情况而言(也许对于多数用户也如此),1200是最好的选择。

84bc3402b3c648655fdb6430c4d9a0c1.png

然后在SSDT界面从SQL Server导入数据。本案例使用的数据集非常简单,只有一个日期字段和两个随机生成的字段--No_(可以看作是产品号)以及Qty(可以看作是销量),但数据量较大,每天会产生大约几十万行的新数据,部分数据如下所示:

1bcabd473094463351c2aa7df1c7b66c.png

然后我们在右侧Tabular Model Explorer找到我们导入的表,选择"Partitions(分区)"。在弹出的Partition Manager界面,你可以通过修改SQL语句将数据集分区,如下图点击"New"创建新的分区(可能很多PBI用户没用使用过SSDT,因此我特地在此说明),比如本案例将数据集按天分区,因此在原有SQL查询语句基础上增加了WHERE过滤条件。故而通过此方式,我们就可以把90天的数据按天分成90个分区,在每次刷新数据时,只需要刷新最新一天的分区就可以了,这样就实现了增量刷新的目的。

1abfef3a0f8f22a24e429f2fd0f34a44.png

然而,要实现真正动态的增量刷新,这种方式显然行不通。当新的一天到来时,你不可能还回到SSDT,手动删除最早的分区,手动创建最新的分区,再手动执行插入最新一天的数据。在BI的世界,手动这个词是令人反感的,我们必须找到方法让这一切都自动化。

幸运的是,我们可以在SSMS里将这一切操作以脚本方式运行。但首先我们需要发布我们的表格模型项目,这样我们才能在SSMS连接到表格模型实例后看到它:

cb5052e86b4ba7f54a7e7b7a9d51837d.png

右键点击表格(Query)选择分区,如下所示, 通过点击"Script Action to New Query Window",对应的操作脚本会在查询窗口中打开,对于分区的一切操作(新建,修改,处理,删除)都可以通过运行脚本完成。这样我们就可以通过定时运行脚本的方式,让数据集在最新的一天自动创建分区并插入新数据了。

423b0364ce002ac48a1244ac3a2bd34f.png

在设计脚本之前,还需要完成最后一个步骤:在数据库实例中创建链接数据库。这是因为脚本需要使用SQL执行(而非MDX或DAX),这样才可以调用SSAS脚本执行数据库操作,因此需要一个连接到表格模型数据库的数据库实例提供一个可以操控SSAS数据库的接口。

新建链接数据库,如下图,在Provider处选择SSAS的OLEDB接口,如果没有此选项,也许是因为在数据库安装时此组件没被安装,你可以自己去下载一个Provider for Analysis Services然后安装到数据库中。

91bcf3d73baae0b4827c75ca9efdbd49.png

完成上一步后,我们就可以在数据库查询窗口,使用SQL执行脚本。根据上文思路,此方案的完整代码如下,你可以把代码中<>中的值替换为你自己的值,在Query中换上你的SQL或更改其他必要的参数直接使用:

DECLARE 

现在我们可以在SSMS中设置作业让脚本定时执行了,比如本案例中会设置它每天运行一次,那么每天数据集都只会刷新最新一天的数据,而无需全部都刷新一遍了。

最后,打开Power BI Desktop, 连接到SSAS数据库。注意此处要选择"Connect live",如下图,这样才能把Power BI的数据抽取业务"外包"给SSAS,否则我们前面的一堆步骤就算白做了:

9a3b5cf5e6cc50316daa4970aa75adf2.png

我还附上了针对于较旧版本的SSAS的代码,因为新版本的脚本格式是JSON,而旧版本使用XML,有此需求你可以到我的博客网站查看完整代码。

End~


若喜欢本文请点赞支持下吧~只收藏不点赞貌似不太道义 ~_~

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

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

相关文章

我和Git的第一次

我第一次接触Git应该是在2010年&#xff0c;我那年买了第一块Linux开发板&#xff0c;是友善之臂的mini2440&#xff0c;就是这个开发板打开了我Linux的大门&#xff0c;价格是499&#xff0c;我两个月的生活费。如果说到了Linux&#xff0c;不说Git就有点说不过去了&#xff0…

创建线程的方式_创建线程有几种不同的方式?

方式可以用来创建线程1&#xff09;继承Thread类2&#xff09;实现Runnable接口3&#xff09;应用程序可以适用Executor框架来创建线程池实现了Runnable接口这种方式更受欢迎&#xff0c;因为这不需要继承Thread类。在应用设计中已经继承了别的对象的情况下&#xff0c;这需要多…

内存屏障,先看这篇文章

刚看到这个词的时候&#xff0c;我以为是白内障&#xff0c;然后查了很多资料&#xff0c;才理解内存屏障是干嘛的&#xff0c;我就不像很多其他文章说得那么多了&#xff0c;我希望我说得简单一些&#xff0c;让大家看了我的文章都知道这个是怎么回事。说到内存屏障&#xff0…

SpringMVC原理及非注解配置详解

如需转发请标明出处&#xff1a;http://www.cnblogs.com/gudu1/p/7222556.html 1. Spring介绍 Spring MVC是Spring提供的一个强大而灵活的web框架。借助于注解&#xff0c;Spring MVC提供了几乎是POJO的开发模式&#xff0c;使得控制器的开发和测试更加简单。 这些控制器一般不…

ftp 追加远程文件_远程办公彻底火了,高效办公,拒绝卡顿,远程利器你选对了么?...

远程办公的同时肯定会应用到公司的内部系统了&#xff0c;比如OA、ERP等系统&#xff0c;当然为了提高远程办公人员的工作效率&#xff0c;实现资源共享最大化&#xff0c;企业FTP服务的应用也是必不可少。无论是员工出差还是修改&#xff0c;一旦涉及文件的应用&#xff0c;通…

android jxl.jar 使用,使用jxl.jar在Android中操作Excel表格——重中之重——对隐藏表的处理...

曾简单了解过C#&#xff0c;将Excel(数据库表)表中的数据导入到C#中&#xff0c;使用C#制作的图形化界面进行对Excel表中数据进行操作。今天想试试&#xff0c;在Android中导入Excel表格进行操作。在网上查阅资料&#xff0c;找到了jxl.jar包。jxl.jarjxl.jar是通过java操作exc…

自定义协议的这些典型例子你会了吗?

上次分享的《分享一个很酷的上位机软件》中&#xff0c;有如下协议&#xff1a;有位读者朋友问数据为什么要按这样的格式来发。其实这是个自定义协议&#xff0c;这是上位机开发者定义的一个数据交互协议。我们下位机往伏特加上位机发送数据需要遵循这样的协议数据&#xff0c;…

java 原子类_小学妹教你并发编程的三大特性:原子性、可见性、有序性

在并发编程中有三个非常重要的特性&#xff1a;原子性、有序性,、可见性&#xff0c;学妹发现你对它们不是很了解&#xff0c;她很着急&#xff0c;因为理解这三个特性对于能够正确地开发高并发程序有很大的帮助&#xff0c;接下来的面试中也极有可能被问到&#xff0c;小学妹就…

关于a标签不能调用js方法的小细节,你注意到了么?

在我们做后台删除的时候&#xff0c;当点击删除标签时&#xff0c;你希望弹出一个友好的提示框&#xff01;比如这样&#xff1a; 那代码应该怎样写呢&#xff1f;向下面这样&#xff1f; <!DOCTYPE html> <html lang"en"> <head><meta charset…

4岁小女孩给Linux内核贡献提交

今天在reddit上看到一个有趣的讨论&#xff0c;一个4岁的小女孩给Linux提交了一个补丁&#xff0c;并且这个补丁合并到了代码中。链接如下&#xff1a;https://www.reddit.com/r/linux/comments/2pqqla/kernel_commit_4_year_old_girl_fixes_formatting_to/cmzfvpl/我们看看她修…

php文件上传后没有打开权限_记墨者靶机文件上传(二)

“ 声明&#xff1a;该公众号大部分文章来自日常学习笔记&#xff0c;若是转载会先得到原作者授权或其他公众号白名单&#xff0c;并附上链接。剑者&#xff0c;心之刃也。既可为杀&#xff0c;亦可为护。杀与护&#xff0c;不过一念之间&#xff01;请勿利用文章内的相关技术从…

你还会写这段C51程序吗?

经典题目解析定时器T1采用计数模式&#xff0c;方式1中断&#xff0c;计数输入引脚 P3.5外接开关按钮作为计数信号输入&#xff0c;P1口控制8个LED小灯&#xff0c;初始状态所有小灯全亮&#xff0c;按3次按钮开关产生计数中断时&#xff0c;高3位和低5位交替闪烁3次&#xff0…

JDBC连接数据库(Java DataBase Connectivity,java)

通过JDBC操作数据库(以mysql为例) 1、官网下载JDBC的相关JAR包 【https://dev.mysql.com/downloads/connector/j/】 2、解压后&#xff0c;导入jar包 连接数据(引入外部jar包)项目上右键->build path->configure build path->上面Libraries->Add External JARs 3、…

过年回家抢票攻略

每年过年抢票都是一个困难的事情&#xff0c;所以决定发一篇文章汇总一下各种抢票软件&#xff0c;大家自己有方案的可以在文章后面留言&#xff0c;让跟多的人看到&#xff0c;希望大家都能顺利抢到车票&#xff0c;顺利回家。超级抢票机&#xff0c;一款超强的火车票抢票神器…

C语言,函数不可返回指向栈内存的指针

预备知识&#xff1a;内存的分类C/C程序占用的内存分为两大类&#xff1a;静态存储区与动态存储区。其示意图如下所示&#xff1a;数据保存在静态存储区与动态存储区的区别就是&#xff1a;静态存储区在编译-链接阶段已经确定了&#xff0c;程序运行过程中不会变化&#xff0c;…

android 界面绘制完毕,几种获取android 界面性能数据的快捷方法

探测 界面绘制性能获取界面的绘制性能有很多种方法&#xff0c;比如说 Systrace 但是这种方法 有一个不太好的地方就是使用起来较为复杂&#xff0c; 有没有一种 谷歌官方推荐 的方便一点的方法 &#xff0c;其实是有的&#xff0c;只需要一个函数 就可以获得layout的时间 非常…

联想rd650怎么装系统win7_Lenovo g50重装win7系统|U盘重装联想g50笔记本系统

Lenovo可以说是个家喻户晓的品牌很多小伙伴们也是使用联想的电脑&#xff0c;今天有小伙伴和小编提了一款Lenovo g50笔记本&#xff0c;小编了解到这款笔记本电脑的口碑和销量都很不错&#xff0c;其实这位小伙伴的问题呢是要如何重装win7系统&#xff0c;毕竟质量再好的电脑也…

书籍推荐

今天天气很好&#xff0c;风和日丽&#xff0c;艳阳高照&#xff0c;大家心情应该也很不错&#xff0c;毕竟&#xff0c;今天是周五&#xff0c;就像上学的时候一样&#xff0c;下午的铃声一响&#xff0c;每个同学都像脱缰的野马一样&#xff0c;周五&#xff0c;上班族的人们…

【转】JMeter学习(十三)分布式部署

Jmeter 是Java 应用&#xff0c;对于CPU和内存的消耗比较大&#xff0c;因此&#xff0c;当需要模拟数以千计的并发用户时&#xff0c;使用单台机器模拟所有的并发用户就有些力不从心&#xff0c;甚至会引起JAVA内存溢出错误。为了让jmeter工具提供更大的负载能力&#xff0c;j…

android mvp框架基类,Android MVP架构模式基类封装

前言MVP模式是Android官方推荐的架构模式&#xff0c;可使视图与数据层完全解耦。本文旨意封装在MVP模式中的基类如Activity&#xff0c;Fragment&#xff0c;Presenter类。以下内容建议在了解了mvp模式的读者阅读&#xff0c;如果还有对mvp架构模式有疑问的&#xff0c;请看我…