2012-05-22 2 views
1

JTable에 페이지 매김이 없다는 것을 전혀 알지 못했습니다.
이제 나는 그것에 붙어 있습니다. 나는 netbeans에서 프로젝트를 코딩 오전 및 그것에서 페이지 매김을 만드는 방법을 알아낼 수 없습니다. 비록 내가 자바 스윙 페이지 매김의 많은 예제를 발견하지만 그들은 netbeans에서 구현되지 않습니다. 어떻게 아래 언급 된 코드에서 페이지 매김을 구현할 것인가?Netbeans JTable 페이지 매기기

import java.sql.*; 
import java.util.logging.Level; 
import java.util.logging.Logger; 
import javax.swing.JOptionPane; 
import javax.swing.table.DefaultTableModel; 

/* 
* To change this template, choose Tools | Templates 
* and open the template in the editor. 
*/ 

/** 
* 
* @author Joseph 
*/ 
public class SupplierForm extends javax.swing.JFrame { 

    /** 
    * Creates new form SupplierForm 
    */ 
    public SupplierForm() { 
     initComponents(); 
    } 

    /** 
    * This method is called from within the constructor to initialize the form. 
    * WARNING: Do NOT modify this code. The content of this method is always 
    * regenerated by the Form Editor. 
    */ 
    @SuppressWarnings("unchecked") 
    // <editor-fold defaultstate="collapsed" desc="Generated Code">       
    private void initComponents() { 

     jPanel1 = new javax.swing.JPanel(); 
     supplierCombo = new javax.swing.JComboBox(); 
     jScrollPane1 = new javax.swing.JScrollPane(); 
     dataTable = new javax.swing.JTable(); 

     setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); 

     jPanel1.setBorder(new javax.swing.border.SoftBevelBorder(javax.swing.border.BevelBorder.RAISED)); 

