【保姆级教程+测试】在eclipse中如何连接数据库包括测试连接成功的步骤 错误:java.lang.NullPointerException
今天在复习jdbc 的时候遇到这个问题,就是我要新建一个工程连接数据库的时候出现了下面这个错误,显示空指针异常,怎么都排除不了。我把相同的代码复制到之前的工程中就可以连接数据库,所以这个时候我就断定是新建工程肯定是哪个的配置还不行。最最后排查是我的配置文件jdbc.properties,放在了工程的目录下面,而且正确的做法应该是放在src目录下面才行,所以大家一定要小心啊
那么下面就来演示一下,在eclipse中新建一个Java工程的步骤:
- 导入MySQL连接的jar包(先建立lib目录,然后把该包导入目录下面)
然后把该包引入库中
就可以看到下图;
- 导入封装好的jdbc相关操作(就是那个jdbc工具类),这个工具类是我自己写的,这个工具类(JDBCUtils)应该放在src目录下面的一个包(com.atguigu1.util)里面,具体的JDBCUtils如下:
package com.atguigu1.util;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
/**
* @Description 操作数据库的工具类
*/
public class JDBCUtils {
/*
* @Description 获取数据库的连接
*/
public static Connection getConnection() throws Exception {
// 1.读取配置文件中的4个基本信息
InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("jdbc.properties");
Properties pros = new Properties();
pros.load(is);
String user = pros.getProperty("user");
String password = pros.getProperty("password");
String url = pros.getProperty("url");
String driverClass = pros.getProperty("driverClass");
// 2.加载驱动
Class.forName(driverClass);
// 3.获取连接
Connection conn = DriverManager.getConnection(url, user, password);
return conn;
}
/**
*
* @Description 关闭连接和Statement的操作
*/
public static void closeResource(Connection conn,Statement ps){
try {
if(ps != null)
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn != null)
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
*
* @Description 关闭资源操作
*/
public static void closeResource(Connection conn,Statement ps,ResultSet rs){
try {
if(ps != null)
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(conn != null)
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
try {
if(rs != null)
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
- 还有要配置好相关的jdbc.properties文件(这个文件是放在src目录下面的一定要记住啊,之前我放在了工程目录下面,然后一直报空指针异常,怎么都发现不了,我人都傻了)
//这个文件的一些内容就是所连接数据库的一些信息
user=root
password=123456
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.jdbc.Driver
- 测试:在com.atguigu1.transaction包下面创建一个测试类ConnectionTest
package com.atguigu1.transaction;
import java.sql.Connection;
import org.junit.Test;
import com.atguigu1.util.JDBCUtils;
public class ConnectionTest {
@Test
public void testGetConnetion() throws Exception{
Connection conn = JDBCUtils.getConnection();
System.out.println(conn);
}
}
输出结果如下:说明连接数据库成功