我正在开发一个涉及JDBC和MySQL数据库的小应用项目。我试图坚持MVC架构,同时做到这一点,交互的主要形式是控制器。当用户根据被按下的查找按钮搜索数据库时,它会创建一个新的JTable视图以显示搜索结果:
model = DbUtils.resultSetToTableModel( results );
view = new Tunes_Peddler_View( model );
如果我再次按下“查找”按钮,则会创建一个新的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视图只是更新而不是创建一个新的视图,我应该只添加一个监听器,或者我应该怎么做呢?
感谢。
答案 0 :(得分:1)
不要创建视图的新实例,而是在控制器中维护对视图的单个引用,当您获得新模型时,将其传递给视图的实例并允许视图设置模型表
这是MVC如何工作的核心