Saiku更改源代码实现默认查询一天的数据(十)
Saiku通过更改源代码实现默认查询前一天数据
saiku在本地进行的编译的方式前面已有教程说明,接下来就是更改原代码了 (从网上学得教程,目前只了解到获取最新一天的数据信息)
参考博客地址: https://blog.csdn.net/zstao168/article/details/52818569
1. 主要更改的类信息:在saiku-web工程中的Query2Resource.java中,具体类路径为: /saiku-web/src/main/java/org/saiku/web/rest/resources/Query2Resource.java
在该类的 public QueryResult execute(ThinQuery tq ) 方法中添加 tq = this.restrictQueryByDate(tq); (execute方法大概在该类的 185-220行左右)
/**
*
* Execute a Saiku Query
* @summary Execute Query
* @param tq Thin Query model
* @return A query result set.
*/
@POST
@Consumes({"application/json" })
@Path("/execute")
public QueryResult execute(ThinQuery tq) { //add code to limit query date
tq = this.restrictQueryByDate(tq);
try {
if (thinQueryService.isMdxDrillthrough(tq)) {
Long start = (new Date()).getTime();
ResultSet rs = thinQueryService.drillthrough(tq);
QueryResult rsc = RestUtil.convert(rs);
rsc.setQuery(tq);
Long runtime = (new Date()).getTime()- start;
rsc.setRuntime(runtime.intValue());
return rsc;
} QueryResult qr = RestUtil.convert(thinQueryService.execute(tq));
ThinQuery tqAfter = thinQueryService.getContext(tq.getName()).getOlapQuery();
qr.setQuery(tqAfter);
return qr;
}
catch (Exception e) {
log.error("Cannot execute query (" + tq + ")",e);
String error = ExceptionUtils.getRootCauseMessage(e);
return new QueryResult(error);
}
}
在Query2Resource.java类中添加 ThinQuery restrictQueryByDate(ThinQuery tq) 方法,内容如下
// add code for query limit
private ThinQuery restrictQueryByDate(ThinQuery tq) { ThinQueryModel queryModel = tq.getQueryModel();
Map<AxisLocation, ThinAxis> axesMap = queryModel.getAxes(); NamedList<ThinHierarchy> namedList = new NamedListImpl<ThinHierarchy>(); ThinAxis filterAxis = axesMap.get(AxisLocation.FILTER);
List<ThinHierarchy> filterHie = filterAxis.getHierarchies(); namedList = this.resetThinHierachy(filterHie); //将修改后的Row重新set到queryModel
if(namedList.size() > 0) { ThinAxis newFilterAxis = new ThinAxis(
AxisLocation.FILTER,
namedList,
filterAxis.isNonEmpty(),
filterAxis.getAggregators()
); axesMap.put(AxisLocation.FILTER,newFilterAxis);
} //将修改后的Row重新set到queryModel
if(namedList.size() == 0) { ThinAxis rowAxis = axesMap.get(AxisLocation.ROWS);
List<ThinHierarchy> rowHie = rowAxis.getHierarchies(); namedList = this.resetThinHierachy(rowHie); if(namedList.size() > 0) {
ThinAxis newRowsAxis = new ThinAxis(
AxisLocation.ROWS,
namedList,
rowAxis.isNonEmpty(),
rowAxis.getAggregators()
); axesMap.put(AxisLocation.ROWS,newRowsAxis);
}
} //if columns contained date member
//if contained and have not set the limit ,then add limit to one day ,if do not hava then add this column and limit to one day;
if(namedList.size() == 0) { // namedList.clear(); ThinAxis colAxis = axesMap.get(AxisLocation.COLUMNS);
List<ThinHierarchy> colHie = colAxis.getHierarchies(); namedList = this.resetThinHierachy(colHie); if(namedList.size() == 0) { //if list is empty,then column don't hava date ,then add colHie to list and enfore to add date member;
namedList.addAll(colHie); SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
String yesterday = format.format(new Date(new Date().getTime() - 24 * 60 * 60 * 1000)); String newDateMdx = "[SaikuUseDate].[SaikuUseDate].["+yesterday+"]"; ThinMember thinMember = new ThinMember(yesterday,newDateMdx,yesterday);
ThinHierarchy thinHie = new ThinHierarchy(); thinHie.setName("[SaikuUseDate].[SaikuUseDate]"); List<ThinMember> thinMemberList = new ArrayList<ThinMember>();
thinMemberList.add(thinMember);
ThinSelection selection = new ThinSelection();
selection.setMembers(thinMemberList);
selection.setType(ThinSelection.Type.INCLUSION);
ThinLevel thinLevel = new ThinLevel(yesterday,yesterday,selection,null);
// thinLevel.setSelection(selection);
Map<String,ThinLevel> mapLevel = new LinkedHashMap<String,ThinLevel>();
mapLevel.put("SaikuUseDate", thinLevel); thinHie.setLevels(mapLevel); namedList.add(thinHie);
ThinAxis newColAxis = new ThinAxis(
AxisLocation.COLUMNS,
namedList,
colAxis.isNonEmpty(),
colAxis.getAggregators()
); axesMap.put(AxisLocation.COLUMNS,newColAxis);
}
} return tq;
} private NamedList<ThinHierarchy> resetThinHierachy(List<ThinHierarchy> hieList) { NamedList<ThinHierarchy> namedList = new NamedListImpl<ThinHierarchy>();
boolean flag = false; for(ThinHierarchy hie : hieList) {
if(hie.getName().equals("[SaikuUseDate].[SaikuUseDate]")) { if(hie.getLevels().get("SaikuUseDate").getSelection() == null) {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
String yesterday = format.format(new Date(new Date().getTime() - 24 * 60 * 60 * 1000)); String newDateMdx = "[SaikuUseDate].[SaikuUseDate].["+yesterday+"]"; ThinMember thinMember = new ThinMember(null,newDateMdx,yesterday); List<ThinMember> thinMemberList = new ArrayList<ThinMember>();
thinMemberList.add(thinMember);
ThinSelection selection = new ThinSelection();
selection.setMembers(thinMemberList); hie.getLevels().get("SaikuUseDate").setSelection(selection);
} flag = true;
} namedList.add(hie);
}
if(flag) return namedList; namedList.clear();
return namedList; }
ps: 如果 hie.getLevels().get("SaikuUseDate") 中得到的ThinLevel对象没有setSeletion(selection)方法,需要手工在ThinLevel中添加set方法
还有一点需要注意,就是加上这些代码之后,saiku的schame文件中cube需要有 SaikuUseDate 日期字段。
最后将整个项目打包编译即可,将新的saiku-server启动,然后配置一些数据信息,便能获取最近一天的数据信息了。
Saiku更改源代码实现默认查询一天的数据(十)的更多相关文章
- Saiku根据入参日期查询出对应的数据(二十)
Saiku根据入参日期查询出对应的数据 之前好像有写过一篇博客关于saiku date range的,现在进一步更新啦!!! 这里的日期筛选会更完善一些,需要提供两个参数 开始日期与结束日期(star ...
- Saiku更改導出文件的文件名(十九)
Saiku更改導出文件的文件名 Saiku查询完数据之后,可以以excel,pdf,csv等格式将数据导出,这里我们来讲一下怎么更改导出的文件名. 找到对应的导出方法所在的js文件: saiku-se ...
- Informatica 常用组件Source Qualifier之二 默认查询
2 默认查询 对于关系源,PowerCenter Server 将在运行会话时为每个源限定符转换生成查询.对于每个在映射中使用的源列,默认查询均为 SELECT 语句.也就是说,PowerCenter ...
- Windows10系统如何更改程序的默认安装目录?
Windows10系统如何更改程序的默认安装目录? 在Windows10系统的使用中,软件程序的默认安装目录是:C:\Program Files\...或者C:\Program Files(x86)\ ...
- 如何在TFS中恢复系统默认查询”已指派给我”的设置(TFS 2013)
故事是这样开始的,一天开发人员求助说,在浏览器中修改了系统默认的工作项查询"已指派给我"的后,发现这个查询每次都提示超时,并且没有办法恢复到初始的设置状态,因为出现超时提示以后,查 ...
- mysql数据库管理工具sqlyog在首选项里可以设置默认查询分页条数和字体,改写关键字大小写
sqlyog设置一直习惯用sqlyog来管理mysql数据库,但有三个地方用得不是很爽:1.默认查询条数只有1000条经常需要勾选掉重新查询.2.自动替换关键字大小写,有时候字段名为关键字的搞成大写的 ...
- [saiku] 系统登录成功后查询Cubes
一.系统启动时初始化ds和conn 1.查询出目前系统拥有的Datasources和Connections放入内存中 2.比对saiku-datasources中的ds是否有新增的,如果有,创建新的d ...
- 也可以使用如下命令更改您的默认 Shell
也可以使用如下命令更改您的默认 Shell chsh -s /bin/zsh (需要输入您的密码)
- 更改git bash默认的路径
更改git bash默认的路径 在打开git bash时,每次都是在C:\Uer路径下,每次都需要先用cd命令转换到自己需要工作的路径(cd /f/dss).修改打开git bash 时的默认的 ...
随机推荐
- Django框架详细介绍---模板系统
Django模板系统 官方文档: https://docs.djangoproject.com/en/2.0/ref/templates/builtins/#std:templatetag-for 1 ...
- pyCharm的第一个项目
首先打开编译器pyCharm 创建一个项目 在location :新建文件夹 在interpreter:指定python解释器的路径 python解释器下载官网: https://www.python ...
- 【酷】JS+CSS打造沿Y轴纵深运动的3D球体
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...
- Docker Kubernetes YAML文件常用指令
YAML文件常用指令 配置文件说明: 定义配置时,指定最新稳定版API(当前为v1). 配置文件应该存储在集群之外的版本控制仓库中.如果需要,可以快速回滚配置.重新创建和恢复. 应该使用YAML格式编 ...
- Python GIL锁
GIL全局解释器锁:为了解决多线程修改同一块数据. python的线程是调用操作系统的源生线程,启动时就是调用C语言的C源生接口,python调用C语言接口的线程去执行任务时,必须上下文对应关系传给C ...
- shell实现自动部署两台tomcat项目Ⅱ
本次分为3个脚本, scp.sh放进第一台机器(负责传输文件), schenglee.sh放进第一台机器(自动部署), schenglee2.sh放进第二台机器(自动部署) 环境 tomcat1: 1 ...
- 剑指offer(2)替换空格
题目描述 请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 题目分析 我们如果要替换空格,两步 ...
- selenium+java利用AutoIT实现文件上传
转自https://www.cnblogs.com/yunman/p/7112882.html?utm_source=itdadao&utm_medium=referral 1.AutoIT介 ...
- luogu2046[NOI2010]海拔 对偶图优化
luogu2046[NOI2010]海拔 对偶图优化 链接 https://www.luogu.org/problemnew/show/P2046 思路 海拔一定是0或者1,而且会有一条01交错的分界 ...
- WDTP注册破解
简介 WDTP 不止是一款开源免费的 GUI 桌面单机版静态网站生成器和简单方便的前端开发工具,更是一款跨平台的集笔记.个人知识管理.写作/创作.博客/网站内容与样式管理等功能于一体的多合一内容处理/ ...