反馈已提交

网络繁忙

利用内置数据集实现范围划分

  • 文档创建者:axing
  • 历史版本:8
  • 最近更新:Catqiu 于 2023-12-01
  • 1. 概述

    1.1 问题描述

    当我们希望在 FineReport 中根据数值区段对其进行等级划分时,例如根据销售员的销量范围,对销售员划分等级,如下表所示:

    销量范围
    等级
    2000以上 A
    1900~2000 B
    1800~1900 C
    1700~1800 D
    1600~1700  E
    1500~1600F
    1500以下 G

    通常的做法是写 IF 公式一个一个范围的判断,导致公式冗长,嵌套复杂。那如何能简单快速的建立等级对应关系呢?

    1.2 解决思路

    利用内置数据集建立好范围与等级对应关系,再利用 tablename.select() 公式来查询。

    2. 示例

    2.1 数据准备

    1)新建普通报表,新建数据库查询 ds1,SQL 查询语句为:SELECT 销售员,sum(销量) 销量 FROM 销量 group by 销售员

    1607574125920563.png

    2)新建内置数据集「范围划分」,设计三个字段分别为「最大值」、「最小值」和「等级」,设置表示范围值的两个列名的数据类型为整数或小数,再将对应数值和等级增加到字段中。如下图所示:

    Snag_605dde5.png

    2.2 报表设计

    1)将 ds1 中「销售员」「销量」数据列分别拖入 A2、B2 单元格,输入对应标题,设计表格样式如下图所示:

    1607574380806785.png

    2)选中 C2 单元格,单击右键,选择「单元格元素>插入公式」,公式为: 范围划分.select(等级, B2 >= 最小值 && B2 < 最大值),即返回当前 B2 单元格在「范围划分」数据集中大于等于最小值并且小于最大值对应的等级。

    image.png

    2.3 效果预览

    2.3.1 PC 端

    保存报表,点击「分页预览」,效果如下图所示:

    Snag_610a701.png

    2.3.2 移动端

    App 和 HTML5 端均支持,效果如下图所示:

    Snag_613423d.png

    3. 模板下载

    已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\SpecialSubject\利用内置数据集实现范围划分.cpt

    点击下载模板:利用内置数据集实现范围划分.cpt

    附件列表


    主题: 报表应用
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持