【发布时间】:2014-08-03 09:33:20
【问题描述】:
我正在处理一个涉及 JDBC 和 MySQL 数据库的小型应用程序项目。我试图在这样做的同时坚持 MVC 架构,交互的主要形式是控制器。当用户根据按下的 Find 按钮搜索数据库时,它会创建一个新的 JTable 视图来显示搜索结果:
model = DbUtils.resultSetToTableModel( results );
view = new Tunes_Peddler_View( model );
如果我再次按下 Find 按钮,则会创建 JTable 的新实例,而我希望现有窗口使用新查询的结果进行更新。
这是从结果对象创建表模型的 DbUtils 类的代码:
public static TableModel resultSetToTableModel(ResultSet rs)
{
try
{
//get the the metadata for number of columns and column names
ResultSetMetaData metaData = rs.getMetaData();
int numberOfColumns = metaData.getColumnCount();
Vector<String> columnNames = new Vector<String>();
// Get the column names and store in vector
for (int column = 0; column < numberOfColumns; column++)
{
columnNames.addElement(metaData.getColumnLabel(column + 1));
//NOTE: need to do the (+1) because metaData columns indexing starts at 1
//but JTable column numbering starts at 0.
}
// Get all rows data and store in a Vector.
Vector<Object> rows = new Vector<Object>();
rs.first();
do
{
Vector<Object> newRow = new Vector<Object>();
for (int i = 1; i <= numberOfColumns; i++) {
newRow.addElement(rs.getObject(i));
}
rows.addElement(newRow);
}while (rs.next());
return new DefaultTableModel(rows, columnNames);
} catch (Exception e)
{
System.out.println("Exception in DbUtils method resultSetToTableModel()...");
e.printStackTrace();
return null;
}//end catch
}//end method
以及用于创建实际视图本身的代码:
public Tunes_Peddler_View(TableModel model)
{
// Call super.
super("Returned Records");
// Boilerplate
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setSize(1000, 200);
this.setLocationRelativeTo( null );
// Create the JTable and pass it the TableModel as an argument
JTable table = new JTable( model );
table.setModel(model );
// Create a JScrollPane to hold the JTable
JScrollPane scrollPane = new JScrollPane( table );
this.add( scrollPane );
// Last line
this.setVisible(true);
}
为了使 JTable 视图只更新而不是创建新视图,我应该只向它添加一个侦听器还是应该如何去做?
谢谢。
【问题讨论】:
-
不要创建视图的新实例,而是在控制器中维护对视图的单一引用,当您获得新模型时,将其传递给视图实例并允许视图设置表的模型
-
收听视图会自动更新作为响应。
-
@MadProgrammer 我稍微调整了我的视图类,让这个单一的引用发生并且它起作用了!如果你想把它写下来作为答案,我会接受。
标签: java swing jdbc jtable tablemodel