0

最近我正在为一个大学项目学习一些 HTML、JSP 和 servlet,问题是我将一个数据库放入 MySQL Workbench,其中 id 主键、自动增量,然后是一些字段,如用户名、密码、名字、姓氏等上。

目标是创建一个登录页面和注册页面,出于某种原因,如果我使用 MySQL Workbench 将数据推送到数据库中,它将让我使用我的登录表单和我的选择语句检索它,但出于某种原因,我正在做同样的事情注册的东西,但在这种情况下使用查询 INSERT。

因此,经过研究,我做了 preparestatment 并将 executeQuery 更改为 executeUpdate 和所有内容,但我的日志在某处显示 nullPointerException,我知道这可能是一个简单而愚蠢的错误,我没有看到,但我是新手。到目前为止,这是您将数据插入我的数据库中所做的:

public static UserBean registarUsuario(UserBean bean){

            //preparing some objects for connection 
     Statement stmt = null;    
     ResultSet rs = null;  

    try {
        Class.forName("com.mysql.jdbc.Driver");
    } catch (ClassNotFoundException ex) {
        System.out.println("Error al cargar el driver");
        System.out.println(ex.getMessage());
    }

     String firstname = bean.getFirstName();    
     String lastname = bean.getLastName(); 
     String username = bean.getUsername();    
     String password = bean.getPassword();   
     boolean admin = bean.isAdmin(); 
     int tipo = bean.getType(); 
        String insertQuery =
           "insert into idusuario (firstname,lastname,username,password,admin,tipo) values ('"+firstname+"','"+lastname+"','"+username+"','"+password+"','"+admin+"','"+tipo+"')";

        System.out.println("Firstname is " + firstname);          
  System.out.println("Surname is " + lastname);
  System.out.println("Query: "+insertQuery);

  try 
  {
     //connect to DB 
     currentCon = DriverManager.getConnection("jdbc:mysql://localhost:3306/usuarios", "root", "admin");
     rs = stmt.executeQuery(insertQuery);
...

我的输出:

信息:查询:插入 idusuario(名字、姓氏、用户名、密码、管理员、tipo)值('jhon'、'marston'、'jmar'、'123'、'true'、'0') 信息:错误: java.lang.NullPointerException

问题是 Netbeans 甚至没有告诉我 NPE 发生在哪里,所以我有点困惑,我不知道查询是否错误或者是否有其他问题,因为正如我在输出中看到的那样,查询似乎没问题。

我把你留在这里我的数据库结构

在此处输入图像描述

4

2 回答 2

3

您正在分配stmtas null 并且从不初始化它。

 Statement stmt = null;    
 ResultSet rs = null;  

然后你正在尝试使用它:

 rs = stmt.executeQuery(insertQuery);

在使用它之前,您需要执行以下操作:

PreparedStatement stmt=currentCon.prepareStatement(yourQuery);
于 2018-05-17T18:50:58.967 回答
1

因此,经过研究,我做了 preparestatment 并将 executeQuery 更改为 executeUpdate 和所有内容,但我的日志在某处显示 nullPointerException,我知道这可能是一个简单而愚蠢的错误,我没有看到,但了解我在这方面是新的。这是我迄今为止所做的将数据插入我的数据库

当我们使用insert时,update或者delete我们需要使用executeUpdate。当我们使用时,select我们需要使用executeQuery.

在您的示例中,您正在executeQueryinsert. 这是错误的。你需要使用这个:

rs = stmt.executeUpdate(insertQuery);

你得到一个 NPE 是因为你试图在没有结果的地方检索结果。

这是帮助您减少样板代码的一件好事...(因此您不必不断重复自己的数据库初始化值)

为您的数据库连接创建一个类:

public class DBConnection {
    private static String url = null;
    private static Connection conn = null;
     public static Connection getConnection(){
     try{
       Class.forName("com.mysql.jdbc.Driver");
       url = "jdbc:mysql://localhost:3306/usuarios";
       conn = DriverManager.getConnection(url,"root","admin");
     }   catch (Exception e) {
            System.out.println(e);
        } 
     return conn;
     }
}

现在您可以在所有其他类中使用它,如下所示:

public static UserBean registarUsuario(UserBean bean){
          try(Connection conn= DBConnection.getConnection()){
              PreparedStatement pst = conn.prepareStatement("insert into idusuario (firstname,lastname,username,password,admin,tipo) values (?,?,?,?,?,?);");  
              pst.setString(1, bean.getFirstName());
              pst.setString(2, bean.getLastName());
              pst.setString(3, bean.getUserName());
              pst.setString(4, bean.getPassword());
              pst.setBoolean(5, bean.isAdmin());
              pst.setInt(6, bean.getType());
                pst.executeUpdate();    
          }catch (SQLException e) {
                e.printStackTrace();
            }

    }
于 2018-05-17T19:03:57.700 回答