历史版本8 :NVL函数 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 函数用法编辑

NVL 函数的使用方法:NVL(value1,value2,value3,...):在所有参数中返回第一个不是 null 的值。

注:6.5 之前的版本 NVL 只支持 2 个参数,现在升级到支持多个参数。

下面以填报的示例来说明 NVL 多参数的用法。

2. 需求编辑

填报应用中,可能会遇到一组单元格中,只需将其中不为空的值保存至数据库的某个字段,如下图所示,对于语文成绩级别这个字段,可能有四个值,入库的时候只保存选择的级别。


3. 示例编辑

3.1 创建数据

在数据库中新建一个表,表名为 C,新建如下数据:

然后,添加其报表数据集 ds1,SQL 语句为:select * from C

3.2 表样设计

如下图所示,拖动字段到对应单元格并做相应合并:

image.png

3.3 控件设置

设置 B5、C5、E5、E6、E7、E8 为文本类型控件即可。

image.png

3.4 条件属性设置

对 E5 单元格,设置条件属性:不等于 4 时,公式为$$$!=4,赋新值为空,如下:

222

对 E6 单元格:设置为不等于 3 时,公式为$$$!=3,赋新值为空;

对 E7 单元格:设置为不等于 2 时,公式为$$$!=2赋新值为空;

对 E8 单元格:设置为不等于 1 时,公式为$$$!=1赋新值为空。

3.5 其他属性设置

为了保证“优秀”等不设置控件的单元格在添加记录时能默认添加,可设置单元格属性表-其他属性>插入行策略>原值,如下图:

image.png

3.6 报表填报属性设置

在 NUMBERQ 的值中,输入=NVL(E5,E6,E7,E8),取出第一个不为空的值进行填报,如下:

image.png

3.7 保存与预览模板

在设计器中,点击填报预览,效果:

222

点击增加记录后,点击提交,如下:
222


222

提交成功时,效果如下:
222

刷新页面,可见提交成功,提交值就是第一个不为空的值 3,如下:
222

4. 模板下载编辑

点击下载模板:NVL函数.cpt