使用过滤器搜索并在 jTable 中显示
Searching with filters and showing in a jTable
我正在尝试从数据库中搜索并在 jTable 上显示数据,但是,我也想显示相似的名称。
问题是,用'similar to'或'like'在任何位置显示相似的名字?
例如,如果用户在 jTextField 上搜索“Santos”,我想在 jTable 中显示“Lucas Santos”和“Santos Jr”。
try{
Connection cn=DB.connector.getConnection();
PreparedStatement ps=cn.prepareStatement("select cad_nome,cad_apelido,cad_cpf,cad_idade,cad_data from cad_pessoa where cad_nome similar to ? order by cad_nome asc, cad_cpf asc nulls last ");
if(jTextFieldNOME.getText().equals("")){
//JOptionPane.showMessageDialog(null, "Por favor completar o campo CPF!\n");
PreparedStatement stm=cn.prepareStatement("select * from cad_pessoa ");
ResultSet rs = stm.executeQuery();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}
}
//else {
ps.setString(1, jTextFieldNOME.getText());
ResultSet rs = ps.executeQuery();
ps.execute();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}
}
catch (Exception e)
{
JOptionPane.showMessageDialog(this, e);
}
}
这是我针对此问题使用的解决方案:
else if(jTextFieldNOME.getText() != null) {
PreparedStatement ps=cn.prepareStatement("select cad_nome,cad_apelido,cad_cpf,cad_idade,cad_data from cad_pessoa where cad_nome like ? order by cad_nome asc, cad_cpf asc nulls last ");
ps.setString(1,"%" + jTextFieldNOME.getText() + "%");
ResultSet rs = ps.executeQuery();
ps.execute();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
JOptionPane.showMessageDialog(null, "nomes\n");
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}
我正在尝试从数据库中搜索并在 jTable 上显示数据,但是,我也想显示相似的名称。
问题是,用'similar to'或'like'在任何位置显示相似的名字?
例如,如果用户在 jTextField 上搜索“Santos”,我想在 jTable 中显示“Lucas Santos”和“Santos Jr”。
try{
Connection cn=DB.connector.getConnection();
PreparedStatement ps=cn.prepareStatement("select cad_nome,cad_apelido,cad_cpf,cad_idade,cad_data from cad_pessoa where cad_nome similar to ? order by cad_nome asc, cad_cpf asc nulls last ");
if(jTextFieldNOME.getText().equals("")){
//JOptionPane.showMessageDialog(null, "Por favor completar o campo CPF!\n");
PreparedStatement stm=cn.prepareStatement("select * from cad_pessoa ");
ResultSet rs = stm.executeQuery();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}
}
//else {
ps.setString(1, jTextFieldNOME.getText());
ResultSet rs = ps.executeQuery();
ps.execute();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}
}
catch (Exception e)
{
JOptionPane.showMessageDialog(this, e);
}
}
这是我针对此问题使用的解决方案:
else if(jTextFieldNOME.getText() != null) {
PreparedStatement ps=cn.prepareStatement("select cad_nome,cad_apelido,cad_cpf,cad_idade,cad_data from cad_pessoa where cad_nome like ? order by cad_nome asc, cad_cpf asc nulls last ");
ps.setString(1,"%" + jTextFieldNOME.getText() + "%");
ResultSet rs = ps.executeQuery();
ps.execute();
DefaultTableModel tm=(DefaultTableModel) jTableDADOS.getModel();
tm.setRowCount(0);
JOptionPane.showMessageDialog(null, "nomes\n");
while(rs.next()){
Object o []= {rs.getString("cad_cpf"), rs.getString("cad_nome"), rs.getString("cad_apelido"), rs.getString("cad_idade"), rs.getDate("cad_data")};
tm.addRow(o);
}