Hoo*_*ody 5 java user-interface swing jtable
这是一个try块,用于过滤table_job以查找匹配关键字的行.但是,当表模型更改时,我正在努力获取正确的行索引.它总是选择第一行,即使过滤后的结果显示的行不是第一行.
我知道你可以做些什么fireTableDataChanged(),但是我不知道如何做和做这个,在try和catch块中setLabelText()显示表格内容的方法中. JLabel
try
{
sql = "SELECT Job.jobID as 'Job ID', Employer.name as'Company', Job.title as 'Role', Job.description as 'Description', Job.type as 'Type', Job.benefits as 'Benefits', Job.closing as 'Closing Date' FROM Job INNER JOIN Employer ON Job.employerID=Employer.employerID ORDER BY Employer.name";
pst = conn.prepareStatement(sql);
rs = pst.executeQuery();
TableModel model = DbUtils.resultSetToTableModel(rs);
table_job.setModel(model);
final TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(model);
table_job.setRowSorter(sorter);
searchJob.addActionListener(new ActionListener()
{
public void actionPerformed(ActionEvent e)
{
String text = keyword.getText();
if (text.length() == 0)
{
sorter.setRowFilter(null);
}
else
{
sorter.setRowFilter(RowFilter.regexFilter(text));
}
}
});
}
catch (Exception e)
{
e.printStackTrace();
}
private void setLabelText()
{
try
{
String table_click0 = (table_job.getModel().getValueAt(
row, 0).toString());
String sqlSt = "SELECT Employer.name, * FROM Job INNER JOIN Employer ON Job.employerID = Employer.employerID WHERE jobID='"+table_click0+"' ";
//rest of code to Label text...
}
Run Code Online (Sandbox Code Playgroud)
在String table_click0 = (table_job.getModel().getValueAt(row, 0).toString());被拿起错行,而不是更新所选行.我怎么能考虑到这一点?
您可能需要将"行"值转换为模型索引值(如果row从"视图"的角度检索您的值),请使用convertRowIndexToModel.所以只需更换
String table_click0 = (table_job.getModel().getValueAt(row, 0).toString());
Run Code Online (Sandbox Code Playgroud)
同
String table_click0 = table_job.getModel().getValueAt(table_job.
convertRowIndexToModel(row), 0).toString());
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7185 次 |
| 最近记录: |