2016-07-06 33 views
0

JTableから複数の行を一度に削除したいのですが、一度に1行しか削除できません。 JTableは一度に1つの選択だけを許可しますか?それらを選択して複数の行を削除したいのであれば、私たちはそうすることができますか?指定されたコードは、複数の行を選択しても、一度に1行しか削除できません。一度にJTableデータベースから複数の行を削除する方法

DBConnectionは、MySqlデータベースに接続するためのクラスです。

staffTable1JTable

ShowStaffInStaffTable()の変数名は、ここでゲッターセッタークラス

を使用してMySQLからデータをインポートすることで、私のJTable行と列を更新する機能です、私が試してみました私のコードです:

int row = staffTable1.getSelectedRow(); 
DefaultTableModel model = (DefaultTableModel) staffTable1.getModel(); 

String selected = model.getValueAt(row, 9).toString(); 

if (row >= 0) { 
    try { 
     DBConnection DB12 = new DBConnection(); 
     Connection conn = DB12.Connect(); 
     String sql = "delete from staff where Contact_No= ?"; 
     PreparedStatement stmt = conn.prepareStatement(sql); 
     stmt.setString(1, selected); 
     stmt.executeUpdate(); 
     form12.ShowStaffInStaffTable(); 
    } catch (Exception w) { 
     JOptionPane.showMessageDialog(this, "Connection Error!"+w); 
     w.printStackTrace(); 
    } 
} 
+0

[*テーブルの使用方法:ユーザーの選択*](https://docs.oracle.com/javase/tutorial/uiswing/components/table.html#selection)を参照してください。 – trashgod

+0

@trashgod私は既に私たちが指定されたリンクにあるメソッドによってJTableから複数の行を選択できることを知っていますが、私の質問は、それらを選択した後、JTableとデータベースから複数の行を削除する方法ですか?上記のコード(上記)は、複数の行を選択しても、一度に1行しか削除できません。 –

+0

'JTableから複数の行が選択された後' - 'getSelectedRows'は選択された行のインデックスを含む配列を返します(現在のコードは' getSelectedRow'を使用します) – copeg

答えて

2

以下は、選択された複数の行をJTable(およびJList)から削除する方法を示しています。

import java.awt.*; 
import java.awt.event.*; 
import java.util.Arrays; 
import java.util.ArrayList; 
import java.util.Collections; 
import java.util.List; 
import javax.swing.*; 
import javax.swing.table.*; 

public class ItemDeletion extends JPanel 
{ 
    private JList<String> list; 
    private JTable table; 

    public ItemDeletion() 
    { 
     setLayout(new BorderLayout(5, 5)); 

     String[] items = 
     { 
      "One", 
      "Two", 
      "Three", 
      "Four", 
      "Five", 
      "Six", 
      "Seven", 
      "Eight", 
      "Nine", 
      "Ten" 
     }; 

     // Add the list 

     DefaultListModel<String> listModel = new DefaultListModel<String>(); 

     for (String item: items) 
      listModel.addElement(item); 

     list = new JList<String>(listModel); 


     JButton listDelete = new JButton("Delete From List"); 
     listDelete.addActionListener(new ActionListener() 
     { 
      @Override 
      public void actionPerformed(ActionEvent e) 
      { 
       DefaultListModel model = (DefaultListModel)list.getModel(); 
       int row = list.getSelectedIndex(); 

       while (row != -1) 
       { 
        model.removeElementAt(row); 
        row = list.getSelectedIndex(); 
       } 
      } 
     }); 

     JPanel listPanel = new JPanel(new BorderLayout(5, 5)); 
     listPanel.add(new JScrollPane(list), BorderLayout.CENTER); 
     listPanel.add(listDelete, BorderLayout.PAGE_END); 

     // Add the table 

     DefaultTableModel tableModel = new DefaultTableModel(0, 1); 
     List<String> tableItems = Arrays.asList(items); 
     Collections.shuffle(tableItems); 

     for (String item: tableItems) 
     { 
      System.out.println(item); 
      tableModel.addRow(new String[]{item}); 
     } 

     table = new JTable(tableModel); 

     table.setAutoCreateRowSorter(true); 
     ((DefaultRowSorter)table.getRowSorter()).toggleSortOrder(0); 

     JButton tableDelete = new JButton("Delete From Table"); 
     tableDelete.addActionListener(new ActionListener() 
     { 
      @Override 
      public void actionPerformed(ActionEvent e) 
      { 
       DefaultTableModel model = (DefaultTableModel)table.getModel(); 
       int row = table.getSelectedRow(); 

       while (row != -1) 
       { 
        int modelRow = table.convertRowIndexToModel(row); 
        model.removeRow(modelRow); 
        row = table.getSelectedRow(); 
       } 
      } 
     }); 

     JPanel tablePanel = new JPanel(new BorderLayout(5, 5)); 
     tablePanel.add(new JScrollPane(table), BorderLayout.CENTER); 
     tablePanel.add(tableDelete, BorderLayout.PAGE_END); 

     add(listPanel, BorderLayout.LINE_START); 
     add(tablePanel, BorderLayout.LINE_END); 
    } 

    private static void createAndShowGUI() 
    { 
     JFrame frame = new JFrame("Multiple Item Deletion"); 
     frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
     frame.add(new ItemDeletion(), BorderLayout.NORTH); 
     frame.setLocationByPlatform(true); 
     frame.pack(); 
     frame.setVisible(true); 
    } 

    public static void main(String[] args) 
    { 
     EventQueue.invokeLater(new Runnable() 
     { 
      public void run() 
      { 
       createAndShowGUI(); 
      } 
     }); 
    } 
} 

データベースから行を削除するには、コードを変更する必要があります。

関連する問題