Domanda

Provo a utilizzare Groovy per il mio report per connettere una sottodataset a un database Oracle.

-> In Report> Proprietà> Lingua: Groovy

-> Nel mio set di dati scelgo "Usa un'altra connessione" con l'espressione:

Sql.newInstance(
                    "jdbc:oracle:thin:@ip:1521:XE",
                    "user",
                    "pw",
                    "oracle.jdbc.driver.OracleDriver"
                )
.

I miei parametri (IP, Porta, Utente, Password) sono corretti, ho già fatto questo Java e funziona, ma ho bisogno di farlo con Groovy: (

Quando in anteprima il report (usando Groovy) ottengo questo seguente errore:

net.sf.jasperreports.engine.JRException: net.sf.jasperreports.engine.fill.JRExpressionEvalException: Error evaluating expression :
    Source text : Sql.newInstance(

                    "jdbc:oracle:thin:@ip:1521:XE",

                    "user",

                    "pw",

                    "oracle.jdbc.driver.OracleDriver"

                )

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler.fillReport(ReportControler.java:466)

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler.access$18(ReportControler.java:441)

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler$4.run(ReportControler.java:333)

    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:53)

Caused by: net.sf.jasperreports.engine.fill.JRExpressionEvalException: Error evaluating expression :
    Source text : Sql.newInstance(

                    "jdbc:oracle:thin:@ip:1521:XE",

                    "user",

                    "pw",

                    "oracle.jdbc.driver.OracleDriver"

                )

    at net.sf.jasperreports.engine.fill.JREvaluator.evaluate(JREvaluator.java:263)

    at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:611)

    at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:579)

    at net.sf.jasperreports.engine.fill.JRFillElement.evaluateExpression(JRFillElement.java:1016)

    at net.sf.jasperreports.engine.fill.JRFillSubreport.evaluateSubreport(JRFillSubreport.java:392)

    at net.sf.jasperreports.components.table.fill.FillTableSubreport.evaluateSubreport(FillTableSubreport.java:92)

    at net.sf.jasperreports.components.table.fill.FillTable.evaluate(FillTable.java:118)

    at net.sf.jasperreports.engine.fill.JRFillComponentElement.evaluate(JRFillComponentElement.java:110)

    at net.sf.jasperreports.engine.fill.JRFillElementContainer.evaluate(JRFillElementContainer.java:259)

    at net.sf.jasperreports.engine.fill.JRFillBand.evaluate(JRFillBand.java:456)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillColumnBand(JRVerticalFiller.java:2067)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillDetail(JRVerticalFiller.java:788)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReportStart(JRVerticalFiller.java:298)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReport(JRVerticalFiller.java:152)

    at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:963)

    at net.sf.jasperreports.engine.fill.BaseFillHandle$ReportFiller.run(BaseFillHandle.java:120)

    at java.lang.Thread.run(Unknown Source)

Caused by: groovy.lang.MissingPropertyException: No such property: Sql for class: reportFacturation_1406640568882_851084

    at org.codehaus.groovy.runtime.ScriptBytecodeAdapter.unwrap(ScriptBytecodeAdapter.java:50)

    at org.codehaus.groovy.runtime.callsite.GetEffectivePogoPropertySite.getProperty(GetEffectivePogoPropertySite.java:86)

    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callGroovyObjectGetProperty(AbstractCallSite.java:231)

    at reportFacturation_1406640568882_851084.evaluate(calculator_reportFacturation_1406640568882_851084:263)

    at net.sf.jasperreports.engine.fill.JREvaluator.evaluate(JREvaluator.java:250)

    ... 16 more
.

Prima di tutto, grazie per le tue risposte.

groovy.sql.Sql.newInstance("jdbc:oracle:thin:@ip:1521:XE", "user", "pw", "oracle.jdbc.driver.OracleDriver")
.

Sembra essere la buona espressione: funziona quando provo a connettermi al mio database con GroovyConsole.bat.

Ma sono sempre andati a connetterti al mio database Oracle da Jasperstudio e non so perché.

Ho avuto ojdbc14-1.0.jar al mio percorso di costruzione (stesso vaso che ho usato con Java JDBC Connection e funzionava)

