Foros del Web » Programación para mayores de 30 ;) » Java »

[SOLUCIONADO] Problema NullPointerException

Estas en el tema de Problema NullPointerException en el foro de Java en Foros del Web. Hola a todos! Antes que todo debo aclarar que hace poco empecé con JAVA y JFrame para la interfaz. Ahora el problema es el siguiente, ...
  #1 (permalink)  
Antiguo 26/11/2013, 01:24
 
Fecha de Ingreso: noviembre-2013
Mensajes: 5
Antigüedad: 11 años
Puntos: 0
Exclamación Problema NullPointerException

Hola a todos!

Antes que todo debo aclarar que hace poco empecé con JAVA y JFrame para la interfaz.
Ahora el problema es el siguiente, quiero que al presionar un botón se ejecute una consulta a la BD (MYSQL), pero siempre me aparece el mismo error:

Código:
Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
	at prueba3.conexion.crearSentencia(conexion.java:44)
	at prueba3.usuario.consultaPrueba(usuario.java:25)
	at prueba3.boton.jButton1ActionPerformed(boton.java:68)
Para esto tengo 2 clases y un JFrame Form, los cuales contienen el siguiente código:

Clase conexion:
Código:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class conexion {
    private Connection conn;
    
    public conexion(){
        registrar();
        obtenerConexion();
    }
    
    private String registrar(){
        try{
            Class.forName("com.mysql.jdbc.Driver");
            return "exito";
        }catch(ClassNotFoundException e){
            return "no registrado";
        }
    }
    
    private String obtenerConexion(){
        try{
            conn = DriverManager.getConnection("jdbc:mysql://localhost/prueba","root","");
            return "exito";
        }catch(SQLException e){
            return "no conectado";
        }
    }
    
    public Statement crearSentencia(){
        try{
            return conn.createStatement();
        }catch(SQLException e){
            return null;
        }
    }
}


Clase usuario:
Código:
import java.sql.ResultSet;
import java.sql.SQLException;

public class usuario {
    
    private conexion c;
    
    public usuario(){
        c = new conexion();
    }
    
    public ResultSet consultaPrueba(){
    
        try{
            ResultSet respuesta = c.crearSentencia().executeQuery("select * from usuario");
            return respuesta;
        }catch(SQLException e){
            return null;
        }
    }
    
}

JFrame Form acción del botón:
Código:
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                         
        // TODO add your handling code here:
        
        usuario usu = new usuario();
        
        ResultSet rs = usu.consultaPrueba();
        try{
            while(rs.next()){
                System.out.println(rs.getInt("id"));
                System.out.println(rs.getString("clave"));
            }
        }catch(SQLException e){
            System.out.println(e.getMessage());
        }
    }

¿Qué es lo que estoy haciendo mal?

Saludos y cualquier ayuda será bienvenida, gracias de antemano.
  #2 (permalink)  
Antiguo 26/11/2013, 02:13
Avatar de Fuzzylog  
Fecha de Ingreso: agosto-2008
Ubicación: En internet
Mensajes: 2.511
Antigüedad: 16 años, 3 meses
Puntos: 188
Respuesta: Problema NullPointerException

Imprime por consola lo que sale por pantalla al crear la conexion (System.out en el try y catch de cada método), porque me parece que te da una excepción anterior y no se crea.
__________________
if (fuzzy && smooth) {
fuzzylog = "c00l";
return true;
}
  #3 (permalink)  
Antiguo 26/11/2013, 03:39
 
Fecha de Ingreso: noviembre-2013
Mensajes: 5
Antigüedad: 11 años
Puntos: 0
Respuesta: Problema NullPointerException

Gracias por responder tan pronto Fuzzylog. He modificado la clase conexion imprimiendo por consola como sugeriste y dio el siguiente resultado:

Código:
no registrado
no conectado
exito crear sentencia
Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
	at prueba3.conexion.crearSentencia(conexion.java:49)
	at prueba3.usuario.consultaPrueba(usuario.java:25)
	at prueba3.boton.jButton1ActionPerformed(boton.java:68)
Esto quiere decir que hay errores de conexión con la BD, pero no logro identificar lo malo del código, pues esa clase conexión funciona perfectamente en otro ejercicio que tengo pero que no utiliza JFrame.
  #4 (permalink)  
