Saiku函数解析

1.   now()  :  获取当前日期 直接使用即可

2. IIF(logic_exp, string, string): IIF判断,logic_exp是逻辑表达式,结果为true/false , 为true的时候取第二个参数值,为false的时候取第三个参数值。

eg:  IIF(1>2,"1大于2","1不大于2")   ,   结果为 1不大于2

多个IIF嵌套和我们平时使用IF语句是类似的 (下面多iif嵌套语句1与语句2结果是一样的。)

eg:  (多iif嵌套语句1)

IIF(datediff("y",cdate(now()),cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))<=7,
IIF(datediff("y",cdate(now()),cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))>=0,
IIF( year(cdate(now())) - year(cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))=0,"yes","no"),"no"),"no")  

也可以将多个IIF嵌套中的条件使用 AND 去连接,这样就是使用一个IIF就行了

eg:(多iif嵌套语句2)

IIF(datediff("y",cdate(now()),cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))<=7
AND datediff("y",cdate(now()),cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))>=0
AND year(cdate(now())) - year(cdate([SaikuUseDate].[SaikuUseDate].CurrentMember.Name))=0,"yes","no")

  

3. year(Date) : 获取日期的年份信息

eg: YEAR(cdate("2019-02-26"))

4. CDate(String) : 将String类型的数据转换为日期类型

eg: CDate("2019-02-26")

5. STR( numeric):  将数据类型转换为String类型

eg:  STR(55.6)

6. DateDiff(String, Date, Date) : 得到日期相减的值,第一个参数表示interval,第二个参数是日期类型,第三个是日期类型, eg:  datediff("y", CDate("2019-02-26"), CDate("2019-02-25"))  结算逻辑为 得出2019-02-26至 2019-02-25中相差的天数,结果为 1

interval的取值如下:

7.NonEmptyCrossJoin, 手写MDX语句进行查询的时候需要注意多个rows时的用法

WITH
SET [~ROWS1] AS
{[a].[a].[a].Members}
SET [filterdata] AS {FILTER([SaikuUseDate].[SaikuUseDate].[SaikuUseDate].Members,[Measures].[耗时]>2000)} SELECT
NON EMPTY {[Measures].[耗时]} ON COLUMNS,
NON EMPTY NonEmptyCrossJoin([filterdata], [~ROWS1]) ON ROWS
FROM [rs_nbjc_1_1]
ps:如果有多个rows,使用格式为: NonEmptyCrossJoin([a],NonEmptyCrossJoin([b],[c])) 

 8.DateSerial(year,month,day)   指定年月日信息,转换为Date类型

   参数类型:DateSerial(Integer,Integer,Integer)

  eg: DateSerial(2019,02,02)     结果为2019-02-02转换之后的天数

9. left(str,str_num) : 截取(前面的)字符串信息

  参数类型 left(string,Integer) 

  str 表示被截取的字符串

  str_num: 从第一位开始,截取多少位

eg:  left("helloWolrd",5)   结果为 hello

10. mid(str,start_num,str_num):截取中间的字符串信息

  参数类型  mid(string,Integer,Integer)

  str: 被截取的字符串

  start_num:表示从当前字符串的第几位开始截取

  str_num: 表示截取多少位

eg: mid("helloJava!",6,4)  结果为Java

11. cast(string as dataType)  将字符类型转换为数据类型   (  cast("22" as Integer)  )

  参数类型: string :表示String类型

       dataType: 可以为其它数据类型  比如 Integer , Numeric ,boolean 等

eg:  cast("666" as Integer)  结果就为数据类型Integer 的 666

8/9/10/11综合实例 (这个综合实例的来源是 从数据库中取出的Date类型数据在saiku展示时 变为String类型了,直接使用cdate函数转换时会抛出参数有误的,所以就自己使用函数组装为Date类型)
截取字符串:"2019-09-11"
left("2019-09-11",4) // 截取左边四位 2019
mid("2019-09-11",6,2) //截取从第6位开始的 两位 09
mid("2019-09-11",9,2) //截取从第9位开始的 两位 11

Saiku中将String类型数据转换为Date类型实例:

DateSerial(cast(left([countdate].[countdate].CurrentMember.name,4) as Integer),
cast(mid([countdate].[countdate].CurrentMember.name,6,2) as Integer),
cast(mid([countdate].[countdate].CurrentMember.name,9,2) as Integer))   

其中 [countdate].[countdate].CurrentMember.name 是日期类型字段

DateSerial(cast(left([countdate].[countdate].CurrentMember.name,4) as Integer), --获取年并转换为数值类型

  cast(mid([countdate].[countdate].CurrentMember.name,6,2) as Integer), -- 获取月并转换为数值类型

  cast(mid([countdate].[countdate].CurrentMember.name,9,2) as Integer))  --获取日并转换为数值类型

12.Datepart(String,Datetype)  :返回结果为得到当前年份和周相关的数据信息  

参数类型: String: 表示string类型的数据,但是有固定值,这里讲两个示例 w / ww (w表示当前日期为这周的第几天,ww表示这周是当前年份的第几周)        

     Datetype: 表示时间类型      

