Todos los artículos de Java JDBC de esta web y de Chuwiki los he metido en un pdf que puedes adquirir aquí pdf Java JDBC
En este tutorial tenemos un ejemplo en el que se consulta una base de datos MySQL y el resultado se muestra en un JTable. Nos centraremos en cómo meter el ResultSet en el JTable y de paso crearemos una pequeña clase ConversorResultSetADefaultTableModel que se pueda usar siempre, independientemente de la consula, la tabla, el número de columnas, etc. Eso sí, con sus limitaciones. Haremos un uso simple de ResultSetMetaData para obtener la información necesaria para este código genérico.
Presuponemos que tenemos instalado MySQL y que hemos creado una base de datos y una tabla con datos similar a la siguiente:
Es decir, una base de datos prueba con una tabla persona que tiene los campos id, nombre y nacimiento tal cual se ve en el recuadro.
También suponemos que tenemos disponible el jar con el Driver de MySQL y que lo ponemos en el CLASSPATH o lo añadimos a nuestro proyecto si usamos un IDE.
Primero se obtiene la conexión a la base de datos con un código como este:
Por supuesto tendrás que cambiar el "usuario" y "clave" por los que tú tengas en la base de datos. También, si la base de datos no corre en tu ordenador local, tienes que cambiar "localhost" por el nombre o IP del ordenador donde corra la base de datos.
El siguiente paso es realizar la consulta y obtener el ResultSet. El código es el siguiente
Para meter los datos en el JTable, usaremos un DefaultTableModel. Para ello basta con instanciar el JTable de esta forma
Ahora sólo hay que rellenar el DefaultTableModel con los datos del ResultSet. La forma "manual" de hacer esto es la siguiente
Con esto basta. Todo lo que hagamos en el DefaultTableModel se refresca automáticamente en el JTable. Por ello, según se va ejecutando este código, en el JTable se iran añadiendo automáticamente los datos.
El código que acabamos de hacer está claro que es muy dependiente de la tabla de base de datos que estamos consultando. Hay que añadir tantas columnas como campos tenga el resultado de base de datos. El nombre de las columnas depende de qué estemos consultando, es decir, un nombre de persona, una marca de coche, etc.
Sin embargo, existe una forma más o menos automática de hacer esto. Dado un ResultSet que obtenemos como consulta de base de datos, podemos interrogarle sobre cuántas columnas tiene y cuáles son los nombres de sus campos. Con ello, podemos hacer el código anterior de forma genérica, de tal manera que sólo teniendo el ResultSet y le DefaultTableModelo, podemos rellenarlo sin saber en absoluto qué consulta ni qué tablas se han consultado.
Para obtener esta información, hay que pedirle los MetaDatos al ResulSet. El código que lo hace es este
La clase ResultSetMetaData contiene toda la información sobre los campos de base de datos contenidos en el ResultSet. Necesitamos preguntarle por el número de columnas y por la etiqueta para cada una de las columnas. Este es el código que lo hace
Listo. Ya hemos obtenido de forma genérica la información necesaria para rellenar el DefaultTableModel.
En la clase ConversorResultSetADefaultTableModel del ejemplo se hace precisamente esto. Se le pasa un DefaultTableModel y un ResultSet y se encarga de meter los datos de un lado a otro, utilizando este código genérico que hemos hecho. Una vez que tenemos el array de etiquetas, basta hacer esta llamada al DefaultTableModelo para configurar su número de columnas
El relleno de los datos es inmediato. Igual que el código "manual", pero se puede quitar el "3" y poner un "numeroColumnas".
En ResultSetATableModel.zip tienes los fuentes completos del ejemplo. Si tienes configurada la base de datos como se indicó al principio y tienes un usuario y password similar al del código, puedes desempaquetar, compilar y ejecutar con
Puesto que en el código de ejemplo he puesto que cada segundo se realice la consulta nuevamente y se refresquen los datos, mientras el progrma está en marcha puedes modificar, añadir o borrar datos de la tabla de base de datos. Verás como se actualizan en el JTable.
Puedes revisar los fuentes de ejemplo. La clase realmente interesante es ConversorResultSetADefaultTableModel que posiblemente puedas reutilzar tal cual o con pequeños cambios en tus proyectos.
Una pequeña observación respecto al código. Como SWING no es thread-safe, es decir, no se puede usar alegremente con varios hilos. Como en el ejemplo hay dos hilos: el del main y el de AWT, me he visto obligado en los sitios en que modifico el DefaultTableModel a usar un SwingUtilities.invokeAndWait(). Si quitas eso, es posible que te salten excepciones en el repintado del JTable (es lo que me pasaba a mí y por eso tuve que ponerlo).