Visualizzazione post con etichetta ireport. Mostra tutti i post
Visualizzazione post con etichetta ireport. Mostra tutti i post

mercoledì 24 giugno 2009

JasperServer e iReport: Collegamento ad un database Oracle

Oggi mi è arrivata una nuova richiesta. Creare un report che potesse prendere dati da una fonte Oracle e non Mysql.
Come sempre partendo dalla documentazione web ho subito verificato che la cosa fosse possibile.

Quindi sono entrato nella creazione dei Data Source e ho iniziato a configurare per primo iReport.
La connessione è stata così configurata:
Driver:
oracle.jdbc.driver.OracleDriver
URL:
jdbc:oracle:thin:@Indirizzo_IP_Server:Porta_Server:Nome_DataBase
(usare l'IP del server per evitare problemi sulla network interface e non i nomi WINS es: nomeserver.dominio)

Ovviamente user e password.
E qui iniziano i problemi. Perchè anche se i parametri sono tutti corretti riceviamo un messaggio di errore sulle classi java.
E' necessario scaricare la classe java apposita per la comunicazione.
Il pacchetto è:
ojdbc14.jar
Ne ho trovato una versione scaricabile senza effettuare registrazioni di sorta su www.findjar.com.
Questo pacchetto va messo nelle directory:
X:\Programmi\jasperserver-3.0\ireport\lib (iReport)
X:\Programmi\jasperserver-3.0\apache-tomcat\common\lib
(JasperServer)
Riavviando Jasperserver sarà possibile inizializzare i Data Source necessari.
Buon lavoro.

Wsc

martedì 26 maggio 2009

JasperServer e iReport: Inserimento delle immagini nei report

Per la prima volta oggi mi sono trovato a dover gestire l'inserimento di immagine statiche in un report. Come al solito è stato il solito delirio per riuscire a trovare una risposta.
I manuali sono sempre molto poco ricchi e spiegano spesso male o in maniera incompleta le procedure.

Ad ogni modo siamo arrivati ad una risposta.

Innanzitutto le immagini possono essere caricate come risorsa legata al singolo report oppure inserita nella Cartella Images della Repository di JasperServer.

Ci verranno chiesti un nome per la risorsa, una label e una breve descrizione.

Una volta caricato il file non ci resta che legarlo nel report.
Aggiungiamo quindi un oggetto immagine nel layout delle immagini e per linkarlo all'immagine caricata entriamo nel cammpo Expression e qui usiamo la seguente sintassi:
"repo:nome_risorsa"
Ora il nostro report visualizzarà correttamente l'immagine.
Buon lavoro a tutti. Alla prossima difficoltà.

Wsc

martedì 24 marzo 2009

JasperServer e iReport: Tabelle a nome variabile nei dataset

Oggi ho avuto una nuova problematica da affrontare nell'utilizzo di JasperServer e iReport.

Avevo necessità che l'utente potesse in qualche modo parametrizzare tutto o in parte in nome di una tabella sulla quale far girare il report. Nel caso specifico sul lavor creiamo delle tabelle giornaliere che hanno un nome formato come segue:
DataBase.Piattaforma _090324
Quindi il problema era passare la data al report in modo che l'utente potesse con un singolo report, e senza create procedure particolari al livello di db, interrogare più di una tabella a secondo del giorno di interesse.
La cosa più ovvia era che la parte variabile venisse passata tramite un parametro al report e quindi gioco forza il primo tentativo è stato quello di provare la seguente sintassi, dove il parametro veniva passato come stringa:
SELECT * FROM DataBase.Piattaforma _$P{DataTabella}
Ovviamente l'esperimento ha prodotto un errore, ma devo dire che la soluzione era a portata di mano. Il trucco sta nell'aggiungere un "!" dopo $P:
SELECT * FROM DataBase.Piattaforma _$P!{DataTabella}
Così facendo il tutto funziona perchè il motore effettua la sostituzione del parametro con il suo valore inserito dall'utente prima di inviare la query.

Spero di avervi aiutato anche questa volta.

Wsc

lunedì 16 marzo 2009

JasperServer e iReport: linkare i report tra di loro

Utilizzando Google Analytics ho notato che all'interno del mio blog gli articoli più interessanti per il pubblico siano quelli incentratti sull'argomento Jasper Server e iReport.

Altra funzione che ho usato ultimamente è la possibilità di poter linkare tra loro diversi report.
iReport ci permette di inserire dei link legati ai vari oggetti che compongono il nostro template. Si possono precificare delle URL e quindi possiamo linkare tra loro report già realizzati.

Si procede molto velocemente creando un capo di testo. Dalle "Proprietà" dell'oggetto si sceglie la linguetta "Link ipertestuale" e quindi è possibile inserire il link al report.
Di solito i link ai report sono di questo tipo:
http://NOME_SERVER/jasperserver/flow.html?_flowId=viewReportFlow&reportUnit=/reports/NOME_REPORT&standAlone=true&ParentFolderUri=/reports
Quindi è sufficiente dopo aver deciso la tipologia del link (nel nostro caso Blank e Reference) indicare nella linguetta "Riferimento" l'indirizzo.
Da notare che è anche possibile passare dei parametri se il report destinazione lo prevede passati del report chiamante.
Nel qualcaso un'esempio di link potrebbe essere questo:
"http://NOME_SERVER/jasperserver/flow.html?_flowId=viewReportFlow&reportUnit=/reports/NOME_SOTTOCARTELLA_REPORT/NOME_REPORT&standAlone=true&ParentFolderUri=/reports/NOME_SOTTOCARTELLA_REPORT&SelectFromDateTime="+$V{SelectFrom_STRING}+"&SelectToDateTime="+$V{SelectTo_STRING}
La parte in neretto ci consente di passare ai parametri del report chiamato SelectFromDateTime e SelectToDateTime i valori delle Variabili $V{SelectFrom_STRING} e $V{SelectTo_STRING}.
In questo caso stiamo passando delle date con ora per cui dovendo passare un text alla stringa dell'indirizzo abbiamo usato la seguente espressione per formattarle:
new java.text.SimpleDateFormat("yyyyMMddHHmmss").format($P{SelectFromDateTime})
Come potete vedere a loro volta le variabili erano state costruite da uno dei parametri immessi nel report chiamante.

Spero che anche questa spiegazione sia utile. Se qualcosa non fosse chiaro usate i commenti per porre delle domande.
Alla prossima.

Wsc

giovedì 5 febbraio 2009

JasperServer e iReport: formattare le date

Era un problema con cui mi sono scontrato per un bel po' di tempo...
Avevo bisogno di riformattare le date, usate come parametro, nella creazione di un report da usare all'interno di un campo di tipo String.

Purtroppo tra la scarsa documentazione online su iReport e il poco tempo a disposizione ha lasciato aperta questa problematica per qualche mese.
Fortunatamente l'altro giorno avendo il tempo di mettere insieme un paio di idee sono riuscito a trovare la soluzione.

Il primo passo per giungere al risultato voluto è stato dato dal fatto che qualsiasi funzione aggiuntiva può essere scritta in Java. Però io non conosco questo linguaggio e non mi è rimasto altro che iniziare a googlare (neologismo per effettuare ricerche sul web con google).
Quindi scopro che esiste la seguente funzione SimpleDateFormat.
Non mi resta che indicare la tipologia di formattazione voluta (utilizzo quella italiana "dd/MM/yyyy") e l'oggetto sul quale voglio applicare la funzione (stavo utilizzando un parametro $P{SelectDay} ma la cosa si può applicare anche ai campi del dataset).
A voi il risultato finale:

"Testo fisso del campo "+new SimpleDateFormat("dd/MM/yyyy").format($P{SelectDay})

Spero possa essere d'aiuto a chi si trovasse con la mia stessa problematica.
Alla prossima.

Wsc