zoukankan      html  css  js  c++  java
  • c3p0使用连接时连接mysql数据库

    1. 在src下新建c3p0-config.xml配置文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <c3p0-config>
        <named-config name="mysql">
            <!-- 配置数据库用户名 -->
            <property name="user">root</property>
            <!-- 配置数据库密码 -->
            <property name="password">123456</property>
            <!-- 配置数据库链接地址 -->
            <property name="jdbcUrl">jdbc:mysql://localhost:3306/jt-db?useUnicode=true&amp;characterEncoding=UTF-8
            </property>
            <!-- 配置数据库驱动 -->
            <property name="driverClass">com.mysql.jdbc.Driver</property>
            <!-- 数据库连接池一次性向数据库要多少个连接对象 -->
            <property name="acquireIncrement">20</property>
            <!-- 初始化连接数 -->
            <property name="initialPoolSize">10</property>
            <!-- 最小连接数 -->
            <property name="minPoolSize">5</property>
            <!--连接池中保留的最大连接数。Default: 15 -->
            <property name="maxPoolSize">30</property>
            <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements 属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default:0 -->
    <!--
            <property name="maxStatements">0</property>
    -->
            <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
    <!--
            <property name="maxStatementsPerConnection">0</property>
    -->
            <!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能 通过多线程实现多个操作同时被执行。Default:3 -->
    <!--
            <property name="numHelperThreads">3</property>
    -->
            <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
    <!--
            <property name="propertyCycle">3</property>
    -->
            <!-- 获取连接超时设置 默认是一直等待单位毫秒 -->
    <!--
            <property name="checkoutTimeout">1000</property>
    -->
            <!--每多少秒检查所有连接池中的空闲连接。Default: 0 -->
    <!--
            <property name="idleConnectionTestPeriod">3</property>
    -->
            <!--最大空闲时间,多少秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
    <!--
            <property name="maxIdleTime">10</property>
    -->
            <!--配置连接的生存时间,超过这个时间的连接将由连接池自动断开丢弃掉。当然正在使用的连接不会马上断开,而是等待它close再断开。配置为0的时候则不会对连接的生存时间进行限制。 -->
    <!--
            <property name="maxIdleTimeExcessConnections">5</property>
    -->
            <!--两次连接中间隔时间,单位毫秒。Default: 1000 -->
    <!--
            <property name="acquireRetryDelay">1000</property>
    -->
            <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。Default: null -->
    <!--
            <property name="automaticTestTable">Test</property>
    -->
            <!-- 获取connnection时测试是否有效 -->
            <!--<property name="testConnectionOnCheckin">true</property>-->
        </named-config>
        <!-- </default-config> -->
    
    </c3p0-config>

    2. 创建工具类,获得数据库连接

    package com.tedu.utils;
    
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    
    import com.mchange.v2.c3p0.ComboPooledDataSource;
    public class JDBCUtils {
        //初始化连接池
        //加载名字为“mysql”的配置文件
        private static ComboPooledDataSource dataSource = 
                new ComboPooledDataSource("mysql");
        /**
         * 获取Connection连接
         * @return
         */
        public static Connection getConnection(){
            Connection conn = null;
            try {
                conn = dataSource.getConnection();
                return conn;
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return conn;
        }
    
        /**
         * 关闭连接
         * @param con
         * @param ps
         * @param rs
         */
        public static void close(Connection con,PreparedStatement ps,ResultSet rs){
            try {
                if(rs!=null){
                    rs.close();
                }
                if(ps!=null){
                    ps.close();
                }
                //暂时先不关闭关闭总是会无法连接数据
                if(con!=null){
                    con.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        
        /**
         * 关闭连接
         * @param con
         * @param ps
         */
        public static void close(Connection con,PreparedStatement ps){
            try {
                
                if(ps!=null){
                    ps.close();
                }
                //暂时先不关闭关闭总是会无法连接数据
                if(con!=null){
                    con.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    
    
    }
  • 相关阅读:
    在ElementUI的 MessageBox 弹框 进行api接口请求
    Vue 报错 (Emitted value instead of an instance of Error) the "scope" attribute for scoped slots have been deprecated and replaced by "slot-scope" since 2.5. The new "slot-scope" attribute can also be u
    子组件 修改父组件的属性值
    1、Flutter---配置
    Vant轮播预览图片
    vue 中 v-for 和 :key 配套使用
    js--两数之和
    blazor 中没有 blazor WebAssembly App 模板
    Deepin 安装vue-cli
    C# Linq Join & Lambda Join
  • 原文地址:https://www.cnblogs.com/gxlaqj/p/11400606.html
Copyright © 2011-2022 走看看