sql >> Databasteknik >  >> RDS >> Sqlserver

Dokumentet har inga sidor. Rapport från Jasper

För det första, resurshantering...

Du bör bara öppna en enda anslutning till databasen om du kan. Se till att du stänger den innan applikationen stängs. Anslutningsprocessen kan vara dyr, så du vill verkligen bara göra det när du absolut måste...

Du stänger dina resurser när du är klar med dem. Detta uppnås bäst genom att använda en try-finally blockera...

private Connection con;

protected void close() throws SQLException {
    if (con != null) {
        con.close();
    }
}

protected Connection getConnection() throws ClassNotFoundException, SQLException {
    if (con == null) {
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        String url = "jdbc:odbc:*****";
        String user = "******";
        String pass = "******";
        Connection con = DriverManager.getConnection(url, user, pass);
    }
    return con;
}

private void search() throws Exception {

    Statement state = null;
    ResultSet rs = null;

    try {

        state = getConnection().createStatement();

        rs = state.executeQuery("SELECT "
                + "pIDNo AS 'Patient ID',"
                + "pLName AS 'Last Name',"
                + "pFName AS 'First Name',"
                + "pMI AS 'M.I.',"
                + "pSex AS 'Sex',"
                + "pStatus AS 'Status',"
                + "pTelNo AS 'Contact No.',"
                + "pDocID AS 'Doctor ID',"
                + "pAddr AS 'St. No.',"
                + "pStreet AS 'St. Name',"
                + "pBarangay AS 'Barangay',"
                + "pCity AS 'City',"
                + " pProvince AS 'Province',"
                + " pLNameKIN AS 'Last Name',"
                + "pFNameKIN AS 'First Name',"
                + "pMIKIN AS 'M.I.',"
                + "pRelationKIN AS 'Relation',"
                + "pTotalDue AS 'Total Due'"
                + " FROM dbo.Patients");
        ResultSetMetaData rsmetadata = rs.getMetaData();
        int columns = rsmetadata.getColumnCount();

        DefaultTableModel dtm = new DefaultTableModel();
        Vector column_name = new Vector();
        Vector data_rows = new Vector();

        for (int i = 1; i < columns; i++) {
            column_name.addElement(rsmetadata.getColumnName(i));
        }
        dtm.setColumnIdentifiers(column_name);

        while (rs.next()) {
            data_rows = new Vector();
            for (int j = 1; j < columns; j++) {
                data_rows.addElement(rs.getString(j));
            }
            dtm.addRow(data_rows);
        }
        tblPatient.setModel(dtm);

    } finally {
        try {
            rs.close();
        } catch (Exception e) {
        }
        try {
            state.close();
        } catch (Exception e) {
        }
    }
}

Nu till problemet...

Det verkar som att du har skapat två referenser till con . Ett som klassfält och ett som en metodvariabel (i search ).

Du skickar sedan con till Jasper Reports, som jag misstänker är null . Istället bör du använda getConnection() som beskrivits ovan.

public void reportviewer() {
    try{
        String report = "C:\\Users\\cleanfuel\\Documents\\NetBeansProjects\\StringManipulation\\src\\stringmanipulation\\report1.jrxml";
        JasperReport jasp_report = JasperCompileManager.compileReport(report);
        JasperPrint jasp_print = JasperFillManager.fillReport(jasp_report, null, getConnection());
        JasperViewer.viewReport(jasp_print);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

Uppdaterad med bakgrundsarbetare...

En rapport kan ta lite tid att sammanställa och fylla i. Du bör ladda ner det här arbetet till en bakgrundstråd så att det inte stör ditt användargränssnitt (eller får det att se ut som att din applikation är hängd).

Den enklaste lösningen skulle vara att använda en SwingWorker . Den har funktionalitet för att synkronisera om trådarna med UI

public void reportviewer() {
    // Disable any UI components you don't want the user using while
    // the report generates...
    new ReportWorker().execute();
}

public class ReportWorker extends SwingWorker<JasperPrint, Void> {

    @Override
    protected JasperPrint doInBackground() throws Exception {
        String report = "C:\\Users\\cleanfuel\\Documents\\NetBeansProjects\\StringManipulation\\src\\stringmanipulation\\report1.jrxml";
        JasperReport jasp_report = JasperCompileManager.compileReport(report);
        JasperPrint jasp_print = JasperFillManager.fillReport(jasp_report, null, getConnection());
        return jasp_print;
    }

    @Override
    protected void done() {
        try {
            JasperPrint jasp_print = get();
            JasperViewer.viewReport(jasp_print);
        } catch (Exception exp) {
            exp.printStackTrace();
        }
        // Renable any UI components you disabled before the report run
    }
}

Ta en titt på Concurrency in Swing för mer information.

Tips

Om du kan förkompilera rapporten och ladda den (snarare genom att läsa in XML), kommer det att göra rapportprocessen snabbare.




  1. Oracle:är det möjligt att skapa en synonym för ett schema?

  2. Få maxvärde och motsvarande kolumn

  3. Hur man har en anpassad sorteringsordning för en facklig fråga i Postgres

  4. 2 sätt att lägga till ett procenttecken till ett tal i SQLite