端访问或手机端访问的js代码//帆软部分公式及sql生成(月份、季度取数)

if(!window.navigator) {  
    FR.Msg.alert("提示","当前设备:移动端APP")
}
else{
    if(/Mobile|Android|webOS|iPhone|iPad|Phone/i.test(navigator.userAgent)){
		FR.Msg.alert("提示","当前设备:移动端H5");
	}
	else{
		FR.Msg.alert("提示","当前设备:PC端");
	}
}
————————————————
 

 访问或手机端访问的js代码

以下均为帆软公式:
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月','')))


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")


 

  • 23
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值