Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - |Miguel|

#131
jperezmonge, si no me equivoco, eso me borra sólo la fila del JTable, ¿no? Todo lo que estoy haciendo va contra una base de datos.
#132
Sigue sin funcionar.
En este fragmento:
Código (java) [Seleccionar]

System.out.println("entro en el try");
for(int i=0; i<=fila; i++){
            System.out.println("Empleado: '"+rsE.getString("APELLIDO")+"'. Vuelta número: "+i);

imprime la línea de "entro en el try", pero no la otra. Es decir, salta la excepción al intentar rsE.getString("APELLIDO"), supongo. Revisaré mi forma de controlar los resultSet a ver...

Dejo aquí el código completo, por si alguien tiene mucho tiempo libre XD
http://www.mediafire.com/?xnn2pfkdkxfz15e
Versión en .txt: http://www.mediafire.com/?4vtdket2nuer36w
#133
Hola Bulld0z3r, gracias por contestar.

rsE se carga con el constructor del JFrame donde estoy trabajando mediante el siguiente método:
Código (java) [Seleccionar]

static void cargaEmpleados(){
        try{
            int id_dep = rsD.getInt("dept_no");
            seleccionaEmple(id_dep);
            rsE.first();
        }catch(Exception e){System.out.println("Error capturando depto para la tabla --> "+e);}
       
    }


A ese método lo llamo, como he dicho, en el constructor del JFrame así como en todos los eventos de los botones primero, último, anterior y siguiente. Así me aseguro que rsE tenga siempre datos y además me posiciono en el primero de ellos.

En cuanto a la condición del for, antes la tenía así pero el método getSelectedRow() devuelve enteros a partir del 0 (éste incluido) si hay algo seleccionado, es decir, si cambio la condición y está seleccionada la primera fila no entro en el bucle, ¿me equivoco?

Saludos.
#134
Hola a todos, ¿qué tal?

Bueno, llevo un par de días como un loco y no doy con el fallo en mi programa... os cuento un poco de qué va la historia. Tengo una BBDD de empleados y departamentos con una relación 1:N donde cada empleado tiene un solo departamento y los departamentos de 0 a N empleados... Pues bien, estoy programando en Java un aplicación sencilla que permita añadir, eliminar y modificar datos de cualquier empleado/departamento.

Lo tengo todo acabado, excepto un JFrame en el que arriba tengo un JTextField con el nombre de un departamento y debajo de éste un JTable en el que se muestran los datos de todos los empleados de ese departamento. Hay también botones para pasar al siguiente, anterior, primer y último departamento, con sus eventos correspondientes que vacían y rellenan de nuevo la tabla con los empleados correspondientes al departamento activo.

Y por último tengo un botón que me permitiría borrar de la BBDD el empleado que esté seleccionado. Este es el código:

Código (java) [Seleccionar]

private void jtblEmpleMouseClicked(java.awt.event.MouseEvent evt) {
       System.out.println("Entro en evento");
       int fila=jtblEmple.getSelectedRow();
       System.out.println("Fila seleccionada: "+fila);
       if(fila >= 0){
           System.out.println("entro en if");
           try{
               System.out.println("entro en el try");
               for(int i=0; i<fila+1; i++){
                   System.out.println("Empleado: '"+rsE.getString("APELLIDO")+"'. Vuelta número: "+i);
                   rsE.next();                    
               }
               System.out.println("Voy a borrar");
               //rsE.deleteRow(); línea comentada para no borrar registros en pruebas y quedarme con 0 empleados... xD
               //(aún así, esta línea me da unas veces la excepción de 'No data found' y otras la de 'estado del cursor no válido').
               System.out.println("He borrado.");
           }catch(Exception e){JOptionPane.showConfirmDialog(null, e, "Error de borrado", JOptionPane.PLAIN_MESSAGE);}
           finally{
               System.out.println("llego al finally");
               limpiaTabla();
               rellenaTabla();
               System.out.println("salgo del finally");
           }
       }
       else
           JOptionPane.showConfirmDialog(null, "Seleccione un departamento para eliminarlo.", "Error de borrado", JOptionPane.PLAIN_MESSAGE);
   }


Donde rsE es un ResultSet con todos los empleados del departamento activo y rsD es otro ResultSet con todos los departamentos. Todos esos println sobran, los he usado para ver qué hace la aplicación y esta me devuelve lo siguiente:

Cita de: NetBeans
run:
Entro en evento
Fila seleccionada: 1
entro en if
entro en el try
// aquí me salta la Excepción e
llego al finally
salgo del finally
BUILD SUCCESSFUL (total time: 10 seconds)

Este código funcionaba perfectamente para borrar departamentos... Y así llevo un par de días. Hoy he pedido ayuda al profesor y ha estado una hora  mirando y tocando sin sacar absolutamente nada, lo cual me hace pensar que seguramente será algún fallo bastante estúpido...

Gracias a todos.
#135
Java / Re: No consigo limpiar un JTable...
19 Febrero 2012, 18:45 PM
SOLUCIÓN:
Código (java) [Seleccionar]

void limpiaTabla(){
        try{
            temp = (DefaultTableModel) jtablaDepart.getModel();
            int a =temp.getRowCount()-1;
            for(int i=0; i<a; i++)
                temp.removeRow(0); //aquí estaba el error, antes pasaba la i como parametro.... soy un bacín  XD
        }catch(Exception e){
            System.out.println(e);
        }
    }
#136
Hola a todos de nuevo.
Bueno, el título lo dice todo: no soy capaz de limpiar los datos que he cargado en un JTable a través de una consulta a BBDD. Este es mi método para vaciar la dichosa tablita:
Código (java) [Seleccionar]

//parte de variables
   static ResultSet rs;
   static Statement st;
   static Connection conn;
   DefaultTableModel temp;

Código (java) [Seleccionar]
//parte de métodos
void limpiaTabla(){
       try{
           temp = (DefaultTableModel) jtablaDepart.getModel();
           int a =temp.getRowCount()-1;
           for(int i=0; i<a; i++)
               temp.removeRow(i);
       }catch(Exception e){
           System.out.println(e);
       }
   }


Java me devuelve la siguiente excepción: java.lang.ArrayIndexOutOfBoundsException: 2 >= 2

La tabla tiene 3 columnas, y (en este momento) 4 filas. Cuando llamo a limpiaTabla, me borra el primer y tercer elemento de la tabla y salta esa excepción ...
#137
Java / Re: ¿No se encuentra origen de datos?
19 Febrero 2012, 13:41 PM
Al final era lo que comentaba antes, que al compilar en una máquina de 64 bits había que bajar el JDK a uno de 32 ya que no existen ODBC's de 64.

Lo que tú dices creo que es otra cosa, los driver hay que pasárselos siempre si no me equivoco... no sé, acabo de empezar a trastear con BBDD .
#138
Java / Re: ¿Cómo creo un .exe con NetBeans?
16 Febrero 2012, 22:49 PM
es local, pero estaba metida en el directorio src, como me habías dicho por eso supongo que habrá que crear el odbc para poder acceder a ella. imagino que habrá alguna forma de decirle a la aplicación q sea ella misma la q cree el odbc para distribuir la aplicacion... pero bueno a saber como xD
#139
Java / Re: ¿Cómo creo un .exe con NetBeans?
16 Febrero 2012, 22:36 PM
Sí, algo muy parecido es como lo tengo hecho, así:
Código (java) [Seleccionar]

Toolkit kit = Toolkit.getDefaultToolkit();
Image imgIcon = kit.createImage("src/img/icono.png");
setIconImage(imgIcon);


Una cosa, cuando me voy a otra máquina, ejecuto el jar y la bbdd no funciona de nuevo, imagino q eso es porque debo crear el odbc en la otra máquina tambien?
#140
Java / Re: ¿Cómo creo un .exe con NetBeans?
16 Febrero 2012, 21:53 PM
Cierto, he probado y me funciona bien. Gracias.
No paras de contestarme cosas de forma más coherente q mi profesor... creo q te debo parte de mi nota jaja

EDITO:  la bbdd sí que funciona perfectamente, pero el icono de la aplicación no, me la cambia por la tacita de java. Eso es una gilipollez como un piano, realmente el dibujo me da igual, pero no llego a entender el porqué (eso si me preocupa más).