package com.util; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class SQLConn { static Connection conn;//打开数据库 static Statement stmt;//运行SQL语句 ResultSet rs;//封装 //打开数据库 public static void openDB(){ try { Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); String id="sa"; String pwd="ZhongW123"; String url= //"jdbc:sqlserver://127.0.0.1:1433;databaseName=ZhongYaoYuanSys"; "jdbc:sqlserver://localhost:1433;" + "databaseName=ZhongYaoYuanSys;integratedSecurity=true;"; try { conn = DriverManager.getConnection(url, id, pwd); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } //执行增删改 public static int execUpdate(String sql){ int n = 0; try { stmt = conn.createStatement(); n = stmt.executeUpdate(sql);//n是受影响的行数 } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return n; } //关闭数据库 public static void closeDB(){ try { ((Connection) stmt).close(); conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } //执行查询功能 public ResultSet execQuery(){ return rs; } },找bug
时间: 2024-01-30 14:01:35 浏览: 37
在 `closeDB` 方法中,你试图将 `stmt` 对象强制转换为 `Connection` 对象并调用其 `close()` 方法,这是错误的。因为 `stmt` 是一个 `Statement` 对象,不是 `Connection` 对象。
你需要将 `((Connection) stmt).close();` 改为 `stmt.close();` 即可解决这个问题。
另外,在 `openDB` 方法中,你注释掉了连接字符串中的一行代码,导致连接字符串不完整。你应该把注释去掉以确保连接字符串正确。
最后,在 `execQuery` 方法中,你没有执行任何查询语句,所以返回的 `rs` 对象为空。你需要在这个方法中执行一个查询语句并将结果集封装到 `rs` 对象中。
希望这些建议可以帮助你找到并解决问题!
相关问题
package connectmysql; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.util.Scanner; import java.sql.SQLException; import java.sql.Statement; public class text { private final static String url ="jdbc:mysql://localhost:3306/mytextsql?severTimezone=GMT"; private final static String username="root"; private final static String password="yxh9497"; public static void main(String args[]) { try { Class.forName("com.mysql.cj.jdbc.Driver"); }catch(Exception e) { e.printStackTrace(); } try { Connection connect=DriverManager.getConnection(url,username,password); Statement stmt=connect.createStatement(); Scanner a=new Scanner(System.in); System.out.print("删除的是:"+'\n'); String a4=a.next(); String sql="delete from user where name="+a4; int i=stmt.executeUpdate(sql); if(i > 0){ System.out.println("删除成功"); } }catch(Exception e) { e.printStackTrace(); } } }
看起来您的代码是在使用Java连接MySQL数据库,并尝试删除一个名为`user`的表中的行。但是,这段代码存在一些潜在的问题。
首先,您缺少`import java.sql.SQLException`语句,因此编译器可能会报告找不到该类的错误。因此,您需要在代码顶部添加此导入语句。
其次,您在SQL语句中使用了字符串变量`a4`,但没有将其用引号括起来。这可能导致SQL语句无法正确解析,从而导致删除操作失败。因此,您需要将`a4`变量用引号括起来,以确保SQL语句正确。
最后,您使用了两个`Statement`对象,这应该会导致编译错误。您需要删除其中一个`import java.sql.Statement`语句,并将`stmt`对象的声明放置在`try`块中。
下面是修改后的代码:
```
package connectmysql;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Scanner;
import java.sql.SQLException;
public class text {
private final static String url ="jdbc:mysql://localhost:3306/mytextsql?severTimezone=GMT";
private final static String username="root";
private final static String password="yxh9497";
public static void main(String args[]) {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
}catch(Exception e) {
e.printStackTrace();
}
try {
Connection connect=DriverManager.getConnection(url,username,password);
Statement stmt=connect.createStatement();
Scanner a=new Scanner(System.in);
System.out.print("删除的是:"+'\n');
String a4=a.next();
String sql="delete from user where name='"+a4+"'";
int i=stmt.executeUpdate(sql);
if(i > 0){
System.out.println("删除成功");
}
}catch(SQLException e) {
e.printStackTrace();
}
}
}
```
希望这可以帮助您解决问题。
package com.util; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class DBConn { Connection conn; Statement stmt; ResultSet rs; //返回值 参数 public void openDB(){ try { Class.forName("com.mysql.cj.jdbc.Driver"); String url="jdbc:mysql://localhost:3306/test?useSSL=fasle&serverTimezone==GMT%2B8"; conn = DriverManager.getConnection(url,"root","123456"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public int execUpdate(String sql){ int n=0; try { stmt = conn.createStatement(); n = stmt.executeUpdate(sql); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return n; } public void closeDB(){ try { stmt.close(); conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }找错误
这段代码看起来没有明显错误,但是在使用之前需要先调用 openDB 方法来打开数据库连接。如果没有调用 openDB 方法就直接调用 execUpdate 方法,就会出现空指针异常,因为 conn 对象还没有被初始化。因此,在使用 DBConn 类的时候,需要按照以下步骤来操作:
1. 创建 DBConn 对象。
2. 调用 openDB 方法来打开数据库连接。
3. 调用 execUpdate 方法来执行 SQL 语句。
4. 调用 closeDB 方法来关闭数据库连接。
如果你已经按照以上步骤来使用 DBConn 类,但仍然出现错误,可以检查以下几个方面:
1. 检查数据库连接字符串是否正确。
2. 检查数据库用户名和密码是否正确。
3. 检查是否有足够的权限来访问数据库。
4. 检查 SQL 语句是否正确。
如果还无法解决问题,可以考虑将错误信息打印出来,以便更好地定位问题。
阅读全文