Druid 简单使用

下面直接通过 Java 代码使用 Druid 数据库连接池(使用手动创建的 Map 进行创建)连接到 MySQL 数据并获取一个数据库连接,通过该连接获取当前数据库的时间戳。

环境

JDK版本:1.8

MySQL版本:5.7.*

Maven 依赖

将下面依赖信息添加到 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>

Java 代码

下面代码通过 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

说说我的看法
全部评论(
没有评论
关于
本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,请来信告知:hxstrive@outlook.com
公众号