数据cube的schema与sql的对应的关系
用schema workbench 设置cube的维度结构
saiku 使用的cube,会将不同维度的查询转化为sql语句。
schema中,
cube的事实表和dimension表进行自然连接,具体的dimension设置是,dimension设置界面上foreign key(事实表的某一列)与hierarchy设置界面上primaryKey(dimension表的主键)。关联是通过这两个列进行对比,所以一定要指定正确。
而,level设置界面上的Column是实现group by 的
写一个一个小例子:
mdx语句
SELECT
NON EMPTY {[Measures].[Downloads]} ON COLUMNS,
NON EMPTY TopCount({Hierarchize(CrossJoin([dimDate.default].[day].[2014-01-03], [compare_app.default].[appName].Members))},20,[downloads]) ON ROWS
FROM [aso]
注意[dimDate.default]中default为层级名。要设定好,才能正确的引用level。我为hierarchy起名为default,因为就一个。
转换为对应的sql语句为:
SELECT
`dimdate`.`year` AS `c0`,
`dimdate`.`yearname` AS `c1`,
`dimdate`.`month` AS `c2`,
`dimdate`.`monthname` AS `c3`,
`dimdate`.`datevalue` AS `c4`,
`dimappnamenew_1`.`app_name` AS `c5`
FROM
`dimdate` AS `dimdate`,
`factdownloadsnew` AS `factdownloadsnew`,
`dimappnamenew` AS `dimappnamenew_1`
WHERE
`factdownloadsnew`.`date_time` = `dimdate`.`datevalue`
AND `factdownloadsnew`.`app_link_hash` = `dimappnamenew_1`.`app_link_hash`
AND(
`dimdate`.`datevalue` = '2014-01-03'
AND `dimdate`.`month` = '1'
AND `dimdate`.`year` = '2014'
)
GROUP BY
`dimdate`.`year`,
`dimdate`.`yearname`,
`dimdate`.`month`,
`dimdate`.`monthname`,
`dimdate`.`datevalue`,
`dimappnamenew_1`.`app_name`
ORDER BY
ISNULL(`dimdate`.`year`)ASC,
`dimdate`.`year` ASC,
ISNULL(`dimdate`.`month`)ASC,
`dimdate`.`month` ASC,
ISNULL(`dimdate`.`datevalue`)ASC,
`dimdate`.`datevalue` ASC,
ISNULL(
`dimappnamenew_1`.`app_name`
)ASC,
`dimappnamenew_1`.`app_name` ASC
这里我遇到一个问题,这个维度查询关联是按applinkhash进行,
结果如下:
而同样实现前20排名返回语句,用app_id进行关联:
SELECT
NON EMPTY {[Measures].[Downloads]} ON COLUMNS,
NON EMPTY TopCount({Hierarchize(CrossJoin([dimDate.default].[day].[2014-01-03], [dimApp.appName].[appName].Members))},20,[downloads]) ON ROWS
FROM [aso]
结果如下(不同):
两个结果不同。如,360用app_id统计的少了很多。
问题分析:applinkhash是一一对应的,而app_id也是一一对应的。二者比对应该相同。
app_id统计少了,是什么原因?
在原表中进行查询,直接统计360手机卫士的downloads,证明app_id是正确的。app_link_hash对比,会多统计一些。
原因如下:360手机卫士有两个version,5.0和4.3,两条记录applink,applinkhash相同,只有version不同,所以比对上有两个关联上了,导致累加到了一起。
另外,saiku中呈现的名字也是在schema里设置,对应关系:
schema名-------------最开始,saiku里面选择的schema
下一级
cube名----------------------saiku在每个schema下的名
下一级
dimension名(维度名)-----------------saiku呈现cube下为文件夹名
下一级
level名-------------------saiku可以拖拉使用的对象的
数据cube的schema与sql的对应的关系的更多相关文章
- 查询oracle数据库,返回的数据是乱码。 PL/SQL正常。
查询oracle数据库,返回的数据是乱码. PL/SQL正常. 解决方案如下:
- SQLSERVER:大容量导入数据时保留标识值 (SQL Server)
从MSDN上看到实现大容量导入数据时保留标识值得方法包含三种: MSDN链接地址为:https://msdn.microsoft.com/zh-cn/library/ms178129.aspx 感觉M ...
- MySQL数据导出为Excel, json,sql等格式
MySQL数据经常要导出为Excel, json,sql等格式,通过步骤都很多,麻烦,现在通过Treesoft可以方便的导出你要的数据格式. 1.在线执行SQL,在数据列表中有相应按钮,方便的将数据导 ...
- 【mybatis】mybatis执行一个update方法,返回值为1,但是数据库中数据并未更新,粘贴sql语句直接在数据库执行,等待好久报错:Lock wait timeout exceeded; try restarting transaction
今天使用mybatis和jpa的过程中,发现这样一个问题: mybatis执行一个update方法,返回值为1,但是数据库中数据并未更新,粘贴sql语句直接在数据库执行,等待好久报错:Lock wai ...
- 2016/05/13 thinkphp 3.2.2 ① 数据删除及执行原生sql语句 ②表单验证
[数据删除及执行原生sql语句] delete() 返回受影响的记录条数 $goods -> delete(30); 删除主键值等于30的记录信息 $goods -> delete( ...
- Oracle取查询结果数据的第一条记录SQL
Oracle取查询结果数据的第一条记录SQL: ; ;
- 在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML
在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML 格雷戈里·拉森(Gregory Larsen),2017/08/02(第一次出版:2011 /11/09) 原文链接:http ...
- 在SQL Server中实现关系模型
使用SQL Server的Transact-SQL(T-SQL)方言,此楼梯将为您提供如何使用SQL Server表中的数据的基本了解. DML是数据操作语言,是处理数据的语言的一个方面.它包括SEL ...
- 到T-SQL DML 三级的阶梯:在SQL server中实现关系模型
作者: Gregory Larsen, 2017/08/02 (第一次出版: 2011/11/09) 翻译:谢雪妮,许雅莉,赖慧芳,刘琼滨 译文: 系列 该文章是阶梯系列的一部分:T-SQL DML的 ...
随机推荐
- CocoaChina(总结)升级到xcode8遇到的问题及解决方案
此总结由CocoaChina论坛版主wo709128079及广大坛友共同汇总.>>查看原帖 升级Xcode8已是必然,升级iOS 10的用户不能说大有人在,应该也不会少,楼主听说,如果不升 ...
- Android TV开发总结(六)构建一个TV app的直播节目实例
请尊重分享成果,转载请注明出处:http://blog.csdn.net/hejjunlin/article/details/52966319 近年来,Android TV的迅速发展,传统的有线电视受 ...
- 全废话SQL Server统计信息(1)——统计信息简介
当心空无一物,它便无边无涯.树在.山在.大地在.岁月在.我在.你还要怎样更好的世界?--张晓风<我在> 为什么要写这个内容? 随着工作经历的积累,越来越感觉到,大量的关系型数据库的性能问题 ...
- 百度编辑器UEditor常用设置函数
最近在研究UEditor的使用,下面是附上传送门: 这是API文档http://ueditor.baidu.com/doc/ 这是下载地址http://ueditor.baidu.com/websit ...
- The packages can be overrided by Java Endorsed Standards
Endorsed Standards APIs The Endorsed Standards for Java SE constitute all classes and interfaces ...
- EJB_开发单表映射的实体bean
开发单表映射的实体bean 实体bean 它属于java持久化规范(JPA)里的技术,实体bean通过元数据在Javabean和数据库表之间建立起映射关系,然后Java程序员就可以随心所欲的使用面向对 ...
- x264源代码简单分析:x264_slice_write()
===================================================== H.264源代码分析文章列表: [编码 - x264] x264源代码简单分析:概述 x26 ...
- JDBC数据库连接简介(一)
jdbc的由来 odbc(open database connection) 最初各个数据库比如mysql和oracle等,虽然都支持sql,但是他们的连接方式是不一样的,需要按照相应的api来编写不 ...
- 4.关于QT中的QFile文件操作,QBuffer,Label上添加QPixmap,QByteArray和QString之间的区别,QTextStream和QDataStream的区别,QT内存映射(
新建项目13IO 13IO.pro HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += gui widgets network CON ...
- 随机采样和随机模拟:吉布斯采样Gibbs Sampling实现文档分类
http://blog.csdn.net/pipisorry/article/details/51525308 吉布斯采样的实现问题 本文主要说明如何通过吉布斯采样进行文档分类(聚类),当然更复杂的实 ...