JTable 삽입 후 테이블 모델을 새로 고치는 방법 데이터를 삭제하거나 업데이트합니다.


89

이것은 내 jTable입니다

private JTable getJTable() {
    String[] colName = { "Name", "Email", "Contact No. 1", "Contact No. 2",
            "Group", "" };
    if (jTable == null) {
        jTable = new JTable() {
            public boolean isCellEditable(int nRow, int nCol) {
                return false;
            }
        };
    }
    DefaultTableModel contactTableModel = (DefaultTableModel) jTable
            .getModel();
    contactTableModel.setColumnIdentifiers(colName);
    jTable.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
    return jTable;
}

이 메서드를 호출하여 데이터베이스에서 데이터를 검색하고 테이블 모델에 넣습니다.

public void setUpTableData() {
    DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
    ArrayList<Contact> list = new ArrayList<Contact>();
    if (!con.equals(""))
        list = sql.getContactListsByGroup(con);
    else
        list = sql.getContactLists();
    for (int i = 0; i < list.size(); i++) {
        String[] data = new String[7];

            data[0] = list.get(i).getName();
            data[1] = list.get(i).getEmail();
            data[2] = list.get(i).getPhone1();
            data[3] = list.get(i).getPhone2();
            data[4] = list.get(i).getGroup();
            data[5] = list.get(i).getId();

        tableModel.addRow(data);
    }
    jTable.setModel(tableModel);
}

현재 저는이 방법을 사용하여 테이블 데이터를 업데이트 한 후 테이블을 새로 고칩니다. 먼저 테이블을 비울 게요

DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();
tableModel.setRowCount(0);

그런 다음 테이블 모델을 다시 재구성하여 jTable을 새로 고칩니다. 하지만 모범 사례 나 더 나은 방법이 있다고 생각했습니다.

답변:


119

JTable데이터 변경에 대해 알리려면
tableModel.fireTableDataChanged()

로부터 문서 :

테이블 행의 모든 ​​셀 값이 변경되었을 수 있음을 모든 리스너에게 알립니다. 행 수도 변경되었을 수 있으며 JTable은 처음부터 테이블을 다시 그려야합니다. 테이블의 구조 (열 순서와 같음)는 동일한 것으로 간주됩니다.


업데이트 할 때 마다이 tableModel.fireTableDataChanged ()를 호출한다는 의미입니까?
user236501 2010-07-05

3
@ newbie123 : 새 줄만 삽입하는 경우 대신 fireTableRowsInserted 를 사용할 수 있습니다 . 반면에의 구현 DefaultTableModel.addRow은 이미 처리해야합니다. 테이블이 새로 고쳐지지 addRow않습니까?
Peter Lang

4
사용 setValueAt, DefaultTableModel이벤트를 발생시킵니다.
Peter Lang

18
javax.swing.table.AbstractTableModel인터페이스 TableModel에는 위에서 언급 한 메소드가 없기 때문에 casted에서 호출이 이루어져야합니다.
Milan Aleksić

@PeterLang 내 질문을 참조하십시오 : stackoverflow.com/questions/18282753/…
Sajad

20

케이스에 대한 더 빠른 방법은 다음과 같습니다.

    jTable.repaint(); // Repaint all the component (all Cells).

하나 또는 몇 개의 셀이 변경 될 때 최적화 된 방법 :

    ((AbstractTableModel) jTable.getModel()).fireTableCellUpdated(x, 0); // Repaint one cell.

1
실제로 jTable.invalidate ()가 실제로 다시 그리기를 강제하는 메서드라는 것을 발견했습니다.
케빈 치우

맞지만 validate 메소드는 레이아웃 프로세스의 일부이며 컨테이너의 부모에도 영향을 미칩니다. 따라서 레이아웃을 다시 실행해야하는 경우 사용하십시오. docs.oracle.com/javase/7/docs/api/java/awt/...
다니엘 드 레온에게

8

이 시도

public void setUpTableData() {
    DefaultTableModel tableModel = (DefaultTableModel) jTable.getModel();

    /**
    * additional code.
    **/
    tableModel.setRowCount(0);
    /**/
    ArrayList<Contact> list = new ArrayList<Contact>();
    if (!con.equals(""))
        list = sql.getContactListsByGroup(con);
    else
        list = sql.getContactLists();
    for (int i = 0; i < list.size(); i++) {
        String[] data = new String[7];

        data[0] = list.get(i).getName();
        data[1] = list.get(i).getEmail();
        data[2] = list.get(i).getPhone1();
        data[3] = list.get(i).getPhone2();
        data[4] = list.get(i).getGroup();
        data[5] = list.get(i).getId();

        tableModel.addRow(data);
    }
    jTable.setModel(tableModel);
    /**
    * additional code.
    **/
    tableModel.fireTableDataChanged();
    /**/
}

2
처음에 테이블의 모델을 이미 얻었으므로 끝에 jTable.setModel (tableModel)이 필요하지 않습니다.
데이비드 조지

2
DefaultTableModel dm = (DefaultTableModel)table.getModel();
dm.fireTableDataChanged(); // notifies the JTable that the model has changed

3
아니요, 아닙니다 ... DefaultTableModel이이 이벤트를 구현하고 올바르게 구현했습니다 ...
mKorbel

1

사용하는 것이 더 좋지 않을까요 java.util.Observablejava.util.Observer그 갱신에 테이블을 일으킬 것인가?


7
아니, 확실하지, 그렇게하지 않는 이유는 시뮬레이션의 JTable의 내장 옵션에서 EDT에서
mKorbel

-4

나는 Jtable에서 300ms 후에 자동 새로 고침을 수행했습니다.

DefaultTableModel tableModel = new DefaultTableModel(){
public boolean isCellEditable(int nRow, int nCol) {
                return false;
            }
};
JTable table = new JTable();

Timer t = new Timer(300, new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                addColumns();
                remakeData(set);
                table.setModel(model);
            }
        });
        t.start();

private void addColumns() {
        model.setColumnCount(0);
        model.addColumn("NAME");
            model.addColumn("EMAIL");} 

 private void remakeData(CollectionType< Objects > name) {
    model.setRowCount(0);
    for (CollectionType Objects : name){
    String n = Object.getName();
    String e = Object.getEmail();
    model.insertRow(model.getRowCount(),new Object[] { n,e });
    }}

500 개가 넘는 객체와 같은 많은 수의 객체에서 잘 작동 할 것 같지 않습니다. 다른 방법은 클래스에서 TableModelListener를 구현하는 것뿐입니다.하지만이를 잘 사용하는 방법을 이해하지 못했습니다. http://download.oracle.com/javase/tutorial/uiswing/components/table.html#modelchange참조하십시오.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.