下面直接通过 Java 代码使用 Druid 数据库连接池(使用手动创建的 Map 进行创建)连接到 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>
下面代码通过 DruidDataSourceFactory.createDataSource() 方法创建一个 DataSource 对象,然后使用 DataSource 的 getConnection() 方法获取数据库连接。代码如下:
package com.hxstrive.jdbc_pool.druid; import com.alibaba.druid.pool.DruidDataSourceFactory; import javax.sql.DataSource; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.util.HashMap; import java.util.Map; /** * Druid 简单用法 * @author hxstrive.com */ public class DruidHello { public static void main(String[] args) throws Exception { Map<String,String> map = new HashMap<String,String>(); map.put("driverClassName", "com.mysql.jdbc.Driver"); map.put("url", "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false"); map.put("username", "root"); map.put("password", "aaaaaa"); // 初始化连接数量 map.put("initialSize", "5"); // 最大连接数 map.put("maxActive", "10"); // 最大等待时间 map.put("maxWait", "3000"); map.put("minIdle", "3"); Connection connection = null; PreparedStatement ps = null; ResultSet rs = null; try { DataSource dataSource = DruidDataSourceFactory.createDataSource(map); 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