Antiguo 26/11/2013, 04:13
Avatar de Fuzzylog  
Fecha de Ingreso: agosto-2008
Ubicación: En internet
Mensajes: 2.511
Antigüedad: 16 años, 3 meses
Puntos: 188
Respuesta: Problema NullPointerException

Empieza por resolver lo que ya sabes que empieza mal y el resto o se soluciona sólo o se resuelve después:

https://www.google.es/search?q=com.m...sm=93&ie=UTF-8
__________________
if (fuzzy && smooth) {
fuzzylog = "c00l";
return true;
}
  #5 (permalink)  
Antiguo 26/11/2013, 13:19
Avatar de chuidiang
Colaborador
 
Fecha de Ingreso: octubre-2004
Mensajes: 3.774
Antigüedad: 20 años, 1 mes
Puntos: 454
Respuesta: Problema NullPointerException

Hola:

¿Cual es exactamente la linea 49 de conexion.java?

at prueba3.conexion.crearSentencia(conexion.java:49)

Se bueno.
__________________
Apuntes Java
Wiki de Programación
  #6 (permalink)  
Antiguo 26/11/2013, 14:27
 
Fecha de Ingreso: noviembre-2013
Mensajes: 5
Antigüedad: 11 años
Puntos: 0
Respuesta: Problema NullPointerException

Hola chuidiang!

Las líneas de los errores corresponden a los siguientes extractos de código:

Código Java:
Ver original
  1. public Statement crearSentencia(){
  2.         try{
  3.           return conn.createStatement();  //at prueba3.conexion.crearSentencia(conexion.java:49)
  4.         }catch(SQLException e){
  5.             return null;
  6.         }
  7.     }
Código Java:
Ver original
  1. public ResultSet consultaPrueba(){
  2.    
  3.         try{
  4.             ResultSet respuesta = c.crearSentencia().executeQuery("select * from usuario"); //at prueba3.usuario.consultaPrueba(usuario.java:25)
  5.             return respuesta;
  6.         }catch(SQLException e){
  7.             return null;
  8.         }
  9.     }
Código Java:
Ver original
  1. ResultSet rs = usu.consultaPrueba(); //at prueba3.boton.jButton1ActionPerformed(boton.java:68)
  2.         try{
  3.             while(rs.next()){
  4.                 System.out.println(rs.getInt("id"));
  5.                 System.out.println(rs.getString("clave"));
  6.             }
  7.         }catch(SQLException e){
  8.             System.out.println(e.getMessage());
  9.         }
  #7 (permalink)  
Antiguo 26/11/2013, 14:37
Avatar de chuidiang
Colaborador
 
Fecha de Ingreso: octubre-2004
Mensajes: 3.774
Antigüedad: 20 años, 1 mes
Puntos: 454
Respuesta: Problema NullPointerException

Repito, "¿Cual es exactamente la linea 49 de conexion.java?". Basta con una línea concreta.

De todas formas, es mala práctica no escribir las excepciones, los return null en los catch lo unico que hacen es ocultarte el problema real. Posiblemente esté dando nullpointerexception porque devuelves un null y luego intentas usar ese null para hacer algo.

Pon en todos los catch un e.printStackTrace() y dinos la excepción que sale, y la línea exacta en la que salta.

Se bueno.
__________________
Apuntes Java
Wiki de Programación
  #8 (permalink)  
Antiguo 26/11/2013, 15:15
 
Fecha de Ingreso: noviembre-2013
Mensajes: 5
Antigüedad: 11 años
Puntos: 0
Respuesta: Problema NullPointerException

Bueno creo que no me expresé muy bien

Esta es la linea 49 de conexion:
Código Java:
Ver original
  1. public Statement crearSentencia(){
  2.         try{
  3.             return conn.createStatement(); //Linea 49
  4.         }catch(SQLException e){
  5.             return null;
  6.         }
  7.     }

De todas formas modifiqué los Catch de la clase conexión de la siguiente forma:

Código Java:
Ver original
  1. public Statement crearSentencia(){
  2.         try{
  3.             return conn.createStatement();
  4.         }catch(SQLException e){
  5.             e.printStackTrace();
  6.             throw new RuntimeException(e);
  7.         }
  8.     }

