iReport子报告

时间:2011-11-30 10:30:06

标签: jasper-reports ireport subreport

我不确定将此内容放入哪个帖子中,如果不是这样的话,请指导我正确的。

我正在努力处理iReport中的子报告。

我有一个报告从MSSQL数据库中选择,并使用子报告从MySQL数据库中进行选择。我已经成功地完成了它(报告从MySQL中选择,子报告从MSSQL中选择),但这样做让我感到难过。

这就是我目前正在做的事情: 主报告(只是子报告标签,如果我需要发布有关主报告的更多信息,请告诉我。我替换了一些变量,我的工作需要我):

<subreport>
    <reportElement x="360" y="0" width="100" height="20"/>
    <subreportParameter name="ID">
        <subreportParameterExpression><![CDATA[$F{pkiCandidateID}]]></subreportParameterExpression>
    </subreportParameter>
    <connectionExpression><![CDATA[java.sql.DriverManager.getConnection("jdbc:mysql://<ip address>:3306/<db name>","<username>","<password>")]]></connectionExpression>
    <subreportExpression class="java.lang.String"><![CDATA["repo:/Enterprise/jrxml/Candidates/report1_subreport1.jrxml"]]></subreportExpression>
</subreport>

我收到的错误:

Error filling print... 
Error executing SQL statement for : report1_subreport1 
net.sf.jasperreports.engine.JRException: 
Error executing SQL statement for : report1_subreport1
    at net.sf.jasperreports.engine.query.JRJdbcQueryExecuter.createDatasource(JRJdbcQueryExecuter.java:143)
    at net.sf.jasperreports.engine.fill.JRFillDataset.createQueryDatasource(JRFillDataset.java:684)
    at net.sf.jasperreports.engine.fill.JRFillDataset.initDatasource(JRFillDataset.java:605)
    at net.sf.jasperreports.engine.fill.JRBaseFiller.setParameters(JRBaseFiller.java:1281)
    at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:901)
    at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:845)
    at net.sf.jasperreports.engine.fill.JRFiller.fillReport(JRFiller.java:58)
    at net.sf.jasperreports.engine.JasperFillManager.fillReport(JasperFillManager.java:417)
    at net.sf.jasperreports.engine.JasperFillManager.fillReport(JasperFillManager.java:247)
    at com.jaspersoft.ireport.designer.compiler.IReportCompiler.run(IReportCompiler.java:877)
    at org.openide.util.RequestProcessor$Task.run(RequestProcessor.java:572)
    at org.openide.util.RequestProcessor$Processor.run(RequestProcessor.java:997)
Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: Invalid object name 'tCandidate'.
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:196)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1454)
    at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.doExecutePreparedStatement(SQLServerPreparedStatement.java:388)
    at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement$PrepStmtExecCmd.doExecute(SQLServerPreparedStatement.java:338)
    at com.microsoft.sqlserver.jdbc.TDSCommand.execute(IOBuffer.java:4026)
    at com.microsoft.sqlserver.jdbc.SQLServerConnection.executeCommand(SQLServerConnection.java:1416)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeCommand(SQLServerStatement.java:185)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeStatement(SQLServerStatement.java:160)
    at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.executeQuery(SQLServerPreparedStatement.java:281)
    at net.sf.jasperreports.engine.query.JRJdbcQueryExecuter.createDatasource(JRJdbcQueryExecuter.java:137)
    ... 11 more 
Print not filled. Try to use an EmptyDataSource...

如果我需要提供更多信息,请告诉我。如果您知道我做错了什么,请帮帮我。这让我困扰了2天。

1 个答案:

答案 0 :(得分:1)

查看异常,它正在尝试使用MSSQL Server jdbc驱动程序。您确定首先注册了MySQL JDBC驱动程序吗?也许当您的应用程序启动时,或在执行尝试运行之前:

Class.forName("com.mysql.jdbc.Driver");

除此之外,您可以在调用报表之前在应用程序中构建连接,并将它们作为参数传递,您可以将其用于主报表,第二个可以传递到子报表。