1、数据库连接配置文件druid.properties
需要修改的地方:
- 数据库端口号和数据库名称
- 数据库用户名和密码
- 看代码中间一段注释
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);
//有些方法可能需要抛异常
经历无数报错之后的吐血总结,这以后数据库连接再也没能难倒我。
如果还是连不上,只有一个原因。数据库启动!!!