帆软部分公式及sql生成(月份、季度取数)

以下均为帆软公式:

1.获得当前月往后推三月,如当前为8月,获得"9-11月"字样
if(DATA_MONTH_BOX\<10,(DATA_MONTH_BOX+1)+'-'+(DATA_MONTH_BOX+3)+'月', if(DATA_MONTH_BOX=10,DATA_YEAR_BOX+'年11月-'+NEXT_YEAR+'年1月',
if(DATA_MONTH_BOX=11,DATA_YEAR_BOX+'年12月-'+NEXT_YEAR+'年2月', if(DATA_MONTH_BOX=12,$NEXT_YEAR+'年1-3月',''))))

获得后一月,如当前8月,获得"9月",当前为12月,获得"+1年1月"

IF(DATA_MONTH_BOX\<12,(DATA_MONTH_BOX+1)+'月',
if(DATA_MONTH_BOX=12,NEXT_YEAR+'年1月',''))

获得后两月

IF(DATA_MONTH_BOX\<11,(DATA_MONTH_BOX+2)+'月',
if(DATA_MONTH_BOX=11,NEXT_YEAR+'年1月',
IF(DATA_MONTH_BOX=12,NEXT_YEAR+'年2月','')))

获得后三月

IF(DATA_MONTH_BOX\<10,(DATA_MONTH_BOX+3)+'月',
if(DATA_MONTH_BOX=10,NEXT_YEAR+'年1月',
IF(DATA_MONTH_BOX=11,NEXT_YEAR+'年2月',
IF(DATA_MONTH_BOX=12,NEXT_YEAR+'年3月',''))))


2.获得1-上月份,当前月为1月时,获得"去年1-12月"
if(月份 != 1 \&\& 月份 != 2, 月份 + '月占比比1-' + (月份 - 1) + '月', if(月份 = 1, 月份 + '月占比比去年1-12月', '2月占比比1月'))

sql语句示例:

sum(case when t.data_year='{去年}' and t.data_month='{月份}' then t.num else 0 end ) as 厂家同期当月,
{if(月份=='2',"sum(case when t.data_year='"+年度+"' and t.data_month='1' then t.num else 0 end ) as 厂家1至上月累计,","")} {if(月份=='1',"sum(case when t.data_year='"+去年+"' then t.num else 0 end ) as 厂家1至上月累计,","")}
${if(月份!='1' && 月份!='2',"sum(case when t.data_year='"+年度+"' and t.data_month<="+(月份-1)+" then t.num else 0 end ) as 厂家1至上月累计,","")}

3.获得当前季度
if(月份 % 3 = 0, 月份 / 3, Int($月份 / 3) + 1) + '季度'

sql语句示例:

设置控件为
{当季度_s}=if(月份 % 3 = 0, 月份 / 3, Int(月份 / 3) + 1)

sum(case when t.data_year='{年度}' and (t.data_month\>=(1+3\*({当季度_s}-1)) and t.data_month<=(${当季度_s}*3)) then t.num else 0 end ) as 厂家季度销量,

当数据类型为t.yue1这种时

JOINARRAY(RANGE(if(月份%3=0,月份/3-1,Int(月份/3))\*3+1,if(月份%3=0,月份/3-1,Int(月份/3))*3+3,1),"+t.yue")

4.获得1-当前季度
'1-' + if(月份 % 3 = 0, 月份 / 3, Int($月份 / 3) + 1) + '季度'

sql语句示例:

sum(case when t.data_year='{年度}' and t.data_month\<=({当季度_s}*3) then t.num else 0 end ) as 厂家季度累计,
sum(case when t.data_year='{去年}' and t.data_month\<=({当季度_s}*3) then t.num else 0 end ) as 厂家同期季度累计,

5.获得1-上季度,当前季度为1时,获得"去年1-4季度",此处示例为"当季度占比比1-上季度"
if(if(月份 % 3 = 0, 月份 / 3, Int(月份 / 3) + 1)!='1',if(月份 % 3 = 0, 月份 / 3, Int(月份 / 3) + 1) + '季度占比比1-' + (if(月份 % 3 = 0, 月份 / 3, Int($月份 / 3) + 1) - 1) + '季','1季度占比比去年1-4季度')

sql语句示例:

${if(当季度_s!='1',
"sum(case when t.data_year='"+年度+"' and (t.data_month>=1 and t.data_month<="+((当季度_s-1)*3)+") then t.num else 0 end ) as 厂家1至上季度累计,",
"sum(case when t.data_year='"+去年+"' then t.num else 0 end ) as 厂家1至上季度累计,")}

当数据库一年数据放在一条内时:

IF(
if(月份 % 3 = 0, 月份 / 3, Int(月份 / 3) + 1)!='1', JOINARRAY( RANGE( (if(月份%3=0,月份/3-1,Int(月份/3))-1)*3+1,
(if(月份%3=0,月份/3-1,Int($月份/3))-1)*3+3,
1
)
,"+t.yue"
),
'10+t.yue11+t.yue12'
)

6.获得当季度,如当前3月,获得"1季度"
if(月份%3=0,月份/3,Int($月份/3)+1)

sql语句示例:

获得季度累计的月份计算sql,如当前月为4月,获得1-2季度即1-6月的月份累计sql

sum(case when t.data_year='{年度}' and (t.data_month\>=(1+3\*({当季度_s}-1)) and t.data_month<=(${当季度_s}*3)) then t.num else 0 end ) as 厂家季度销量,

如果是一年的销量数据放在一条数据内:

JOINARRAY(RANGE(1,if(月份%3=0,月份/3-1,Int($月份/3))*3+3,1),"+t.yue")

相关推荐
顾安r2 小时前
11.8 脚本网页 星际逃生
c语言·前端·javascript·flask
Hello.Reader2 小时前
Data Sink定义、参数与可落地示例
java·前端·网络
im_AMBER2 小时前
React 17
前端·javascript·笔记·学习·react.js·前端框架
谷歌开发者3 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢3 小时前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了3 小时前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
街尾杂货店&4 小时前
css - 实现三角形 div 容器,用css画一个三角形(提供示例源码)简单粗暴几行代码搞定!
前端·css
顺凡5 小时前
删一个却少俩:Antd Tag 多节点同时消失的原因
前端·javascript·面试
小白路过5 小时前
CSS transform矩阵变换全面解析
前端·css·矩阵
爬山算法5 小时前
Redis(110)Redis的发布订阅机制如何使用?
前端·redis·bootstrap