eg:  datepart('w',now()) now()表示获取当前日期,当前日期为 2019-03-07 ,返回结果为 ,表示这是本周的第五天    

    datepart('ww',now()) now()表示获取当前日期,当前日期为 2019-03-07 ,返回结果为 10 ,表示今天所属的周为2019的第十周

Saiku部分函数解析(八)的更多相关文章

  1. Hive部分函数解析

    Hive部分函数解析 Hive里的exists ,in ,not exists ,not in 相关函数 表数据准备: 1.选择指定数据库 eg:  use bg_database1; 2. 创建表 ...

  2. ReactiveSwift源码解析(八) SignalProducer的代码的基本实现

    在前面几篇博客中我们详细的聊了ReactiveSwift中的Bag.Event.Observer以及Signal的使用方式和代码实现.那么在接下来的这几篇博客中,我们就依附于之前博客的基础上来聊一聊S ...

  3. Celery 源码解析八:State 和 Result

    在前面几篇解析中,我们已经看过了 Worker 是如何运行的,Task 是如何创建的,以及怎么被路由到 Worker 中,除了这些之外,我们还对流量限制,Worker 控制和 Task/Worker ...

  4. C++解析八-多态

    多态多态按字面的意思就是多种形态.当类之间存在层次结构,并且类之间是通过继承关联时,就会用到多态.C++ 多态意味着调用成员函数时,会根据调用函数的对象的类型来执行不同的函数.下面的实例中,基类 Sh ...

  5. jQuery 源码解析(八) 异步队列模块 Callbacks 回调函数详解

    异步队列用于实现异步任务和回调函数的解耦,为ajax模块.队列模块.ready事件提供基础功能,包含三个部分:Query.Callbacks(flags).jQuery.Deferred(funct) ...

  6. 《MySQL数据分析实战》八句箴言前四句解析

    大家好,我是jacky朱元禄,很高兴继续跟大家学习<MySQL数据分析实战>,从本节课程开始,jacky将从SQL语句入手,给大家解析八句箴言: 不管三七二十一,先把数据show来看: 数 ...

  7. QT源码解析(一) QT创建窗口程序、消息循环和WinMain函数

    QT源码解析(一) QT创建窗口程序.消息循环和WinMain函数 分类: QT2009-10-28 13:33 17695人阅读 评论(13) 收藏 举报 qtapplicationwindowse ...

  8. Celery 源码解析三: Task 对象的实现

    Task 的实现在 Celery 中你会发现有两处,一处位于 celery/app/task.py,这是第一个:第二个位于 celery/task/base.py 中,这是第二个.他们之间是有关系的, ...

  9. Celery 源码解析五: 远程控制管理

    今天要聊的话题可能被大家关注得不过,但是对于 Celery 来说确实很有用的功能,曾经我在工作中遇到这类情况,就是我们将所有的任务都放在同一个队列里面,然后有一天突然某个同学的代码写得不对,导致大量的 ...

随机推荐

  1. cocos2dx spine之一 :spine缓存 (c++ & lua)

    cocos2dx版本为3.10 1.在使用spine的过程中,发现了一个比较严重的问题:每次创建SkeletonAnimation的时候都会很卡,即使是使用同一个骨骼数据skeletonData. 跟 ...

  2. XLua访问C#中的List或者数组

    直接访问即可 以下截图是C#中的List与数组: 现在通过XLua修复一下 RequestRoomListRes 方法(这里主要关注list和数组在XLua中的访问方式,对数组与List的遍历用了两种 ...

  3. 并查集-解决区间和纠错问题 hdu-3038

    题目:多次给出信息,告诉你[a,b]区间的和,求多少个错误信息(错误信息不考虑). 乍一看有点像线段树,但想想就发现这个并不能用线段树方便地解决.后来经提醒是并查集的一种经典题型. 把区间抽象为并查集 ...

  4. ssd制作数据和训练

    1.在/data/VOCdevkit下建立自己的数据集名称如MyDataSet,在MyDataSet目录下需包含Annotations.ImageSets.JPEGImages三个文件夹: 2.Ima ...

  5. stark 组件 url 二级分发的实现

    模拟 admin 组件url设计思路 项目urls 文件中: from django.contrib import admin from django.urls import path from st ...

  6. vue.js如何实现点击按钮动态添加li

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. python记录_day04 列表 元组

    今日主要内容: 列表 和 元组 列表 一.列表介绍 列表是一种能存储大量数据的数据结构,是能装对象的对象.由方括号 [] 括起来,能放任意类型的数据,数据之间用逗号隔开 列表存储数据是有顺序的 二.增 ...

  8. Spring Framework启动详解

    之前一直对Spring启动的过程很迷糊,所以这次国庆梳理一下. Spring启动一言以蔽之:创建一个根应用上下文.(因为其他的所有的应用上下文都可以通过各种方式继承它) (一)了解应用上下文 Spri ...

  9. apache2反向代理

    1.安装 Apache2 sudo apt-get install apache2 2.重启服务器 sudo /etc/init.d/apache2 restart 3.虚拟主机配置 启用这几个模块 ...

  10. 整体二分求动态区间第k大

    比树状数组套主席树不知道高到哪里去了,solve(l,r,L,R)就是对于L,R的操作区间的答案都在l,r区间里,然后递归下去 复杂度O(nlognlogn),每个操作会执行logn次就是o(nlog ...