活用参数搞定各种查询条件

在报表开发过程中,我们经常会用参数对数据进行过滤查询,具体的实现方式通常是在 sql 语句中 where 部分定义好针对哪个字段进行过滤,之后参数模板将不同的值传递给这个字段进行数据查询,返回不同的结果集供报表展现使用。常规的参数使用在教程文档中已经有介绍,这里不做赘述,小编今天只给大家分享两个一般人不知道的小技巧,能够提高报表开发效率及灵活性:

  • 数值为空查询全部数据
  • 动态参数(宏)怎么用

技巧一:参数值为空时怎么查询出全部的数据

在这里我们避免被组织发现(好怕怕)抓紧时间直接跳过画表样,建数据集,等等,开始说重点。首先看一下通常的查询数据集 sql 的设置,如下图:

其中,数据集 sql 中一个?代表一个参数对应一个字段名称,这样为了保证初次展现结果页面有数据就必须要要给参数赋默认值,而我们想要的是参数为空时查询全部数据,此时就需要在原有的参数设置基础上应用一个小技巧 –“or ? is null”,应用后数据集 sql 及参数设置如下:

修改后 2 个 ?对应同一个字段且数据集参数中 2 个参数表达式必须一致,且与 sql 语句中?顺序对应,实际的意思就是,两个问号都作用于员工姓名字段。这样简简单单两步修改后,就阔以实现参数为空时查询全部数据了。

掌握了这个小技能以后,我们接下来再看另一个参数使用的小技巧:

技巧二: ${参数名} 的用法,实例如下:

参数模板中选择要查询的数据表及对应字段,主表进行对应数据表数据的呈现。

相信大家看到这个效果图并不陌生,无非就是选择参数查询过滤,此处与以往不同的是,我们这里并非是针对固定的某个数据表的数据进行过滤筛选,而是选择不同的数据表进行呈现。

实现此效果的关键设置如下:

数据集中 sql 语句的设置

与通常数据集 sql 的写法不同的是我们这里并没有固定写死要查询的数据表及字段,而是使用了两次 ${参数名} 来代替原本要写的字段名称和数据表名。${参数名} 的用法是参数的一种特殊用法,经常在报表中动态地进行表达式的替换,快速实现动态执行语句的拼接。

同时,为了便于操作,这种用法也常常与参数模板结合使用。

回顾总结

然后….. 然后….. , 关于参数使用的小技巧我们先分享到这里,我们来回顾一下其中不为人知的秘密和操作:

1. 润乾中参数的标识符

【知识点】标识符为问号(?), 应用时参数定义注意参数个数顺序要与?对应。

2. 参数为空查询全部数据

【知识点】应用 or ? is null

3.${参数名}

【技巧】相当于占位,可以对 sql 语句的任何一部分进行替换,乃至整个 sql 语句定义。

至此,关于参数使用小技巧的分享就完了,get 了这个小技巧 ,做表的工作是不是越来越轻松了。
快来加入润乾大家庭,get 更多快速简便的报表制作方式吧。