JTable:选择行时从数据库获取值

时间:2013-01-11 18:25:18

标签: java database swing arraylist jtable

我有三个文件,TopicData,TopicView,TopicTableModel。我的程序使用数据库中的值显示一个表。现在,当我点击一行时,将打印该行的索引。 我想修改代码,以便打印来自我的数据库的topicID。 topicID的值存储在ArrayList中但不显示在表中,所以我不能使用JTable.getValueAt( )。

请告知如何修改我的代码。提前致谢。

更多信息:

  1. TopicData从数据库中获取数据并将其存储在ArrayList中。

  2. 然后将ArrayList传递给TopicTableModel,使得数据适合在JTable中显示。

  3. TopicView创建一个JTable并接受TopicTableModel以生成JTable。

  4. TopicData.java

    public class TopicData {
    int id;
    String name; 
    String date; 
    String category;
    String user;
    
    public TopicData(){
    }
    
    public TopicData(int id, String name, String date, String category, String user) {
        this.id = id;
        this.name = name;
        this.date = date;
        this.category = category;
        this.user = user;
    }
    
    
    
    public TopicData(String name, String date, String category, String user) {
        this.name = name;
        this.date = date;
        this.category = category;
        this.user = user;
    }
    
    public int getId() {
        return id;
    }
    
    public void setId(int id) {
        this.id = id;
    }
    
    public String getName() {
        return name;
    }
    
    public void setName(String name) {
        this.name = name;
    }
    
    public String getDate() {
        return date;
    }
    
    public void setDate(String date) {
        this.date = date;
    }
    
    public String getCategory() {
        return category;
    }
    
    public void setCategory(String category) {
        this.category = category;
    }
    
    public String getUser() {
        return user;
    }
    
    public void setUser(String user) {
        this.user = user;
    }
    
    
    public ArrayList<TopicData> getTopicList(){
        ArrayList<TopicData> topicList = new ArrayList<TopicData>();
        ResultSet rs = null;
        DBController db = new DBController();
        db.setUp("myDatabase");
        String dbQuery = "SELECT topicID, topicName, topicDate, topicCategory, topicUser FROM topicTable ORDER BY topicDate";
    
        rs = db.readRequest(dbQuery);
    
        try{
            while(rs.next()){
                int id = rs.getInt("topicID");
                String name = rs.getString("topicName"); 
                String date = rs.getString("topicDate") ; 
                String category = rs.getString("topicCategory");
                String user = rs.getString("topicUser");
    
                TopicData topic = new TopicData (id, name, date, category, user);
                topicList.add(topic);
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        db.terminate();
        return topicList;
    }
    

    TopicTableModel.java

    public class TopicTableModel extends AbstractTableModel {
    
    private static final long serialVersionUID = 1L;
    private int rowCount, colCount;
    private String[] columnNames = {"Name", "Date", "User"};
    private Object [][] data;
    
    public TopicTableModel(ArrayList<TopicData> listOfObjects) {
        rowCount = listOfObjects.size();
        colCount = columnNames.length;
        data = new Object[rowCount][colCount];
    
        for (int i = 0; i < rowCount; i++) {
            //Copy an ArrayList element to an instance of MyObject
            TopicData topic = (listOfObjects.get(i)); 
            data[i][0] = topic.getName();            
            data[i][1] = topic.getDate();
            data[i][2] = topic.getUser();
        }              
    } 
    
    @Override
    public int getColumnCount() {
        // TODO Auto-generated method stub
        return colCount;
    }
    
    @Override
    public int getRowCount() {
        // TODO Auto-generated method stub
        return rowCount;
    }
    
    @Override
    public String getColumnName(int col) {
        return columnNames[col];
    }
    
    @Override
    public Object getValueAt(int rowIndex, int columnIndex) {
        // TODO Auto-generated method stub
        return data[rowIndex][columnIndex];
    }
    
    @Override
    public boolean isCellEditable(int rowIndex, int colIndex) {
        return false; //Disallow the editing of any cell
    }
    
    }
    

    TopicView.java

    private JTable getTable() {
        if (table == null) {
            TopicData topic= new TopicData();
            TopicTableModel tableModel = new TopicTableModel(topic.getTopicList());
            table = new JTable(tableModel);
    
            table.setShowGrid(false);
            table.setFillsViewportHeight(true);
            table.setBounds(173, 87, 456, 263);
            table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
            table.getTableHeader().setReorderingAllowed(false);
            table.getTableHeader().setResizingAllowed(false);
            table.getColumnModel().getColumn(0).setPreferredWidth(500);
    
            ListSelectionModel rowSM = table.getSelectionModel();
            rowSM.addListSelectionListener(new ListSelectionListener() {
                public void valueChanged(ListSelectionEvent e) {
                    //Ignore extra messages.
                    if (e.getValueIsAdjusting()) return;
    
                    ListSelectionModel lsm = (ListSelectionModel)e.getSource();
                    if (lsm.isSelectionEmpty()) {
                        System.out.println("No rows are selected.");
                    } 
                    else {
                        int selectedRow = lsm.getMinSelectionIndex();
                        System.out.println("Row " + selectedRow + " is now selected.");
                    }
                }
            });
        }
        return table;
    }
    

2 个答案:

答案 0 :(得分:4)

你正在艰难地做这件事。不要将TopicData转换为数组,只需让您的TableModel直接读取TopicData对象的ArrayList,因此每个TopicData对应一行。

TopicTableModel.java:

import java.util.ArrayList;

import javax.swing.table.AbstractTableModel;

public class TopicTableModel extends AbstractTableModel {

private static final long serialVersionUID = 1L;
private String[] columnNames = {"Name", "Date", "User"};
private ArrayList<TopicData> data;

public TopicTableModel(ArrayList<TopicData> listOfObjects) {
    data = listOfObjects;
} 

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

@Override
public int getRowCount() {
    return data.size();
}

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

@Override
public Object getValueAt(int rowIndex, int columnIndex) {
    switch (column) {
    case 0:
        return data.getName();
    case 1:
        return data.getDate();
    case 2:
        return data.getUser();
    default:
        throw new ArrayIndexOutOfBoundsException();
    }
}

@Override
public boolean isCellEditable(int rowIndex, int colIndex) {
    return false; //Disallow the editing of any cell
}

public TopicData getTopic(int row) {
    return data.get(row);
}

}

通过对TopicView.java进行一些小修改,您现在可以获取所选行的TopicData并打印其ID。

TopicView.java:

import javax.swing.JTable;
import javax.swing.ListSelectionModel;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;


public class TopicView {
    JTable table;

    private JTable getTable() {
        if (table == null) {
            TopicData topic= new TopicData();
            final TopicTableModel tableModel = new TopicTableModel(topic.getTopicList());
            table = new JTable(tableModel);

            table.setShowGrid(false);
            table.setFillsViewportHeight(true);
            table.setBounds(173, 87, 456, 263);
            table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
            table.getTableHeader().setReorderingAllowed(false);
            table.getTableHeader().setResizingAllowed(false);
            table.getColumnModel().getColumn(0).setPreferredWidth(500);
            table.setDefaultRenderer(TopicData.class, new TopicDataTableCellRenderer());

            ListSelectionModel rowSM = table.getSelectionModel();
            rowSM.addListSelectionListener(new ListSelectionListener() {
                public void valueChanged(ListSelectionEvent e) {
                    //Ignore extra messages.
                    if (e.getValueIsAdjusting()) return;

                    int row = table.getSelectedRow();
                    if (row < 0) {
                        System.out.println("No rows are selected.");
                    }
                    else {
                        System.out.println("id " + tableModel.getTopic(row).getId() + " is now selected.");
                    }
                }
            });
        }
        return table;
    }
}

答案 1 :(得分:3)

你实际上已经掌握了一切。

您需要做的就是更改TableModel,以便保留ArrayList,而不是将该列表转换为Object[][]

这样的事情(可能有一些错字问题):

public class TopicTableModel extends AbstractTableModel {

private static final long serialVersionUID = 1L;
private int rowCount, colCount;
private String[] columnNames = {"ID", "Name", "Date", "User"};
private List<TopicData> listOfObjects;
public TopicTableModel(ArrayList<TopicData> listOfObjects) {
    this.listOfObjects = listOfObjects;
} 

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

@Override
public int getRowCount() {
    return listOfObjects.size();
}

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

@Override
public Object getValueAt(int rowIndex, int columnIndex) {
    TopicData data = listOfObjects.get(rowIndex);
    switch(columnIndex) {
        case 0:
            return data.getId();
        case 1:
            return data.getName();
        case 2:
            return data.getDate();
        case 3:
            return data.getUser();
    }
    return null;
}

@Override
public boolean isCellEditable(int rowIndex, int colIndex) {
    return false; //Disallow the editing of any cell
}

}

副作用:如果您使用Java序列化(或利用TopicData的其他技术),则需要制作Serializable Serializable