簡體   English   中英

JTable用JComboBox填充數據

[英]JTable fill data with JComboBox

我有一個帶有表,組合框的框架,我想通過組合框用數據庫中的數據填充表,但是如果我與itemlistener一起使用,我不會看到該表,沒有itemlistener和String sql="select * from Arlista"那么我會看到我的包含數據的表格(combob = combobox)

combob.addItemListener(new ItemListener(){
    @Override
    public void itemStateChanged(ItemEvent e){
        tesztvalt=(combob.getSelectedItem()).toString();

        if (e.getItem().equals(tesztvalt))
        {
            try {

                Class.forName( driver );
                Connection connection = DriverManager.getConnection( url );
                String sql="select * from "+tesztvalt+"";
                Statement stmt = connection.createStatement();
                ResultSet rs = stmt.executeQuery( sql );
                ResultSetMetaData md = rs.getMetaData();
                int columns = md.getColumnCount();

                while (rs.next()) {
                    Vector row = new Vector(columns);

                    for (int i = 1; i <= columns; i++)
                    {
                        row.addElement( rs.getObject(i) );
                    }
                    data.addElement( row );

                }
                rs.close();
                stmt.close();
                connection.close();
            }catch(Exception ex) {
                System.out.println( e );
            }
            JTable table = new JTable(data, columnNames)
            {
                public Class getColumnClass(int column)
                {
                    for (int row = 0; row < getRowCount(); row++)
                    {
                        Object o = getValueAt(row, column);

                        if (o != null)
                        {
                            return o.getClass();
                        }
                    }
                    return Object.class;
                }
            };
            JScrollPane scrollPane = new JScrollPane( table );
            getContentPane().add( scrollPane );

            JPanel buttonPanel = new JPanel();
            getContentPane().add( buttonPanel, BorderLayout.SOUTH );
        }
    }
});

這是稍微不同的方法,但是很簡單。 當您從組合框中選擇一個項目時,表格會更改。 它使用表模型:

//ComboTableTest.java
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.AbstractTableModel;

public class ComboTableTest extends JFrame implements ActionListener {
    private static final long serialVersionUID = -3898736145211708745L;

    private JComboBox<String> combo;
    private MyTableModel tableModel;

    //constructor
    public ComboTableTest() {
        //set up frame
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setSize(600,175);
        setLayout(new FlowLayout());

        //create combo box
        combo = new JComboBox<String>(new String[]{"one", "two", "three"});
        combo.addActionListener(this);
        add(combo);

        //create table
        tableModel = new MyTableModel();
        final JTable table = new JTable(tableModel);
        table.setPreferredScrollableViewportSize(new Dimension(500, 70));
        table.setFillsViewportHeight(true);
        JScrollPane scrollPane = new JScrollPane(table);
        add(scrollPane);
    }

    @Override
    public void actionPerformed(ActionEvent e) {
        if (e.getSource() == combo) {
            tableModel.setValueAt(0,0,(String)combo.getSelectedItem());
            tableModel.setValueAt(1,1,(String)combo.getSelectedItem());
            tableModel.setValueAt(2,2,(String)combo.getSelectedItem());
        }

    }


    /*** MAIN ***/
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    ComboTableTest frame = new ComboTableTest();
                    frame.setVisible(true);

                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });
    }
}

class MyTableModel extends AbstractTableModel {
    private static final long serialVersionUID = -1359557492205432915L;

    private String[] columnNames = {"Col 1","Col 2","Col 3"};
    private Object[][] data = new Object[][]{{"1","2","3"},{"4","5","6"},{"7","8","9"}};

    public void setValueAt(int row, int col, String s) {
        data[row][col] = s;
        fireTableDataChanged(); //EDITED
    }

    public int getColumnCount() {
        return columnNames.length;
    }

    public int getRowCount() {
        return data.length;
    }

    public String getColumnName(int col) {
        return columnNames[col];
    }

    public Object getValueAt(int row, int col) {
        return data[row][col];
    }

    public Class getColumnClass(int c) {
        return getValueAt(0, c).getClass();
    }
}
String sql="SELECT * FROM "+tesztvalt+""; 

PreparedStatement pst = conn.prepareStatement(sql);
ResultSet rs = pst.executeQuery();

while (rs.next()) 
{
    tabla.setModel(model);
}

您有幾個問題:

  1. 您使用的PreparedStatement錯誤。 您的代碼可能可以運行(我不確定),但是它沒有利用PreparedStatement的功能。

  2. 從ResultSet讀取數據的代碼沒有意義,因為您甚至根本沒有從ResultSet讀取任何數據。

要使用PreparedStatement,代碼類似於:

String sql = "Select * from ?";
PreparedStatement stmt = connection.prepareStatement(sql);
stmt.setString( 1, tesztvalt );
stmt.executeQuery();

現在,PreparedStatement將使用適當的定界符來構建SQL查詢,因此您無需擔心。

如果要從特定表中讀取所有數據,請檢出Table From Database中TableFromDatabaseExample.java代碼。 它顯示了如何構建查詢以及如何訪問列名和數據。

我認為最好和最常見的方法是將所有數據存儲在JTable中,並使用基於組合框選擇的過濾器。

在這個問題上,有人基於文本框來完成此操作。 更改組合很簡單。

如何過濾JTable中的行?

或者,有關教程的信息,請訪問http://docs.oracle.com/javase/tutorial/uiswing/components/table.html,然后選擇“排序和過濾”

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM