【保姆级教程+测试】在eclipse中如何连接数据库包括测试连接成功的步骤 错误:java.lang.NullPointerException

【保姆级教程+测试】在eclipse中如何连接数据库包括测试连接成功的步骤 错误:java.lang.NullPointerException

今天在复习jdbc 的时候遇到这个问题,就是我要新建一个工程连接数据库的时候出现了下面这个错误,显示空指针异常,怎么都排除不了。我把相同的代码复制到之前的工程中就可以连接数据库,所以这个时候我就断定是新建工程肯定是哪个的配置还不行。最最后排查是我的配置文件jdbc.properties,放在了工程的目录下面,而且正确的做法应该是放在src目录下面才行,所以大家一定要小心啊
在这里插入图片描述
那么下面就来演示一下,在eclipse中新建一个Java工程的步骤:

  1. 导入MySQL连接的jar包(先建立lib目录,然后把该包导入目录下面)
    在这里插入图片描述
    然后把该包引入库中
    在这里插入图片描述
    就可以看到下图;
    在这里插入图片描述
  2. 导入封装好的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();
		}
	}
}

  1. 还有要配置好相关的jdbc.properties文件(这个文件是放在src目录下面的一定要记住啊,之前我放在了工程目录下面,然后一直报空指针异常,怎么都发现不了,我人都傻了)
//这个文件的一些内容就是所连接数据库的一些信息
user=root
password=123456
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.jdbc.Driver
  1. 测试:在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);
	}

}

输出结果如下:说明连接数据库成功
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值