Java 操作数据库时候出现错误,找了很久没有解决问题。我是新手请大神指教,谢谢了
错误:Exceptioninthread"main"java.lang.NullPointerExceptionatHome_look.BookDemo.dbquery(...
错误:Exception in thread "main" java.lang.NullPointerException
at Home_look.BookDemo.dbquery(BookDemo.java:30)
at Home_look.BookText.main(BookText.java:9)
//数据库操作类BookDemo
package Home_look;
import java.sql.*;
public class BookDemo {
Connection conn=null;
PreparedStatement stmt=null;
ResultSet rs=null;
public Connection connDrive(){
String dbDrive="com.microsoft.sqlserver.jdbc.SQLServerDriver";
String url="jdbc:sqlserver://localhost:1433;DatabaseName=FJlable";
String dbName="sa";
String dbPass="7540000E";
try{
Class.forName(dbDrive);
conn=DriverManager.getConnection(url,dbName,dbPass);
}catch(ClassNotFoundException e){
e.printStackTrace();
System.out.println("加载数据库驱动失败,请检查驱动是否写错。");
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库路径,用户,密码错误,请检查输入是否正确。");
}catch(NullPointerException e){
e.printStackTrace();
System.out.println("数据库服务没有开启,请检查服务。开启服务在试一试。");
}
return conn;
}
//数据库查询方法
public ResultSet dbquery(String sql,String[] paras){
try{
//提示这一行有问题
stmt=conn.prepareStatement(sql);
for(int i=0;i<paras.length;i++){
stmt.setString(i+1,paras[i]);
}
rs=stmt.executeQuery();
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库查询错误,请检查数据或查询语句错误。");
}
return rs;
}
public boolean dbupdate(String sql,String[]paras){
boolean b=true;
try{
stmt=conn.prepareStatement(sql);
for(int i=1;i<paras.length;i++){
stmt.setString(i+1, paras[i]);
}
stmt.execute();//执行增删改语句
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库在增删改中出现错误,请检查。");
b=false;
}
return b;
}
public void close(){
try{
if(rs!=null){
rs.close();
}
if(stmt!=null){
stmt.close();
}
if(conn!=null){
conn.close();
}
}catch(Exception e){
System.out.println("执行关闭数据库语句错误。");
}
}
}
//主方法调用
package Home_look;
public class BookText {
public static void main(String[] ages){
BookDemo books=new BookDemo();
String booksql="select * from bookDate";
String id = null;
String []sid={id};
//提示这一行也有问题
books.dbquery(booksql,sid );
}
} 展开
at Home_look.BookDemo.dbquery(BookDemo.java:30)
at Home_look.BookText.main(BookText.java:9)
//数据库操作类BookDemo
package Home_look;
import java.sql.*;
public class BookDemo {
Connection conn=null;
PreparedStatement stmt=null;
ResultSet rs=null;
public Connection connDrive(){
String dbDrive="com.microsoft.sqlserver.jdbc.SQLServerDriver";
String url="jdbc:sqlserver://localhost:1433;DatabaseName=FJlable";
String dbName="sa";
String dbPass="7540000E";
try{
Class.forName(dbDrive);
conn=DriverManager.getConnection(url,dbName,dbPass);
}catch(ClassNotFoundException e){
e.printStackTrace();
System.out.println("加载数据库驱动失败,请检查驱动是否写错。");
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库路径,用户,密码错误,请检查输入是否正确。");
}catch(NullPointerException e){
e.printStackTrace();
System.out.println("数据库服务没有开启,请检查服务。开启服务在试一试。");
}
return conn;
}
//数据库查询方法
public ResultSet dbquery(String sql,String[] paras){
try{
//提示这一行有问题
stmt=conn.prepareStatement(sql);
for(int i=0;i<paras.length;i++){
stmt.setString(i+1,paras[i]);
}
rs=stmt.executeQuery();
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库查询错误,请检查数据或查询语句错误。");
}
return rs;
}
public boolean dbupdate(String sql,String[]paras){
boolean b=true;
try{
stmt=conn.prepareStatement(sql);
for(int i=1;i<paras.length;i++){
stmt.setString(i+1, paras[i]);
}
stmt.execute();//执行增删改语句
}catch(SQLException e){
e.printStackTrace();
System.out.println("数据库在增删改中出现错误,请检查。");
b=false;
}
return b;
}
public void close(){
try{
if(rs!=null){
rs.close();
}
if(stmt!=null){
stmt.close();
}
if(conn!=null){
conn.close();
}
}catch(Exception e){
System.out.println("执行关闭数据库语句错误。");
}
}
}
//主方法调用
package Home_look;
public class BookText {
public static void main(String[] ages){
BookDemo books=new BookDemo();
String booksql="select * from bookDate";
String id = null;
String []sid={id};
//提示这一行也有问题
books.dbquery(booksql,sid );
}
} 展开
2个回答
展开全部
这是典型的空指针异常,就是编码中对应的变量为空,然后调用对应的方法或属性导致的,看了一下,有2个问题:
String []sid={id}; 这行代码的意思是传入了一个NULL值的sid变量
books.dbquery(booksql,sid );调用查询方法,查询方法中有【for(int i=0;i<paras.length;i++){】循环初始化参数处理,但此时参数是空,没有判断空的地方,所以这句话直接抛出空指针异常了。
修改,A:将传入参数进行赋值,如 11等数据 B:在查询方法中增加判断空的处理,这样的程序才是完整的。
追问
追答
//修改的是这样的
stmt=conn.prepareStatement(sql);
if(paras!=null){
for(int i=0;i<paras.length;i++){
。。。。
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询