y me lanza el siguiente error:
Código:
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
	at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
	at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
	at java.lang.Class.forName0(Native Method)
	at java.lang.Class.forName(Class.java:190)
	at prueba3.conexion.registrar(conexion.java:26)
	at prueba3.conexion.<init>(conexion.java:20)
	at prueba3.usuario.<init>(usuario.java:19)
	at prueba3.boton.jButton1ActionPerformed(boton.java:66)
	at prueba3.boton.access$000(boton.java:14)
	at prueba3.boton$1.actionPerformed(boton.java:39)
	at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018)
	at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2341)
	at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
	at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
	at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
	at java.awt.Component.processMouseEvent(Component.java:6505)
	at javax.swing.JComponent.processMouseEvent(JComponent.java:3320)
	at java.awt.Component.processEvent(Component.java:6270)
	at java.awt.Container.processEvent(Container.java:2229)
	at java.awt.Component.dispatchEventImpl(Component.java:4861)
	at java.awt.Container.dispatchEventImpl(Container.java:2287)
	at java.awt.Component.dispatchEvent(Component.java:4687)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
	at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
	at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
	at java.awt.Container.dispatchEventImpl(Container.java:2273)
	at java.awt.Window.dispatchEventImpl(Window.java:2719)
	at java.awt.Component.dispatchEvent(Component.java:4687)
	at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:735)
	at java.awt.EventQueue.access$200(EventQueue.java:103)
	at java.awt.EventQueue$3.run(EventQueue.java:694)
	at java.awt.EventQueue$3.run(EventQueue.java:692)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
	at java.awt.EventQueue$4.run(EventQueue.java:708)
	at java.awt.EventQueue$4.run(EventQueue.java:706)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
	at java.awt.EventQueue.dispatchEvent(EventQueue.java:705)
	at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
	at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
	at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)
Exception in thread "AWT-EventQueue-0" java.lang.RuntimeException: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
	at prueba3.conexion.registrar(conexion.java:30)
	at prueba3.conexion.<init>(conexion.java:20)
	at prueba3.usuario.<init>(usuario.java:19)
	at prueba3.boton.jButton1ActionPerformed(boton.java:66)
	at prueba3.boton.access$000(boton.java:14)
	at prueba3.boton$1.actionPerformed(boton.java:39)
	at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018)
	at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2341)
	at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
	at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
	at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
	at java.awt.Component.processMouseEvent(Component.java:6505)
	at javax.swing.JComponent.processMouseEvent(JComponent.java:3320)
	at java.awt.Component.processEvent(Component.java:6270)
	at java.awt.Container.processEvent(Container.java:2229)
	at java.awt.Component.dispatchEventImpl(Component.java:4861)
	at java.awt.Container.dispatchEventImpl(Container.java:2287)
	at java.awt.Component.dispatchEvent(Component.java:4687)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
	at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
	at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
	at java.awt.Container.dispatchEventImpl(Container.java:2273)
	at java.awt.Window.dispatchEventImpl(Window.java:2719)
	at java.awt.Component.dispatchEvent(Component.java:4687)
	at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:735)
	at java.awt.EventQueue.access$200(EventQueue.java:103)
	at java.awt.EventQueue$3.run(EventQueue.java:694)
	at java.awt.EventQueue$3.run(EventQueue.java:692)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
	at java.awt.EventQueue$4.run(EventQueue.java:708)
	at java.awt.EventQueue$4.run(EventQueue.java:706)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
	at java.awt.EventQueue.dispatchEvent(EventQueue.java:705)
	at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
	at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
	at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)
Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
	at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
	at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
	at java.lang.Class.forName0(Native Method)
	at java.lang.Class.forName(Class.java:190)
	at prueba3.conexion.registrar(conexion.java:26)
	... 41 more
BUILD SUCCESSFUL (total time: 26 seconds)
  #9 (permalink)  
Antiguo 26/11/2013, 16:17
 
Fecha de Ingreso: noviembre-2013
Mensajes: 5
Antigüedad: 11 años
Puntos: 0
Respuesta: Problema NullPointerException

Muchas gracias a chuidang y Fuzzylog, pues ya he solucionado el problema. Era algo tan básico como agregar la librería al proyecto y yo que pensé que ya la había agregado.

Saludos y muchas gracias por su atención.

Etiquetas: bd, clase, string
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 22:23.