SQL データベースがあり、レコードの追加/削除/変更を可能にするプログラムに取り組んでいます。私はすでに編集/削除に取り組んでいるレコードを追加することができました。
既存のレコードをテーブルに表示したいので、jTable を使用しています。オンラインでいくつかのコードを見つけて、それを修正してレコードをプルして jtable に表示しましたが、右クリックをコーディングしてポップアップ メニューを表示する方法がわかりません。
そのポップアップ メニューに、レコードの削除やレコードの変更などのオプションを表示したいと考えています。
これは、jTable を作成してデータを表示するために使用しているコードです。
private void menuDeleteAuthorActionPerformed(java.awt.event.ActionEvent evt) {
TableFromDatabase deleteAuthor = new TableFromDatabase();
deleteAuthor.pack();
deleteAuthor.setVisible(true);
Vector columnNames = new Vector();
Vector data = new Vector();
try
{
Connection connection = DriverManager.getConnection( url, user, password );
// Read data from a table
String sql = "SELECT * FROM Authors";
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery( sql );
ResultSetMetaData md = rs.getMetaData();
int columns = md.getColumnCount();
// Get column names
for (int i = 1; i <= columns; i++)
{
columnNames.addElement( md.getColumnName(i) );
}
// Get row data
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 e)
{
System.out.println( e );
}
// Create table with database data
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 );
}
私はJavaが初めてなので、親切に回答してください。ご協力いただきありがとうございます。