> 小计:是指数字列表的一部分的总和
> 纵向分组小计:是指每个纵向分组下的小计
# 纵向分组小计
[TOC]
## 示例1—不存在横向分组小计
### 1、效果展示
纵向分组小计:[点击预览示例1](https://bootapi.jeecg.com/jmreport/view/590808622016319488)
以地区为分组依据,计算销售金额合计;`合计`两个字展示在省份下。

### 2、创建一个名为`区域省份销售统计`的数据报表
> 创建一个区域销售表,有七个字段:ID、数量、区域名称、年、省份、价格、月份

#### 2.1 为`区域省份销售统计`创建SQL数据源

> 部分数据展示

#### 2.2 将字段拖拽到设计器页面

#### 2.3 设置纵向分组、横向分组、动态属性
> 此步骤涉及到`横向纵向组合动态列`和`交叉报表`
横向纵向组合动态列请参考[横向纵向组合动态列](http://report.jeecg.com/2119057)
交叉报表请参考[交叉报表](http://report.jeecg.com/2112709)
* 地区(areaname)纵向分组:`#{jm.group(areaname)}`
* 省份(province)纵向分组:`#{jm.group(province)}`
* 年份(year)横向分组:`#{jm.groupRight(year)}年`
* 月份(month)横向分组:`#{jm.groupRight(month)}月`
* 销售额(amount)动态属性:`#{jm.dynamic(amount)}`

#### 2\. 4、重点来了->设置分组小计
> 特别注意:本例中`#{jm.group(areaname)}`为分组依据字段、`#{jm.group(province)}`为分组字段,则合计可正常显示,”合计“两个字展示在省份下;自1.4.0版本开始当只有分组依据字段,无其他分组字段时,”合计“两个字自动展示在分组字段后一个字段中。
> `#{jm.group(areaname)}`设置为分组依据

> `#{jm.dynamic(amount)}`设置为`求和`

> 保存预览
> 
## 示例2—存在横向分组小计
### 1、效果展示
组合分组小计:[点击预览示例2](https://bootapi.jeecg.com/jmreport/view/590812531803901952)
以区域为分组依据,设置纵向小计和横向小计
小计:横向计算,单价\*金额
合计:金额列组内相加

### 2、创建一个名为`区域省份销售统计`的数据报表
> 创建一个区域销售表,有七个字段:ID、数量、区域名称、年、省份、价格、月份

#### 2.1 为`区域省份销售统计`创建SQL数据源

> 部分数据展示

#### 2.2 将字段拖拽到设计器页面

#### 2.3 设置横向分组、纵向分组、动态属性、横向小计
> 此步骤涉及到`横向纵向组合动态列`和`交叉报表`和`横向分组小计`
横向纵向组合动态列请参考[横向纵向组合动态列](http://report.jeecg.com/2119057)
交叉报表请参考[交叉报表](http://report.jeecg.com/2112709)
横向分组小计请参考[横向分组小计](http://report.jeecg.com/2250464)
* 地区(areaname)纵向分组:`#{jm.group(areaname)}`
* 部门(province)纵向分组:`#{jm.group(province)}`
* 年份(year)横向分组:`#{jm.groupRight(year)}年`
* 月份(month)横向分组:`#{jm.groupRight(month)}月`
* 动态字段:
单价(`#{jm.dynamic(price)}`)
金额(`#{jm.dynamic(amount)}`)
小计(`#{jm.compute(price*amount)}`)

#### 2.4、重点来了->设置分组小计
> 特别注意:本例中`#{jm.group(areaname)}`为分组依据字段、`#{jm.group(dept)}`为分组字段,则合计可正常显示,”合计“两个字展示在省份下;自1.4.0版本开始当只有分组依据字段,无其他分组字段时,”合计“两个字自动展示在分组字段后一个字段中。
> `#{jm.group(areaname)}`设置为分组依据

> `#{jm.dynamic(amount)}`设置成求和列

> 保存预览

## 特殊规则注意
> 设置动态单元格类型
> 当数据不完整时系统默认会进行补0操作便于小计表达式计算,如果该单元格不是数值类型则需要设置为文本,设置文本后该单元格显示为空;如:`备注`字段为空时,不需要展示为0,则设置备注字段类型为`文本`。
> 
## 数据格式 重要!!!(数据必须完整)
> 特别注意:当有横向分组时,数据中第一条`数据必须完整`;例如:期望展示1-12月的数据,则第一条数据1-12月必须都有数据。
* SQL数据:

* 返回JSON格式:
~~~
{
"data": [{
"amount": "100",
"month": "1",
"areaname": "华北",
"year": "2020",
"price": "5",
"id": "1",
"dept": "河北",
"settleamount": "100"
},
{
"amount": "200",
"month": "2",
"areaname": "华北",
"year": "2020",
"price": "5",
"id": "10",
"dept": "河北",
"settleamount": "200"
},
{
"amount": "202",
"month": "2",
"areaname": "华北",
"year": "2020",
"price": "6",
"id": "12",
"dept": "河南",
"settleamount": "202"
},
{
"amount": "203",
"month": "1",
"areaname": "华东",
"year": "2020",
"price": "6",
"id": "13",
"dept": "辽宁",
"settleamount": "203"
},
{
"amount": "204",
"month": "2",
"areaname": "华东",
"year": "2020",
"price": "6",
"id": "14",
"dept": "辽宁",
"settleamount": "204"
},
{
"amount": "205",
"month": "1",
"areaname": "华南",
"year": "2020",
"price": "5",
"id": "15",
"dept": "湖北",
"settleamount": "205"
},
{
"amount": "206",
"month": "2",
"areaname": "华南",
"year": "2020",
"price": "5",
"id": "16",
"dept": "湖北",
"settleamount": "206"
},
{
"amount": "207",
"month": "1",
"areaname": "华南",
"year": "2020",
"price": "5",
"id": "17",
"dept": "安徽",
"settleamount": "207"
},
{
"amount": "208",
"month": "2",
"areaname": "华南",
"year": "2020",
"price": "5",
"id": "18",
"dept": "安徽",
"settleamount": "208"
},
{
"amount": "201",
"month": "2",
"areaname": "华北",
"year": "2021",
"price": "5",
"id": "20",
"dept": "河北",
"settleamount": "201"
},
{
"amount": "200",
"month": "1",
"areaname": "华北",
"year": "2021",
"price": "5",
"id": "21",
"dept": "河北",
"settleamount": "200"
},
{
"amount": "202",
"month": "2",
"areaname": "华北",
"year": "2021",
"price": "6",
"id": "22",
"dept": "河南",
"settleamount": "202"
},
{
"amount": "209",
"month": "1",
"areaname": "华北",
"year": "2021",
"price": "6",
"id": "23",
"dept": "河南",
"settleamount": "209"
},
{
"amount": "202",
"month": "1",
"areaname": "华北",
"year": "2020",
"price": "6",
"id": "24",
"dept": "河南",
"settleamount": "202"
},
{
"amount": "203",
"month": "1",
"areaname": "华东",
"year": "2021",
"price": "6",
"id": "25",
"dept": "辽宁",
"settleamount": "203"
},
{
"amount": "204",
"month": "2",
"areaname": "华东",
"year": "2021",
"price": "6",
"id": "26",
"dept": "辽宁",
"settleamount": "204"
},
{
"amount": "205",
"month": "1",
"areaname": "华南",
"year": "2021",
"price": "5",
"id": "27",
"dept": "湖北",
"settleamount": "205"
},
{
"amount": "206",
"month": "2",
"areaname": "华南",
"year": "2021",
"price": "5",
"id": "28",
"dept": "湖北",
"settleamount": "206"
},
{
"amount": "207",
"month": "1",
"areaname": "华南",
"year": "2021",
"price": "5",
"id": "29",
"dept": "安徽",
"settleamount": "207"
},
{
"amount": "208",
"month": "2",
"areaname": "华南",
"year": "2021",
"price": "5",
"id": "30",
"dept": "安徽",
"settleamount": "208"
},
{
"amount": "203",
"month": "1",
"areaname": "华东",
"year": "2020",
"price": "6",
"id": "43",
"dept": "天津",
"settleamount": "203"
},
{
"amount": "204",
"month": "2",
"areaname": "华东",
"year": "2020",
"price": "6",
"id": "44",
"dept": "天津",
"settleamount": "204"
},
{
"amount": "203",
"month": "1",
"areaname": "华东",
"year": "2021",
"price": "6",
"id": "45",
"dept": "天津",
"settleamount": "203"
},
{
"amount": "204",
"month": "2",
"areaname": "华东",
"year": "2021",
"price": "6",
"id": "46",
"dept": "天津",
"settleamount": "204"
}]
}
~~~
- 安装步骤
- 1.nacos配置文件
- 2.容器部署
- 3. 初始化数据库
- 操作手册
- 一、基础操作
- 1. 鉴权
- 2. 创建报表
- 3. 编辑报表
- 4. 背景设置
- 5. 复制、粘贴、剪切
- 6. 行操作
- 7. 添加数据源
- 8. 报表数据集
- 8.1 SQL数据集配置
- 8.2 API数据集配置
- 8.3 JavaBean数据集
- 8.4 对象数据集配置
- 8.5 集合数据集配置
- 8.6 JSON数据集配置
- 8.7 sql数据源解析失败弹窗
- 8.8 存储过程
- 8.9 Redis数据集
- 8.10 MongoDB数据集
- 9. 插入数据
- 10. 数据格式化设置
- 11. 数据字典配置
- 12. 导入报表
- 13. 导出报表
- 14. 分页设置
- 15. 报表集成
- 16. 分享报表
- 17.报表模版库
- 18.数据源查询默认值配置
- 19.自定义分页条数
- 20.报表定时保存配置
- 21.补全空白行
- 22.预览页工具条设置
- 23.动态合并格
- 二、打印设计
- 1.打印设置规则_重要
- 2. 打印区域设置
- 3. 打印清晰度设置
- 4. 打印机样式设置
- 5. 套打怎样设置
- 6. 带背景打印
- 三、数据报表设计
- 1. 分组
- 1.1 纵向分组(相邻合并)
- 1.2 横向分组(相邻合并)
- 1.3 横向动态列分组
- 1.4 横向纵向组合动态列分组
- 1.5 横向分组小计
- 1.6 分组内合计
- 1.7 纵向分组小计
- 1.8 常用分组示例
- 1.9 分组数据排序设置
- 2.查询条件
- 2.1 API查询条件配置
- 2.2 API查询条件为时间
- 2.3 API自定义查询条件
- 2.4 SQL配置查询条件
- 2.5 API接口后台接收参数说明
- 2.6 API范围查询
- 3.条形码/二维码
- 3.1 二维码配置说明
- 3.2 条形码配置说明
- 3.3 条形码和二维码改值
- 4.交叉报表
- 5.明细报表
- 6.主子报表
- 6.1 主子表API数据源(新)
- 6.2 主子表SQL数据源(新)
- 7.联动钻取
- 7.1 报表联动(新)
- 7.2 报表钻取(新)
- 7.3 报表钻取带条件用法
- 7.4 图表钻取带条件用法
- 7.5 报表联动图表带条件用法
- 7.6 图表联动图表带条件用法
- 7.7 钻取联动条件规则
- 8.组件交互清单
- 9.循环块设置
- 10.分栏设置
- 11.分版设置
- 12.多表头复杂报表
- 四、表达式函数
- 1. 数据集表达式
- 2. 单元格表达式
- 3. 统计函数
- 4. 行号函数
- 5. 日期函数
- 6. 数学函数
- 7. 字符串函数
- 8. 条件表达式
- 9. 颜色表达式
- 10. 判断函数
- 11. 函数库列表(高级)
- 12. 基本运算符(高级)
- 13. 自定义报表函数
- 五、报表查询配置
- 1. 报表参数配置
- 2. 报表查询配置
- 3. 查询控件类型
- 4. 查询控件默认值
- 5. 时间控件设置说明
- 6. 时间控件默认值设置
- 7. SQL中条件表达式
- 8. 查询控件下拉树
- 9. 范围查询设置默认值
- 10. JS增强和CSS增强
- 11. 技巧说明
- 12. 参数公用示例
- 六、图形报表设计
- 1. 基本配置
- 1.1 图表背景设置
- 1.2 图表动态刷新
- 1.3 图表之间的联动
- 2. 柱形图配置
- 2.1 数据源配置
- 2.1.1 单数据源配置
- 2.1.2 多数据源配置
- 3. 折线图配置
- 3.1 数据源配置
- 3.1.1 单数据源配置
- 3.1.2 多数据源配置
- 4. 饼图配置
- 4.1 数据源配置
- 5. 折柱图配置
- 5.1 数据源配置
- 6. 散点图配置
- 6.1 普通散点图数据源配置
- 6.2 气泡散点图数据源配置
- 7. 漏斗图配置
- 7.1 数据源配置
- 8. 象形图配置
- 8.1 数据源配置
- 9. 地图配置
- 9.1 地图区配置
- 9.2 数据源配置
- 10. 仪表盘配置
- 10.1 数据源配置
- 11. 雷达图配置
- 11.1 数据源配置
- 12. 关系图配置
- 12.1 数据源配置
- 七、其他
- 1. sql数据集 in查询
- 2. 联动/钻取配置说明
- 3. 数据集字段字典配置
- 4. 传参渲染到报表上
- 5. 钻取、联动条件用法
- 6. 导出图片支持背景导出
- 7. 模板示例补充表
- 快速入门
- 1. 整体页面布局介绍
- 2. SQL数据源报表制作
- 3. SQL数据源报表带参制作
- 4. API数据源报表制作
- 5. API数据源报表带参制作
- JDEasyWorkflow
