birt动态SQL实现有三种方式:拼接SQL、绑定变量和让应用程序拼接,birt得到返回结果集方式。
1.拼接SQL方式
在数据集中写SQL,如下:
select id ,code,name,type from type
选中数据集,点script方式,在beforeOpen事件中写如下SQL:
var type = reportContext.getParameterValue("type"); var name = reportContext.getParameterValue("name"); var query = this.queryText; if(type!=null){ query = query + " and type = "+type; } if(name!=null&&name!=""){ query = query + " and name = '"+name+"'"; } this.queryText = query;
然后就可以了,当然,也可以不写第一步,直接所有的SQL都在beforeOpen中拼接。
但是,拼接SQL方式不仅复杂容易错,还会导致SQL注入风险。
2.绑定变量方式
在数据集的SQL中写如下SQL
select id ,code,name,type from location where (type = ? or ? is null ) and ( name = ? or ? is null )
然后配置数据集的参数,如下图:
最后一项是链接报表的参数。倒数第二项是默认值,填null
这种方式不会有SQL注入风险。
要注意参数与问号个数要相同
当采用绑定变量时,数据集参数和报表参数关联时,可能会出现这样的异常:
org.eclipse.birt.report.data.oda.jdbc.JDBCException: Cannot set preparedStatement null value.
原因是数据集参数中不能将Intger 类型设置为null值,要解决这个问题,可以将
Intger 类型的参数全部改成DECIMAL,原因待研究。
另外如果想要查看执行的SQL,可以在数据集的SCRIPT的beforeOpen事件写如下脚本:
importPackage( Packages.java.io ); out = new PrintWriter( new FileWriter("c:/debuginfo.txt", true ) ); out.println("queryText:-->"+ this.queryText); out.close();
第三种是在应该程序处理查询,BIRT负责取出结果集展示,采用的是BIRT+SPRING+MYBATIS。
当然这里MYBATIS也可以是其它框架,思路一样。
BirtBeanFactory.java
public class BirtBeanFactory { private static BeanFactory ctx; public synchronized static void setBeanFactory(BeanFactory beanFactory) { ctx = beanFactory; } public static Object getBean(String str) { return ctx.getBean(str); } public static <T> T getBean(Class<T> clazz) { return ctx.getBean(clazz); } }
GlobalInitializer.java
public class GlobalInitializer implements InitializingBean ,BeanFactoryAware{ private BeanFactory beanFactory; @Override public void afterPropertiesSet() throws Exception { BirtBeanFactory.setBeanFactory(beanFactory); } @Override public void setBeanFactory(BeanFactory beanFactory) throws BeansException { this.beanFactory = beanFactory; } }
BirtDataFactory.java
public class BirtDataFactory { private TestService manager = (TestService) BirtBeanFactory.getBean(TestService.class); public List<Location> findListByDto(LocationDto dto){ return manager.findListByDto(dto); } }
spring配置文件配置下:
<bean id="globalInitializer" class="com.test.birt.core.GlobalInitializer"/>
这样代码层就完成了,
在birt中创建脚本数据源
创建脚本数据集,在数据集的open事件中写这样的方法:
importPackage(Packages.com.test.birt.core); importPackage(Packages.com.test.birt.report.dto); factory = new BirtDataFactory(); dto = new TestDto(); dto.setCreateTimeStart(reportContext.getParameterValue("createTimeStart")); dto.setCreateTimeEnd(reportContext.getParameterValue("createTimeEnd")); if(reportContext.getParameterValue("dcId")!=null){ dto.setDcId(reportContext.getParameterValue("dcId").longValue()); } collectList=factory.findListByDto(dto); iterator = collectList.iterator();
在fecth阶段,写这样 的代码:
if(iterator.hasNext() == false ){ return false; } else{ var collectBean = iterator.next(); row["id"]=collectBean.getId(); row["name"] = collectBean.getName(); return true; }
这样就可以了。
要显示的字段(row["id"]等)可以在数据集中编辑,选中数据集--EDIT--OUTPUT COLUMNS---ADD
相关推荐
fire bird常用sql语句 一、分页写法小例: 二、显示表名和表结构 三、使用ISQL连接数据库 四、更新字段注释 五、显示字段注释 六、更新表注释 七、查询所有的表和视图(包括系统表和系统视图) 八、查询所有的用户表...
Text2SQL_语义解析数据集、解决方案、paper资源整合项目_NL2SQL
开发者需要了解如何使用Java的JDBC(Java Database Connectivity)接口连接到数据库,执行SQL查询和操作数据。 6. **Excel处理**:项目中提到了使用第三方库处理Excel表格。Java有许多库,如Apache POI,可以读写...
FlyBird Database Manager 是一款MySQL管理工具。 推荐度5颗星,非常值的尝试的MySQL管理软件。 优点有: 免安装, 基于浏览器,支持导出Excel, CSV, SQL多种格式数据。 相比navicat dbeaver , workbench 更加轻量化...
《全面解析:蛋蛋助手v1.50与DOscan及Bird工具的综合应用》 在信息技术领域,软件工具的高效使用是提升工作效率的关键。本文将深入探讨“蛋蛋助手v1.50”、“DOscan”以及“Bird”这三款工具的功能特性及其在实际...
SQL> connect sys/redbird@kt6zt1 as sysdba; SQL> select table_name from dba_tables; ``` #### 4. 数据字典内容 接下来我们将详细介绍如何利用数据字典进行不同类型的查询。 - **对象定义查询**:获取指定...
这使得Hive用户可以在不先解压缩的情况下,对压缩数据进行SQL查询,提高了数据仓库的效率。 六、HBase Integration 对于NoSQL数据库HBase,Elephant Bird提供了对LZO和protobuf的支持,包括对列族的配置和数据读写...
FlyBird Database Manager 是一款MySQL管理工具。 推荐度5颗星,非常值的尝试的MySQL管理软件。 优点有: 免安装, 基于浏览器,支持导出Excel, CSV, SQL多种格式数据。 相比navicat dbeaver , workbench 更加轻量化...
FlyBird Database Manager 是一款MySQL管理工具。 推荐度5颗星,非常值的尝试的MySQL管理软件。 优点有: 免安装, 基于浏览器,支持导出Excel, CSV, SQL多种格式数据。 相比navicat dbeaver , workbench 更加轻量化...
FlyBird Database Manager 是一款MySQL管理工具。 推荐度5颗星,非常值的尝试的MySQL管理软件。 优点有: 免安装, 基于浏览器,支持导出Excel, CSV, SQL多种格式数据。 相比navicat dbeaver , workbench 更加轻量化...
它支持多种操作系统,包括Windows、Linux、macOS等,且提供了丰富的API和SQL标准支持,适用于各种开发环境。火鸟数据库以其高效的性能、强大的安全特性和易于管理的特点,在中小型企业以及开发人员中广受欢迎。 **...
数据库技术:如关系型数据库(如MySQL、Oracle、SQL Server)和非关系型数据库(如MongoDB、Redis)等。 前端开发:HTML、CSS、JavaScript等用于构建网页和Web应用程序的技术。 后端开发:涉及服务器端编程、API开发...
- **BCNF(Bird-Chen Normal Form)**:进一步消除非主属性对候选键的依赖。 - **第四范式(4NF)**:消除多值依赖。 - **第五范式(5NF)**:又称为投影-连接范式,确保分解后的表仍然保持原有的数据关系。 #### 六、...
T-SQL,语句大全,涵盖了T-SQL的常用的语法,还有实例解释,非常不错的..........
ClickHouse 中的投影(Projections)是一种优化查询执行的技术,由 Amos Bird 在 ClickHouse PPT 中详细介绍。下面是 ClickHouse 中投影的相关知识点: 一、什么是投影(What is a Projection?) 投影是一种存储...
sqlqs-SQL查询字符串 SQL谓词解析器的一个非常简单且基本的查询...用 const { parse , sqlize , where } = require ( 'sqlqs' )let qs = { class : 'in.Mammal,Bird' , genus : 'eq.Neotoma' , id : 'gt.1000'}// par
在数据库上执行sql表达式并显示结果 通过csv格式的文件导入和导出数据 浏览表和视图的内容,看着他们在输入数据时不断增长 在浏览表时选择要删除和编辑的数据 插入,删除,显示Blob字段的内容 播放数据库元数据,...
2. **参数绑定**:将参数与数据集查询或SQL语句关联,以便根据参数值动态调整查询条件。例如,可以将日期参数绑定到查询的WHERE子句中,只显示选定日期范围内的数据。 3. **参数传递**:在运行报表时,用户可以在弹...
谷歌师兄的leetcode刷题...SQL)。 这个位 - 带有用于测试的 GUI - 将事件读取和写入 Lightning 日历 SQLite 数据库。 有太多事情需要我去查阅(堆栈溢出等),我觉得有必要分享结果。 很快就会有一个Android客户端。
对于复杂的交叉表,通常会用到SQL查询数据集,因为它允许我们灵活地选择和组合数据。 进入交叉报表的设计阶段,BIRT提供了直观的CrossTab Editor。在这个编辑器中,你可以定义行区、列区以及值区域。行区和列区分别...