mysql数据库连接:Java-mysql8.0.11-jdk1.9

1、数据库连接配置文件druid.properties

需要修改的地方:

  1. 数据库端口号和数据库名称
  2. 数据库用户名和密码
  3. 看代码中间一段注释
driverClassName=com.mysql.cj.jdbc.Driver
url = jdbc:mysql://localhost:3306/day17?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone =GMT
username=root
password=123456
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000

//看自己是否需要下面的配置,一般连接数据库上面的代码就够了
//下面的配置是我利用Maven构建项目时,只用上面的代码会报错。
filters=stat
timeBetweenEvictionRunsMillis=60000
minEvictableIdleTimeMillis=300000
validationQuery=SELECT 1
testWhileIdle=true
testOnBorrow=false
testOnReturn=false
poolPreparedStatements=false
maxPoolPreparedStatementPerConnectionSize=200

2、需要的jar包

在这里插入图片描述
有需要私信我,免费分享。

3、数据库连接类JDBCutils.java

(阿里写的)粘贴复制即可


import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

/*
	1. 声明静态数据源成员变量
	2. 创建连接池对象
	3. 定义公有的得到数据源的方法
	4. 定义得到连接对象的方法
	5. 定义关闭资源的方法
 */
public class JDBCUtils {
     
	// 1.	声明静态数据源成员变量
	private static DataSource ds;

	// 2. 创建连接池对象
	static {
     
		// 加载配置文件中的数据
		InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
		Properties pp = new Properties();
		try {
     
			pp.load(is);
			// 创建连接池,使用配置文件中的参数
			ds = DruidDataSourceFactory.createDataSource(pp);
		} catch (IOException e) {
     
			e.printStackTrace();
		} catch (Exception e) {
     
			e.printStackTrace();
		}
	}

	// 3. 定义公有的得到数据源的方法
	public static DataSource getDataSource() {
     
		return ds;
	}

	// 4. 定义得到连接对象的方法
	public static Connection getConnection() throws SQLException {
     
		return ds.getConnection();
	}

	// 5.定义关闭资源的方法
	public static void close(Connection conn, Statement stmt, ResultSet rs) {
     
		if (rs != null) {
     
			try {
     
				rs.close();
			} catch (SQLException e) {
     }
		}

		if (stmt != null) {
     
			try {
     
				stmt.close();
			} catch (SQLException e) {
     }
		}

		if (conn != null) {
     
			try {
     
				conn.close();
			} catch (SQLException e) {
     }
		}
	}

	// 6.重载关闭方法
	public static void close(Connection conn, Statement stmt) {
     
		close(conn, stmt, null);
	}
}

4、数据库连接代码(结束)

JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
//接下来直接用对象template调用方法执行SQL语句就行。
//如
template.query(String sql);

template.updata(String sql);
//有些方法可能需要抛异常

经历无数报错之后的吐血总结,这以后数据库连接再也没能难倒我。

如果还是连不上,只有一个原因。数据库启动!!!

你可能感兴趣的:(MySQL,java,jdbc)