Java - realizar una consulta sobre un JTable a través de un JTextField, -que el usuario vaya tecleando en .

 
Vista:
Imágen de perfil de Mario
Val: 17
Ha aumentado 1 puesto en Java (en relación al último mes)
Gráfica de Java

realizar una consulta sobre un JTable a través de un JTextField, -que el usuario vaya tecleando en .

Publicado por Mario (6 intervenciones) el 14/12/2019 19:25:55
Hola expertos en la programación Java con Netbeans, un cordial saludo... quiero realizar una consulta sobre un JTable a través de un JTextField, -que el usuario vaya tecleando en el JTextField y en automático el JTable vaya mostrando el primer registro que coincida con el texto del JTextField pero sin dejar de mostrar los demás registros, (el JTable Master al subir/bajar un registro con mouseClicked o VK_UP/VK_DOWN crea un filtro en la JTable hija), ya he programado algunos eventos del JTextField pero ninguno me da el resultado que espero. Les Adjunto el codigo y una pantalla de lo que tengo.

Espero contar con su apoyo, de antemano muchas gracias ...


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
package frm;
 
import clases.Controller; // En esta clase hago las Conexiones y consultas a MySQL
 
 
public class Tablas extends javax.swing.JFrame {
 
    int idvis;
    private DefaultTableModel defaultHija;
    private DefaultTableModel mdlHija;
    private final Controller controller;
    private TableRowSorter trsfiltro;
    String filtro;
 
    public Tablas() throws SQLException {
        controller = new Controller();
        Tablas();
    }
 
    public void Tablas() throws SQLException {
        initComponents();
//        txtbuscar.addKeyListener(new KeyAdapter() {
//            @Override
//            public void keyReleased(final KeyEvent e) {
//                String cadena = (txtbuscar.getText()).toUpperCase();
//                txtbuscar.setText(cadena);
//                repaint();
//                filtro();
//            }
//        });
 
        DefaultTableModel defaultPadre = new DefaultTableModel();
        tblPadre.setModel(defaultPadre);
 
        defaultPadre.addColumn("ID");
        defaultPadre.addColumn("NOMBRE");
        defaultPadre.addColumn("ESTADO");
        defaultPadre.addColumn("MUNICIPIO");
        defaultPadre.addColumn("LOCALIDAD");
        defaultPadre.addColumn("DIRECCION");
 
        controller.getRols(defaultPadre);
        pnlPadre.setViewportView(tblPadre);
 
        tblPadre.addMouseListener(new MouseAdapter() {
            @Override
            public void mouseClicked(MouseEvent e) {
                getUserSelected(e);
            }
        });
 
        tblPadre.addKeyListener(new KeyListener() {
            @Override
            public void keyTyped(KeyEvent e) {
            }
 
            @Override
            public void keyPressed(KeyEvent e) {
            }
 
            @Override
            public void keyReleased(KeyEvent e) {
                int row = tblPadre.getSelectedRow();
                idvis = (int) tblPadre.getValueAt(row, 0);
                if (e.getKeyCode() == VK_UP) {
                    getAdministrators(idvis);
                } else if (e.getKeyCode() == VK_DOWN) {
                    getAdministrators(idvis);
                }
            }
        });
        creartblhija();
    }
 
//    public void filtro(){
//        filtro = txtbuscar.getText();
//        trsfiltro.setRowFilter(RowFilter.regexFilter(txtbuscar.getText(),0));
//    }
 
    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">
    private void initComponents() {
 
        );
 
        pack();
    }// </editor-fold>
 
    private void creartblhija() {
        defaultHija = new DefaultTableModel();
        tblHija = new JTable();
        tblHija.setModel(defaultHija);
        defaultHija.addColumn("ID");
        defaultHija.addColumn("TARJ");
        defaultHija.addColumn("ENTRADA");
        defaultHija.addColumn("SALIDA");
        defaultHija.addColumn("AREA");
        defaultHija.addColumn("ASUNTO");
        defaultHija.addColumn("IDENT");
        defaultHija.addColumn("NUM");
        defaultHija.addColumn("REF:");
        defaultHija.addColumn("RESP:");
        defaultHija.addColumn("VEH");
        controller.getAdministrators(mdlHija, idvis);
    }
 
    private void getUserSelected(MouseEvent evt) {
        int row = tblPadre.rowAtPoint(evt.getPoint());
        idvis = (int) tblPadre.getValueAt(row, 0);
        getAdministrators(idvis);
    }
 
    private void getAdministrators(Integer idvis) {
        defaultHija.setRowCount(0);
        controller.getAdministrators(defaultHija, idvis);
        pnlHija.setViewportView(tblHija);
        pnlHija.revalidate();
        pnlHija.repaint();
    }
 
    private void btnCerrarActionPerformed(java.awt.event.ActionEvent evt) {
        dispose();
    }
 
    private void txtbuscarCaretUpdate(javax.swing.event.CaretEvent evt) {
//        String bus = txtbuscar.getText().trim();
//        for (int i = 0; i < tblPadre.getRowCount(); i++) {
//            if (tblPadre.getValueAt(i, 0).equals(bus)) {
//                tblPadre.changeSelection(i, 0, false, false);
//            }
//        }
    }
 
    public static void main(String args[]) {
        try {
            for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
                if ("Windows".equals(info.getName())) {
                    javax.swing.UIManager.setLookAndFeel(info.getClassName());
                    break;
                }
            }
        } catch (ClassNotFoundException ex) {
            java.util.logging.Logger.getLogger(Tablas.class
                    .getName()).log(java.util.logging.Level.SEVERE, null, ex);
 
        } catch (InstantiationException ex) {
            java.util.logging.Logger.getLogger(Tablas.class
                    .getName()).log(java.util.logging.Level.SEVERE, null, ex);
 
        } catch (IllegalAccessException ex) {
            java.util.logging.Logger.getLogger(Tablas.class
                    .getName()).log(java.util.logging.Level.SEVERE, null, ex);
 
        } catch (javax.swing.UnsupportedLookAndFeelException ex) {
            java.util.logging.Logger.getLogger(Tablas.class
                    .getName()).log(java.util.logging.Level.SEVERE, null, ex);
        }
        //</editor-fold>
 
        /* Create and display the form */
        java.awt.EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    new Tablas().setVisible(true);
                } catch (SQLException ex) {
                    Logger.getLogger(Tablas.class.getName()).log(Level.SEVERE, null, ex);
                }
            }
        });
    }
 
    // Variables declaration - do not modify
    private javax.swing.JButton btnCerrar;
    ......
    ......
    // End of variables declaration  
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder