该插件目前已下架帆软市场,本文档仅提供给历史使用了该插件的客户,帆软目前不再提供该插件的任何获取渠道。
|
1. 概述
1.1 版本
1.2 应用场景
Redis 缓存数据库作为最为的流行的缓存数据库之一,经常被使用在各种需要高速访问的场景下,偶尔也需要把缓存中的数据取出来做一些简单的查看和分析。但是 Redis 作为 NoSQL数据库,在 FineReport 中没有办法直接使用 JDBC 或者 JNDI 连接访问。
1.3 功能描述
Redis 插件使设计器连接 Redis 数据库并取数,且支持哈希表、列表、集合以及有序集合。
注:该插件仅支持在 设计器建立数据连接,不支持 [平台]数据连接 。
2. 插件介绍
2.1 插件安装
设计器插件安装方法请参见:设计器插件管理
服务器安装插件方法请参见:服务器插件管理
3. 示例
3.1 新建 Redis 数据连接
1)点击服务器>定义数据连接,如下图所示:

2)选择 Redis 并输入数据库地址、端口号和密码,如下图所示:

3)配置 Redis 连接的连接池信息,如下图所示:

4)如果当前报表服务器无法直接连接 Redis 服务器,而是需要通过跳板机器连接 Redis 服务器,则需要配置跳板服务器,如下图所示:

注意:一旦配置了跳板服务器,连接池配置即失效,只能使用单个连接。
3.2 Redis 数据集
3.2.1 新建 Redis 数据集
点击+,选择 Redis 数据集,如下图所示:

3.2.2 编写 Redis 查询语句
1)根据参数 $key ,查询 redis 中的值,相当于调用命令:get name ,如下图所示:

注意:左侧的列表是用于展示搜索出来的 key 值的,方便编写 SQL 语句的时候使用列出来的 key 值。
3.2.3 预览效果
查询预览结果如下图所示:

3.2.4 支持的命令
操作符 |
示例代码 |
说明 |
get |
get hellokey |
获取 hellokey 对应的值 |
mget |
mget foo bar zyx |
获取参数列表汇总所有的键对应的值 |
hkeys |
hkeys website |
获取指定哈希表中的所有键 |
hget |
hget site redis |
- |
hmget |
hmget pet dog cat |
返回哈希表key中,一个或多个给定域的值,可参考 http://redisdoc.com/hash/hmget.html |
hgetall |
hgetall contry |
获取哈希表中所有的键值对 |
lrange |
lrange score 0 -1 |
获取列表中指定位置的值 |
smembers |
smembers name |
获取无序列表中参数值对应的所有元素 |
zrange |
zrange |
- |
3.3 Redis 程序数据集
Redis 程序数据集,是使用支持 ES6 的 JavaScript 脚本语句,来从 Redis 查询数据并进行数据转换的数据集,该数据使用非常灵活,但需要有一定的 JavaScript 脚本知识。
注1:该类型的数据集需要使用 2019-03-10 之后的 JAR 包。
注2:在数据集中支持选择使用的引擎类型:V8引擎/Nashon 引擎
V8 为高速引擎,支持 ES6 语法,但低版本服务器可能不支持。默认为自带的引擎,效率较低但兼容性好。
注3:支持的引擎类型与Redis服务器有关,部分服务器版本不支持V8 引擎,可使用语句查看当前服务器使用的脚本引擎:
return merge([[console.engine()]], ["engine"]);
3.3.1 新建 Redis 程序数据集

3.3.2 编写 Redis 查询脚本
注意:脚本语句基于JavaScript,在使用前需要掌握一定的JavaScript基础,提供一个自学JS语言的网站仅供参考:JS学习
1)输入对应的脚本,进行数据集查询,如下图所示:

2)得到预览结果如下图所示:

3)同时也可以在脚本中传递参数,如下图中的 ${key} ,表示 key 是从报表中传递的参数,如下图所示:
注:查询脚本中使用的参数名字,和报表参数的名字不能相同,例如这里的key和name,是两个不同的名字。

3.3.3 内置函数和变量
注意:所有 Redis 函数均返回的是字符串,如果需要转换成数组或者对象,可以使用 JSON.parse() 函数将字符串转换为 JavaScript 对象。
3.3.4 执行外部脚本
在 Redis 程序数据集中,可以使用 Files.require(filePath) 来引入外部脚本文件,示例如下:
// 相对路径,读取的是 下的文件 // Files.require("");表示读取 C 盘下的文件 Files.require(""); return merge(content, column);
其中 query.js 文件的位置为:报表工作目录/resources/script/query.js。
使用相对路径的时候会读取报表工作目录下的文件,使用绝对路径时,会直接读取该文件。
|