历史版本4 :Excel增量导入时实现序号自增 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 问题描述

数据库表里已经有序号的情况下,增量导入数据时导入后发现序号从 1 开始。如下图所示:

如果想要延续之前的序号进行排序,该如何实现呢?

1.2 解决方案

使用层次坐标公式 Cellx[Celly:z] + 1获取 Celly 扩展出来的第 z 个值对应的 Cellx 值并加 1。将 z 置为 -1,则为获取每次扩展出来的最后一个数,再加 1 生成序号 。

2. 示例编辑

2.1 数据准备

新建数据集 ds1,数据库查询对话框中写入 SQL 查询语句:SELECT * FROM 产品类别。如下图所示:

2.2 报表设计

1)将数据集字段拖入单元格,A2 单元格添加「数字控件」,B2、C2单元格添加「文本控件」,设计报表样式。如下图所示:

2)选中 A2 单元格,为其添加一个条件属性。属性类别为「新值」:A2[A2:-1]+1判断类型为公式: len($$$)==0

实现当 A2 列序号空白时以层次坐标 A2[A2:-1]+1 新增序号。如下图所示:

公式说明:

A2[A2:-1]+1:获取 A2 单元格扩展出来的最后一个值并加 1

len($$$)==0:当前单元格为空

2.3 设置填报属性

给模板添加填报属性,如下图所示:

2.4 效果预览

准备一个 Excel 文件,其中没有序号列。如下图所示:

点击可下载 Excel:层次坐标实现序号正向自增.xlsx

注:要使用没有序号列的 Excel 文件,否则有序号列会覆盖公式,使其不生效。

保存模板,点击「填报预览」,点击增量导入,选择 Excel 文件后即可将文件导入,导入后生成连续的序号。如下图所示:

注:不支持移动端。

3. 模板下载编辑

已完成的模板,可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\SpecialSubject\ExcelImport\Excel增量导入时实现序号自增.cpt

点击下载模板:Excel增量导入时实现序号自增.cpt