下面直接通过 Java 代码使用 Druid 数据库连接池(通过属性文件的方式进行创建)连接到 MySQL 数据并获取一个数据库连接,通过该连接获取当前数据库的时间戳。
JDK版本:1.8
MySQL版本:5.7.*
将下面依赖信息添加到 pom.xml 文件:
<!-- https://mvnrepository.com/artifact/com.alibaba/druid --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.15</version> </dependency> <!-- 数据库驱动依赖 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.38</version> </dependency>
在项目的 resources 目录下创建 druid.properties 属性文件,内容如下:
driverClassName=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false username=root password=aaaaaa # 初始化连接数量 initialSize=5 # 最大连接数 maxActive=10 # 最大等待时间 maxWait=3000 minIdle=3
下面代码通过 DruidDataSourceFactory.createDataSource() 方法创建一个 DataSource 对象,然后使用 DataSource 的 getConnection() 方法获取数据库连接。代码如下:
package com.hxstrive.jdbc_pool.druid;
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Properties;
/**
* Druid 简单用法
* @author hxstrive.com
*/
public class DruidHello {
public static void main(String[] args) throws Exception {
Connection connection = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
Properties properties = new Properties();
InputStream is = DruidHello.class.getClassLoader().getResourceAsStream("druid.properties");
properties.load(is);
DataSource dataSource = DruidDataSourceFactory.createDataSource(properties);
connection = dataSource.getConnection();
ps = connection.prepareStatement("select CURRENT_TIMESTAMP() as ct");
rs = ps.executeQuery();
if (rs.next()) {
System.out.println(rs.getTimestamp("ct"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
// 释放资源
if(null != rs) {
rs.close();
}
if(null != ps) {
ps.close();
}
if(null != connection) {
connection.close();
}
}
}
}运行代码,输出如下:
2023-07-11 12:33:45.0