     supplierCombo.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "Item 1", "USER", "Item 3", "Item 4" })); 
     supplierCombo.addActionListener(new java.awt.event.ActionListener() { 
      public void actionPerformed(java.awt.event.ActionEvent evt) { 
       supplierComboActionPerformed(evt); 
      } 
     }); 

     dataTable.setModel(new javax.swing.table.DefaultTableModel(
      new Object [][] { 

      }, 
      new String [] { 
       "ID", "Title 2", "Title 3", "Title 4" 
      } 
     )); 
     jScrollPane1.setViewportView(dataTable); 

     javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1); 
     jPanel1.setLayout(jPanel1Layout); 
     jPanel1Layout.setHorizontalGroup(
      jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) 
      .addGroup(jPanel1Layout.createSequentialGroup() 
       .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) 
        .addGroup(jPanel1Layout.createSequentialGroup() 
         .addGap(173, 173, 173) 
         .addComponent(supplierCombo, javax.swing.GroupLayout.PREFERRED_SIZE, 141, javax.swing.GroupLayout.PREFERRED_SIZE) 
         .addGap(0, 0, Short.MAX_VALUE)) 
        .addGroup(jPanel1Layout.createSequentialGroup() 
         .addGap(20, 20, 20) 
         .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 660, Short.MAX_VALUE))) 
       .addContainerGap()) 
     ); 
     jPanel1Layout.setVerticalGroup(
      jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) 
      .addGroup(jPanel1Layout.createSequentialGroup() 
       .addContainerGap() 
       .addComponent(supplierCombo, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) 
       .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED) 
       .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) 
       .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) 
     ); 

     javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane()); 
     getContentPane().setLayout(layout); 
     layout.setHorizontalGroup(
      layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) 
      .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup() 
       .addContainerGap(31, Short.MAX_VALUE) 
       .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) 
       .addGap(34, 34, 34)) 
     ); 
     layout.setVerticalGroup(
      layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) 
      .addGroup(layout.createSequentialGroup() 
       .addGap(26, 26, 26) 
       .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) 
       .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) 
     ); 

     pack(); 
    }// </editor-fold>       

    private void supplierComboActionPerformed(java.awt.event.ActionEvent evt) {            
     // TODO add your handling code here: 

     String tableName = (String) supplierCombo.getModel().getSelectedItem(); 
     DefaultTableModel model = (DefaultTableModel) dataTable.getModel(); 
     int c = model.getRowCount(); 
     for (int i=c-1; i>=0; i--){ 
      model.removeRow(i); 
      dataTable.revalidate(); 
      } 
     String sql = "select * from "+ tableName+" "; 
     try { 
      try { 
       Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); 
      } catch (ClassNotFoundException ex) { 
       Logger.getLogger(SupplierForm.class.getName()).log(Level.SEVERE, null, ex); 
      } 
      Connection connect = (Connection) DriverManager.getConnection("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=C:\\Merlin1.accdb"); 
      Statement statmnt = connect.createStatement(); 
      ResultSet rslt = statmnt.executeQuery(sql); 
      while(rslt.next()){ 
       String id = rslt.getString("ID"); 
       String name = rslt.getString("USER_NAME"); 
       String surname = rslt.getString("PASSWORD"); 
       //String age = rslt.getString("Age"); 
       model.addRow(new Object[]{id,name,surname}); 
      } 
     } catch(SQLException e){ 
      JOptionPane.showMessageDialog(this,"No Supplier exists with this name"); 

      } 
    // dataTable.revalidate(); 

    }            

    /** 
    * @param args the command line arguments 
    */ 
    public static void main(String args[]) { 
     /* 
     * Set the Nimbus look and feel 
     */ 
     //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) "> 
     /* 
     * If Nimbus (introduced in Java SE 6) is not available, stay with the 
     * default look and feel. For details see 
     * http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html 
     */ 
     try { 
      for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) { 
       if ("Nimbus".equals(info.getName())) { 
        javax.swing.UIManager.setLookAndFeel(info.getClassName()); 
        break; 
       } 
      } 
     } catch (ClassNotFoundException ex) { 
      java.util.logging.Logger.getLogger(SupplierForm.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
     } catch (InstantiationException ex) { 
      java.util.logging.Logger.getLogger(SupplierForm.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
     } catch (IllegalAccessException ex) { 
      java.util.logging.Logger.getLogger(SupplierForm.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
     } catch (javax.swing.UnsupportedLookAndFeelException ex) { 
      java.util.logging.Logger.getLogger(SupplierForm.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
     } 
     //</editor-fold> 

     /* 
     * Create and display the form 
     */ 
     java.awt.EventQueue.invokeLater(new Runnable() { 

      public void run() { 
       new SupplierForm().setVisible(true); 
      } 
     }); 
    } 
    // Variables declaration - do not modify      
    private javax.swing.JTable dataTable; 
    private javax.swing.JPanel jPanel1; 
    private javax.swing.JScrollPane jScrollPane1; 
    private javax.swing.JComboBox supplierCombo; 
    // End of variables declaration     
} 
+0

가능한 복제본 [Swing에서 JTable에 페이지 매김 지원을 제공하는 방법] (http : // s tackoverflow.com/questions/1481138/how-to-provide-pagination-support-to-a-jtable-in-swing) – Stephan

답변

1

경우에 paginations에게 Database 측면에 두 가지

1)을 만들 수 SQL statement

박리 수직 ScrollBar 수평 방법 JScrollBar.setValue(int)JScrollPane의 행

2) 디스플레이 환산 수 움직일 수 있습니다 JTable 내부 JScrollPane

+0

튜토리얼 링크를 구현하고 이해하면 실제로 코딩에 도움이 될 것입니다. –

+0

@ Namelus : 2 번 항목에 대한 자세한 내용은이 [답변] (http://stackoverflow.com/a/8389513/230513)을 참조하십시오. – trashgod