보고서 데이터 소스

데이터 소스는 구조화 된 데이터 컨테이너입니다. 보고서를 생성하는 동안 JasperReports 엔진은 데이터 소스에서 데이터를 가져옵니다. 데이터는 데이터베이스, XML 파일, 개체 배열 및 개체 컬렉션에서 얻을 수 있습니다. Filling Reports 장에서 보았습니다 . fillReportXXX () 메서드는 다음과 같은 형식으로 채워야하는 보고서의 데이터 소스를받을 것으로 예상합니다.net.sf.jasperreports.engine.JRDataSource 개체 또는 java.sql.Connection (보고서 데이터가 관계형 데이터베이스에서 발견되는 경우).

JRDataSource 인터페이스에는 구현해야하는 두 가지 메소드 만 있습니다.

  • public boolean next ()는 JRException을 던집니다.

    • 보고서 작성 시간에이 메서드는 데이터를 반복 할 때보고 엔진에 의해 데이터 원본 개체에서 호출됩니다.

  • public Object getFieldValue (JRField jrField)가 JRException을 발생시킵니다.

    • 이 메소드는 현재 데이터 소스 레코드의 각 보고서 필드에 대한 값을 제공합니다.

데이터 소스에서 데이터를 검색하는 유일한 방법은 보고서 필드를 사용하는 것입니다. 데이터 소스의 레코드를 획득하는 방법에 따라 JRDataSource 인터페이스의 몇 가지 기본 구현이 있습니다.

데이터 소스 구현

아래 표는 데이터 소스와 그 구현 클래스를 요약 한 것입니다.

데이터 소스 구현 클래스
JDBC net.sf.jasperreports.engine.JRResultSetDataSource
자바빈 net.sf.jasperreports.engine.data.JRBeanCollectionDataSource, net.sf.jasperreports.engine.data.JRBeanArrayDataSource
지도 기반 net.sf.jasperreports.engine.data.JRMapArrayDataSource, net.sf.jasperreports.engine.data.JRMapCollectionDataSource
TableModel net.sf.jasperreports.engine.data.JRTableModelDataSource
XML net.sf.jasperreports.engine.data.JRXmlDataSource
CSV net.sf.jasperreports.engine.data.JRCsvDataSource
XLS net.sf.jasperreports.engine.data.JRXlsDataSource
net.sf.jasperreports.engine.JREmptyDataSource

JDBC 데이터 소스

수업 JRResultSetDataSourcejava.sql.ResultSet 객체를 크랩 합니다. 이것은 관계형 데이터베이스에서 보고서 데이터를 추출 할 때 가장 일반적으로 사용되는 데이터 소스 구현입니다. java.sql.Connection 이 대신 엔진에 전달 되면 먼저 관련 쿼리를 실행하고 반환 된 java.sql.ResultSet 객체를 JRResultSetDataSource 인스턴스에 저장합니다 .

JavaBean 데이터 소스

클래스 JRBeanArrayDataSourceJRBeanCollectionDataSourceJavaBean 객체의 배열 및 컬렉션을 래핑 할 수있는 구현을 나타냅니다. 배열 또는 컬렉션 내의 각 개체는 이러한 유형의 데이터 소스에서 하나의 레코드로 표시됩니다. 특정 JavaBean 속성과 해당 보고서 필드 간의 매핑은 명명 규칙에 따라 이루어집니다. 보고서 필드의 이름은 JavaBeans 사양에 지정된 JavaBean 속성의 이름과 동일해야합니다.

이 튜토리얼의 모든 예제에서 우리는 JRBeanCollectionDataSource를 사용했습니다.

지도 기반 데이터 소스

구현 클래스 JRMapArrayDataSourceJRMapCollectionDataSource부모 애플리케이션이 이미 메모리 내에서 사용 가능한보고 데이터를 java.util.Map 개체 로 저장 한 경우 유용 합니다 . 래핑 된 배열 또는 컬렉션의 각 Map 개체는 데이터 원본의 가상 레코드로 간주되며 각 보고서 필드의 값은 키로 명명 된 보고서 필드를 사용하여 맵에서 추출됩니다.

TableModel 데이터 소스

