如何将 DefaultTableModel 对象的数据放入 DefaultTableModel 的子类中
How to get a DefaultTableModel object's data into a subclass of DefaultTableModel
我有一个 jTable 显示简单的两列 sql table 的数据并允许用户维护列表。这是我的第一个 java 程序。让用户可以编辑数据列表并按保存更新。
我从这行代码中获取 sql 数据到 jTable 的 DefaultTableModel:
paCutAboveTable.SetTableModel((DefaultTableModel) DbUtils.resultSetToTableModel(rs));
我猜这里的人很熟悉 DBUtils 和 resultSets。
我想在每一行中添加一个复选框。在这里和其他地方看,我一直看到子类化 DefaultTableModel 以便覆盖这样的方法:
/*
* JTable uses this method to determine the default renderer/
* editor for each cell. If we didn't implement this method,
* then the last column would contain text ("true"/"false"),
* rather than a check box.
*/
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
但是我不知道如何将 DefaultTableModel 的输出从 resultSetToTableModel 方法获取到我的子类 - 如果将 SetTableModel 方法更改为接受子类作为其参数,则显示的语句不会编译。
有没有我想念的简单方法?
下面是一个示例,展示了如何从 ResultSet 中读取数据并在您自己的自定义 DefaultTableModel 中实现 getColumnClass(...)
方法:
import java.awt.*;
import java.sql.*;
import java.util.*;
import javax.swing.*;
import javax.swing.table.*;
public class TableFromDatabase extends JFrame
{
public TableFromDatabase()
{
Vector<Object> columnNames = new Vector<Object>();
Vector<Object> data = new Vector<Object>();
try
{
// Connect to an Access Database
String driver = "sun.jdbc.odbc.JdbcOdbcDriver";
// String url = "jdbc:odbc:???"; // if using ODBC Data Source name
String url =
"jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=c:/directory/???.mdb";
String userid = "";
String password = "";
Class.forName( driver );
Connection connection = DriverManager.getConnection( url, userid, password );
// Read data from a table
String sql = "Select * from ???";
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.getColumnLabel(i) );
}
// Get row data
while (rs.next())
{
Vector<Object> row = new Vector<Object>(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
DefaultTableModel model = new DefaultTableModel(data, columnNames)
{
@Override
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;
}
};
JTable table = new JTable( model );
JScrollPane scrollPane = new JScrollPane( table );
add( scrollPane );
JPanel buttonPanel = new JPanel();
add( buttonPanel, BorderLayout.SOUTH );
}
public static void main(String[] args)
{
TableFromDatabase frame = new TableFromDatabase();
frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
frame.pack();
frame.setVisible(true);
}
}
通过覆盖 getColumnClass(...)
方法,您现在将看到右对齐格式的数字,如果您需要对数据进行排序,它将正常工作,因为该列将根据数值而不是字符串值进行排序.
I want to add a CheckBox to each row.
现在你有两个选择:
修改上面的代码,使"columnNames" Vector包含复选框列的另一个header名称,并向每个"row"添加Boolean.FALSE
遍历 ResultSet 时的向量。
按原样使用上面的 TableModel(或使用 DbUtils TableModel),然后创建一个包装器 TableModel,它将向任何现有 TableModel 添加一个复选框列。查看:How to add checkbox in Jtable populated using rs2xml 了解此方法的示例。
我有一个 jTable 显示简单的两列 sql table 的数据并允许用户维护列表。这是我的第一个 java 程序。让用户可以编辑数据列表并按保存更新。 我从这行代码中获取 sql 数据到 jTable 的 DefaultTableModel:
paCutAboveTable.SetTableModel((DefaultTableModel) DbUtils.resultSetToTableModel(rs));
我猜这里的人很熟悉 DBUtils 和 resultSets。 我想在每一行中添加一个复选框。在这里和其他地方看,我一直看到子类化 DefaultTableModel 以便覆盖这样的方法:
/*
* JTable uses this method to determine the default renderer/
* editor for each cell. If we didn't implement this method,
* then the last column would contain text ("true"/"false"),
* rather than a check box.
*/
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
但是我不知道如何将 DefaultTableModel 的输出从 resultSetToTableModel 方法获取到我的子类 - 如果将 SetTableModel 方法更改为接受子类作为其参数,则显示的语句不会编译。 有没有我想念的简单方法?
下面是一个示例,展示了如何从 ResultSet 中读取数据并在您自己的自定义 DefaultTableModel 中实现 getColumnClass(...)
方法:
import java.awt.*;
import java.sql.*;
import java.util.*;
import javax.swing.*;
import javax.swing.table.*;
public class TableFromDatabase extends JFrame
{
public TableFromDatabase()
{
Vector<Object> columnNames = new Vector<Object>();
Vector<Object> data = new Vector<Object>();
try
{
// Connect to an Access Database
String driver = "sun.jdbc.odbc.JdbcOdbcDriver";
// String url = "jdbc:odbc:???"; // if using ODBC Data Source name
String url =
"jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=c:/directory/???.mdb";
String userid = "";
String password = "";
Class.forName( driver );
Connection connection = DriverManager.getConnection( url, userid, password );
// Read data from a table
String sql = "Select * from ???";
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.getColumnLabel(i) );
}
// Get row data
while (rs.next())
{
Vector<Object> row = new Vector<Object>(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
DefaultTableModel model = new DefaultTableModel(data, columnNames)
{
@Override
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;
}
};
JTable table = new JTable( model );
JScrollPane scrollPane = new JScrollPane( table );
add( scrollPane );
JPanel buttonPanel = new JPanel();
add( buttonPanel, BorderLayout.SOUTH );
}
public static void main(String[] args)
{
TableFromDatabase frame = new TableFromDatabase();
frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
frame.pack();
frame.setVisible(true);
}
}
通过覆盖 getColumnClass(...)
方法,您现在将看到右对齐格式的数字,如果您需要对数据进行排序,它将正常工作,因为该列将根据数值而不是字符串值进行排序.
I want to add a CheckBox to each row.
现在你有两个选择:
修改上面的代码,使"columnNames" Vector包含复选框列的另一个header名称,并向每个"row"添加
Boolean.FALSE
遍历 ResultSet 时的向量。按原样使用上面的 TableModel(或使用 DbUtils TableModel),然后创建一个包装器 TableModel,它将向任何现有 TableModel 添加一个复选框列。查看:How to add checkbox in Jtable populated using rs2xml 了解此方法的示例。