反饋已提交
網絡繁忙
Redis 缓存数据库作为最为的流行的缓存数据库之一,经常被使用在各种需要高速访问的场景下,偶尔也需要把缓存中的数据取出来做一些简单的查看和分析。但是 Redis 作为 NoSQL数据库,在 FineReport 中没有办法直接使用 JDBC 或者 JNDI 连接访问。
Redis 插件使设计器连接 Redis 数据库并取数,且支持哈希表、列表、集合以及有序集合。
注:该插件仅支持在 设计器建立数据连接,不支持 [平台]数据连接 。
点击下载插件:Redis数据集
设计器插件安装方法请参见:设计器插件管理
服务器安装插件方法请参见:服务器插件管理
1)点击服务器>定义数据连接,如下图所示:
2)选择 Redis 并输入数据库地址、端口号和密码,如下图所示:
3)配置 Redis 连接的连接池信息,如下图所示:
4)如果当前报表服务器无法直接连接 Redis 服务器,而是需要通过跳板机器连接 Redis 服务器,则需要配置跳板服务器,如下图所示:
注意:一旦配置了跳板服务器,连接池配置即失效,只能使用单个连接。
点击+,选择 Redis 数据集,如下图所示:
1)根据参数 $key ,查询 redis 中的值,相当于调用命令:get name ,如下图所示:
注意:左侧的列表是用于展示搜索出来的 key 值的,方便编写 SQL 语句的时候使用列出来的 key 值。
查询预览结果如下图所示:
Redis 程序数据集,是使用支持 ES6 的 JavaScript 脚本语句,来从 Redis 查询数据并进行数据转换的数据集,该数据使用非常灵活,但需要有一定的 JavaScript 脚本知识。
注1:该类型的数据集需要使用 2019-03-10 之后的 JAR 包。
注2:可以在数据集中选择使用的引擎类型,V8 为高速引擎,支持 ES6 语法,但低版本 Linux 服务器可能不支持,默认为 JRE 自带的引擎,效率较低但兼容性好。
注3:如果服务器不支持 V8 引擎,会降级为使用 JDK 内置的 Nashon 引擎,只能使用 ES5 语法。
注4:可以使用脚本语句 return merge([[console.engine()]], ["engine"]); 查看当前服务器使用的脚本引擎。
注意:脚本语句基于JavaScript,在使用前需要掌握一定的JavaScript基础,提供一个自学JS语言的网站仅供参考:JS学习
1)输入对应的脚本,进行数据集查询,如下图所示:
2)得到预览结果如下图所示:
3)同时也可以在脚本中传递参数,如下图中的 ${key} ,表示 key 是从报表中传递的参数,如下图所示:
注意:查询脚本中使用的参数名字,和报表参数的名字不能相同,例如这里的key和name,是两个不同的名字。
名称
作用
类型
注意事项
注意:所有 Redis 函数均返回的是字符串,如果需要转换成数组或者对象,可以使用 JSON.parse() 函数将字符串转换为 JavaScript 对象。
在 Redis 程序数据集中,可以使用 Files.require(filePath) 来引入外部脚本文件,示例如下:
// 相对路径,读取的是 下的文件// Files.require("");表示读取 C 盘下的文件Files.require("");return merge(content, column);
其中 query.js 文件的位置为:报表工作目录/resources/script/query.js。
使用相对路径的时候会读取报表工作目录下的文件,使用绝对路径时,会直接读取该文件。
文 檔回 饋
滑鼠選中內容,快速回饋問題
滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。
不再提示
10s後關閉