많은 클라이언트 측 애플리케이션에서 데이터는 표 형식으로 표시됩니다. 많은 응용 프로그램에서 일반적인 요구 사항은 사용자가이 표 형식을 보고서로 인쇄 할 수 있도록하는 것입니다. 구현 클래스JRTableModelDataSourceSwing 애플리케이션에 대한 간단한 표 형식으로 보고서를 생성하는 작업을 수행합니다. 이 클래스는 javax.swing.table.TableModel 객체를 래핑합니다. 래핑 된 TableModel 개체의 열은 이름 또는 0 기반 인덱스로 액세스 할 수 있습니다.

XML 데이터 소스

수업 JRXmlDataSourceDOM 기반 데이터 소스 구현으로, XPath 표현식을 사용하여 XML 문서에서 데이터를 선택합니다. XML 데이터 소스의 레코드는 XPath 표현식을 통해 선택된 노드 요소로 표시됩니다. 필드 값은 필드 설명 (JRXML의 <fieldDescription> 요소)에서 제공하는 XPath 표현식을 사용하여 각 레코드에서 검색됩니다.

XPath는 XML 문서의 속성 및 요소를 탐색하는 데 사용되는 언어입니다. XPath에 대한 자세한 정보는http://www.w3.org/TR/xpath.

CSV 데이터 소스

JRCsvDataSource구조화 된 텍스트 파일에서 데이터를 검색하는 데이터 소스의 구현을 나타냅니다. 일반적으로 CSV. 필드 값은 열 인덱스를 사용하여 검색됩니다.

XLS 데이터 소스

JRXlsDataSourceExcel 문서에서 데이터를 검색하는 데이터 소스의 구현을 나타냅니다. 이 데이터 소스 구현에 대한 보고서 필드 매핑도 필드 열 인덱스를 기반으로합니다.

빈 데이터 소스

클래스 JREmptyDataSource, 주어진 수의 가상 빈 레코드가 내부에있는 데이터 소스를 시뮬레이션합니다. UI 도구에서 기본 보고서 미리보기 기능을 제공하거나 특수 보고서 템플릿에서 또는 테스트 및 디버깅 목적으로 사용됩니다.

되감기 가능한 데이터 소스

그만큼 net.sf.jasperreports.engine.JRRewindableDataSource기본 JRDataSource 인터페이스를 확장합니다 . 인터페이스에 moveFirst ()라는 하나의 메소드 만 추가합니다. 이 메서드는 커서를 데이터 소스의 첫 번째 요소로 이동하기위한 것입니다.

되감기 가능한 데이터 원본은 isSplitAllowed = "false"설정으로 인해 분할이 허용되지 않는 밴드 내부에 배치 된 하위 보고서로 작업 할 때 유용하며 현재 페이지에 하위 보고서를 렌더링 할 공간이 충분하지 않습니다.

위의 모든 데이터 소스 구현은 JRResultSetDataSource, 레코드 포인터를 뒤로 이동하는 것을 지원하지 않기 때문입니다. 이는 하위 보고서에 전달하기 전에이 데이터 소스를 수동으로 사용하여 java.sql.ResultSet을 래핑하는 경우에만 문제가됩니다. SQL 쿼리가 하위 보고서 템플릿에 있으면 다음 페이지에서 하위 보고서를 다시 시작할 때 엔진이 다시 실행하므로 문제가 없습니다.

데이터 소스 공급자

JasperReports 라이브러리에는 인터페이스가 있습니다. net.sf.jasperreports.engine.JRDataSourceProvider. 이렇게하면 데이터 소스 개체를 만들고 삭제하는 데 도움이됩니다. GUI 도구를 사용하여 보고서 템플릿을 만들 때 보고서의 데이터 소스를 사용자 지정하기위한 특수 도구가 필요합니다. JRDataSourceProvider는 사용자 정의 데이터 소스를 디자인 도구에 연결하는 표준 방법입니다. 이 인터페이스의 사용자 정의 구현은 데이터 소스 객체의 생성 및 폐기를 허용하는 다음 메소드를 구현해야하며 가능하면 데이터 소스 내에 사용 가능한 보고서 필드를 나열하는 메소드도 구현해야합니다.

public boolean supportsGetFieldsOperation();

public JRField[] getFields(JasperReport report)
   throws JRException, UnsupportedOperationException;

public JRDataSource create(JasperReport report) throws JRException;

public void dispose(JRDataSource dataSource) throws JRException;