我不确定将此内容放入哪个帖子中,如果不是这样的话,请指导我正确的。
我正在努力处理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天。
答案 0 :(得分:1)
查看异常,它正在尝试使用MSSQL Server jdbc驱动程序。您确定首先注册了MySQL JDBC驱动程序吗?也许当您的应用程序启动时,或在执行尝试运行之前:
Class.forName("com.mysql.jdbc.Driver");
除此之外,您可以在调用报表之前在应用程序中构建连接,并将它们作为参数传递,您可以将其用于主报表,第二个可以传递到子报表。