这个在帆软sql中怎么实现

表里有烟台,北京,西安的金额,当选择烟台时要求展示的是烟台和西安的和,选择其他的还是展示自己本身金额

image.png

image.png

FineReport yzmikrWe3651420 发布于 2025-5-7 15:35
1min目标场景问卷 立即参与
回答问题
悬赏:3 F币 + 添加悬赏
提示:增加悬赏、完善问题、追问等操作,可使您的问题被置顶,并向所有关注者发送通知
共3回答
最佳回答
0
CD20160914Lv8专家互助
发布于2025-5-7 15:37(编辑于 2025-5-7 15:39)

直接在sql中判断一下参数是不是烟台了

where 1=1

${if(cs="烟台","and 字段名称 in('烟台','西安')","and 字段名称='"+cs+"'")}

image.png

image.png

最佳回答
0
用户k6280494Lv6专家互助
发布于2025-5-7 15:38

select sum(je) from a 

where year='${year}' 

${if(yq='烟台',"and yq in('烟台','西安')","and yq='"+yq+"'")}

最佳回答
0
苏菲的供词Lv6中级互助
发布于2025-5-7 17:02(编辑于 2025-5-7 17:06)

方法1:

where 1=1

and year = '${year}'

and ( case when '${yuanqu}' = '烟台' then yuanqu = '烟台' or yuanqu = '西安' else yuanqu = '${yuanqu}' end)

方法2:(union一个西安的,然后把union的西安改成烟台,这样烟台就多了一个西安的值,原来的西安的值也还在)

select year,'烟台',金额 from a where yuanqu = '西安'

union all

select * from a

  • 4关注人数
  • 50浏览人数
  • 最后回答于:2025-5-7 17:06
    请选择关闭问题的原因
    确定 取消
    返回顶部