Ho avuto Groovy-SQL-2.3.6.jar al mio percorso di costruzione (poi tutto .jar da Groovy perché ero "senza speranza" ma non ha cambiato nulla)

-> In Report> Proprietà> Lingua: Groovy

-> Nel mio set di dati scelgo "Usa un'altra connessione" con l'espressione:

groovy.sql.Sql.newInstance("jdbc:oracle:thin:@ip:1521:XE", "user", "pw", "oracle.jdbc.driver.OracleDriver")
.

Non funziona ancora, ottengo il seguente errore nel palcoscenico "Rapporto di riempimento" dopo l'anteprima:

    net.sf.jasperreports.engine.JRException: net.sf.jasperreports.engine.fill.JRExpressionEvalException: Error evaluating expression : 
    Source text : groovy.sql.Sql.newInstance("jdbc:oracle:thin:@ip:1521:XE", "user", "pw", "oracle.jdbc.driver.OracleDriver")

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler.fillReport(ReportControler.java:466)

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler.access$18(ReportControler.java:441)

    at com.jaspersoft.studio.editor.preview.view.control.ReportControler$4.run(ReportControler.java:333)

    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:53)

Caused by: net.sf.jasperreports.engine.fill.JRExpressionEvalException: Error evaluating expression : 
    Source text : groovy.sql.Sql.newInstance("jdbc:oracle:thin:@ip:1521:XE", "user", "pw", "oracle.jdbc.driver.OracleDriver")

    at net.sf.jasperreports.engine.fill.JREvaluator.evaluate(JREvaluator.java:263)

    at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:611)

    at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:579)

    at net.sf.jasperreports.engine.fill.JRFillElement.evaluateExpression(JRFillElement.java:1016)

    at net.sf.jasperreports.engine.fill.JRFillSubreport.evaluateSubreport(JRFillSubreport.java:392)

    at net.sf.jasperreports.components.table.fill.FillTableSubreport.evaluateSubreport(FillTableSubreport.java:92)

    at net.sf.jasperreports.components.table.fill.FillTable.evaluate(FillTable.java:118)

    at net.sf.jasperreports.engine.fill.JRFillComponentElement.evaluate(JRFillComponentElement.java:110)

    at net.sf.jasperreports.engine.fill.JRFillElementContainer.evaluate(JRFillElementContainer.java:259)

    at net.sf.jasperreports.engine.fill.JRFillBand.evaluate(JRFillBand.java:456)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillColumnBand(JRVerticalFiller.java:2067)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillDetail(JRVerticalFiller.java:788)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReportStart(JRVerticalFiller.java:298)

    at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReport(JRVerticalFiller.java:152)

    at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:963)

    at net.sf.jasperreports.engine.fill.BaseFillHandle$ReportFiller.run(BaseFillHandle.java:120)

    at java.lang.Thread.run(Unknown Source)

Caused by: java.sql.SQLException: No suitable driver found for jdbc:oracle:thin:@ip:1521:XE

    at java.sql.DriverManager.getConnection(Unknown Source)

    at java.sql.DriverManager.getConnection(Unknown Source)

    at groovy.sql.Sql.newInstance(Sql.java:398)

    at groovy.sql.Sql.newInstance(Sql.java:442)

    at groovy.sql.Sql$newInstance.call(Unknown Source)

    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)

    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:108)

    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:128)

    at reportFacturation_1406728137596_951810.evaluate(calculator_reportFacturation_1406728137596_951810:263)

    at net.sf.jasperreports.engine.fill.JREvaluator.evaluate(JREvaluator.java:250)

    ... 16 more
.

Provo anche con "/ XE" ma non funziona neanche.

Non so cosa sto facendo male, qualsiasi idea?

Grazie per l'aiuto! :)

È stato utile?

Soluzione

Sostituisci questo:

Sql.newInstance(
                "jdbc:oracle:thin:@ip:1521:XE",
                "user",
                "pw",
                "oracle.jdbc.driver.OracleDriver"
               )
.

Con questo:

groovy.sql.Sql.newInstance("jdbc:oracle:thin:@ip:1521:XE", "user", "pw", 
        "oracle.jdbc.driver.OracleDriver")
.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top