JDBC学习笔记(二)

JDBC控制事务:

事务:一个包含多个步骤的业务操作。如果这个业务操作被事务管理,则要么多个步骤同时成功,要么同时失败。

操作:1.开启事务  2.提交事务  3. 回滚事务

使用Connection对象管理事务

try {
            //开启事务
            conn.setAutoCommit(false);
            需要事务管理的操作 
            //提交事务
            conn.commit();
            }
        } catch (Exception e) {
            try {
                if (conn != null) {
                    //事件回滚
                    conn.rollback();
                }
            } catch (SQLException e1) {
                e1.printStackTrace();
            }
            e.printStackTrace();
        }finally {
            释放资源
        }

数据库连接池:

概念:其实就是一个容器(集合),存放数据库连接的容器。

当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完值后,会将连接对象归还给容器。

好处:1.节约资源   2. 用户访问高效

实现:

1标准接口:DataSoure  javax.sql包下的  方法:获取连接:getConnection()  归还连接:Connection.close()只是归还不会关闭连接 

2一般我们不去实现它,有数据库其他厂商来实现 C3P0:数据库连接池技术  Druid:数据库连接池实现技术,由阿里巴巴提供的

C3P0:数据库连接池技术

步骤:1导入jar包(两个)c3p0-0.9.5.2-sources.jar  、mchange-commons-java-0.2.11-sources.jar

2.定义配置文件:名称:c3p0.properties 或者 c3p0-config.xml  放在src目录下

3.创建核心对象  数据库连接池对象  ComboPooledDateSoure

要注意c3p0和jdbc的版本问题!!!

c3p0下载地址:https://download.csdn.net/download/weixin_41568914/11103542

c3p0配置文件信息:

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
    <default-config>
        <!-- 连接参数 -->
        <property name="driverClass">com.mysql.cj.jdbc.Driver</property>
        <property name="jdbcUrl">jdbc:mysql://localhost:3306/db4?useSSL=false</property>
        <property name="user">root</property>
        <property name="password">root</property>

        <!-- 连接池参数 -->
        <!-- 初始化申请的连接数量 -->
        <property name="initialPoolSize">5</property>
        <!-- 最大的连接数量 -->
        <property name="maxPoolSize">10</property>
        <!-- 超时时间 -->
        <property name="checkoutTimeout">3000</property>
    </default-config>
    <named-config name="otherc3p0">
        <!-- 连接参数 -->
        <property name="driverClass">com.mysql.cj.jdbc.Driver</property>
        <property name="jdbcUrl">jdbc:mysql://localhost:3306/db4?useSSL=false</property>
        <property name="user">root</property>
        <property name="password">root</property>
        <!-- 连接池参数 -->
        <property name="initialPoolSize">5</property>
        <property name="maxPoolSize">8</property>
        <property name="checkoutTimeout">1000</property>
    </named-config>

检测是否可以成功连接

 public static void main(String[] args) throws Exception {
        DataSource ds = new ComboPooledDataSource();
        Connection conn = ds.getConnection();
        System.out.println(conn);
    }

Druid的使用

下载Druid的jar包

导入Druid的jar包

配置文件

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///db3?useUnicode=true&characterEncoding=UTF-8&useSSL=false
username=root
password=root
#初始化连接数
initialSize=5
#最大连接数
maxActive=10
#最大等待时间
maxWait=3000

druid使用

public static void main(String[] args) throws Exception {
        Properties pro = new Properties();
        InputStream is = Demo1.class.getClassLoader().getResourceAsStream("druid.properties");
        pro.load(is);
        DataSource ds = DruidDataSourceFactory.createDataSource(pro);
        Connection connection = ds.getConnection();
        System.out.println(connection);
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值