java oracle 连接池_oracle数据库连接池配置

java oracle 连接池_oracle数据库连接池配置频繁的创建和销毁数据库连接即消耗系统资源又使得程序效率低下,在这种情况下,出现了使用数据库连接池的方法,类似于线程池,初期创建一定数量的连接供应用程序使用,当使用完成后将其归还给连接池而不是销毁,这样有效的提高了资源利用率,下面分享一种简单的创建连接池的方法:1.首先,我们新建一个maven工程,并且导入ojdbc,dbcp,junit三个包待用2.然后,我…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

        频繁的创建和销毁数据库连接即消耗系统资源又使得程序效率低下,在这种情况下,出现了使用数据库连接池的方法,类似于线程池,初期创建一定数量的连接供应用程序使用,当使用完成后将其归还给连接池而不是销毁,这样有效的提高了资源利用率,下面分享一种简单的创建连接池的方法:

1.首先,我们新建一个maven工程,并且导入ojdbc  , dbcp  , junit三个包待用

创建工程并导包

2.然后,我们在src/main/resources目录下创建一个文件db,properties用以存放一些配置参数等,以后更换数据库密码什么的只需要改此文件而不是改动代码。

db.properties文件代码如下

# connection parameters
driver=oracle.jdbc.driver.OracleDriver    (数据库驱动类)



url=jdbc:oracle:thin:@localhost:1521:xe 

//jdbc协议:数据库子协议:主机:端口/连接的数据库


user=system
pwd=root

#这个没什么说的,用户名密码,自己创建数据库的时候都设置过

# datasouce parameters
initSize=1
maxSize=2

#最大连接数,这个不用管

driver的选取:

java oracle 连接池_oracle数据库连接池配置

java oracle 连接池_oracle数据库连接池配置

以上就算是准备工作

下面开始敲代码了

在src/main/java 下创建一个包,再创建一个类,名字自己取

补充两点1.Properties类专门用来读取properties文件
               2.Properties类本质上就是Map

编写如下图代码读取我们在db.properties文件中设置的参数,注意,这里我们创建的是连接池,这些内容

我们只需要加载一次,所以写在static代码块中

代码:

package util;

import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import org.apache.tomcat.dbcp.dbcp.BasicDataSource;

public class DBUtil {
    //连接池对象
    private static BasicDataSource ds;
    //加载参数
    static{
        Properties p = new Properties();
        try {
            p.load(DBUtil.class.getClassLoader().getResourceAsStream("db.properties"));
            String driver = p.getProperty("driver");
            String url = p.getProperty("url");
            String user = p.getProperty("user");
            String pwd = p.getProperty("pwd");
            String initSize = p.getProperty("initSize");
            String maxSize = p.getProperty("maxSize");
            //创建连接池
            ds = new BasicDataSource();
            //设置参数
            ds.setDriverClassName(driver);
            ds.setUrl(url);
            ds.setUsername(user);
            ds.setPassword(pwd);
            ds.setInitialSize(new Integer(initSize));
            ds.setMaxActive(new Integer(maxSize));
        } catch (IOException e) {
            e.printStackTrace();
            throw new RuntimeException("加载配置文件失败",e);
        }
    }
    /*
     * 以上就是将配置文件里的参数全部读取出来,接下来就是要
     * 写两个方法,一个是用来创建连接的,一个关闭连接
     * */
    public static Connection getConnection() throws SQLException{
        return ds.getConnection();
    }
    
    public static void close(Connection conn){
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
                throw new RuntimeException("关闭连接失败",e);
            }
        }
    }
}

写完之后,基本工作就完成了,下面我们在src/test/resources下创建一个测试类来检测我们的代码

这里我们使用的是Junit做单元测试

代码:

package test;

import java.sql.Connection;
import java.sql.SQLException;

import org.junit.Test;

import util.DBUtil;

public class Testdb {
    @Test
    public void test01(){
        Connection conn = null;
        try {
            conn = DBUtil.getConnection();
            System.out.println("OK!");
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }finally{
            DBUtil.close(conn);
        }
        
    }
}

运行上述代码得到如图所示的结果说明我们的代码是正确的

java oracle 连接池_oracle数据库连接池配置

并且控制台输出OK!

如果出现错误请检查数据库驱动类是否填写正确,数据库服务是否正常启动,

第一次写文章,纯手打,不喜勿喷谢谢,请各位大神多多指教

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193222.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java之二维数组的初始化

    java之二维数组的初始化二维数组的格式:二维数组的内存图:二维数组的例子:

    2022年5月16日
    44
  • pychram 激活码【中文破解版】

    (pychram 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/ide…

    2022年3月22日
    43
  • ODBC 安装/使用/编程

    ODBC 安装/使用/编程前言:主要讲解ODBCAPI,以mysql为例,从配置到安装,再到具体的编程,以期对ODBC有个初步的认识.*)下载mysql,选择社区版mysql,并安装http://dev.m

    2022年7月1日
    22
  • 关于java类加载正确的是_java类初始化过程

    关于java类加载正确的是_java类初始化过程注意我们当在另一个类中引用其他类的final静态值的时候,编译器把其他类的final符号引用存储在自己类的常量池中了

    2022年8月9日
    3
  • spring MVC拦截器01

    spring MVC拦截器01

    2022年1月21日
    46
  • python浮雕图片_用Python来画浮雕画

    python浮雕图片_用Python来画浮雕画浮雕艺术在世界各地都可以见到,中国古代在唐朝以来就有许多浮雕效果的东西,很多的大型纪念性建筑都有这种作为装饰,常见的有花窗,龙柱等。简单的来说,浮雕就是把所要呈现的图像突起于石头表面,根据凹凸的程度不同从而形成三维的立体感。用Python画一张浮雕画,那就进行类似的原理,通过勾画图像的轮廓,并且降低周围的像素值,那就可以产生一张具有立体感的浮雕效果图片。我们可以采用相邻像素相减的方法来得到轮廓与平…

    2022年6月20日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号