jdbc事务 数据源

简介: 事务:   为什么要开启事务,在程序中并不是编译过了就行了,逻辑行的同才行。   有了事务可以更好的帮我们执行逻辑数据源:    数据库连接优化 帮我们更快的链接数据库    数据源有个数据库池用的话直接从数据库池中拿就行import com.

事务:

   为什么要开启事务,在程序中并不是编译过了就行了,逻辑行的同才行。

   有了事务可以更好的帮我们执行逻辑


数据源:

    数据库连接优化 帮我们更快的链接数据库

    数据源有个数据库池用的话直接从数据库池中拿就行

import com.mchange.v2.c3p0.ComboPooledDataSource;

import javax.sql.DataSource;
import java.beans.PropertyVetoException;
import java.sql.Connection;
import java.sql.SQLException;

public class T1 {
    /**
     * 常见connection对象
     */
    private static T1 ourInstance = new T1();
    private DataSource dataSource = null;//申请一个数据源 接口为空

    public static T1 getInstance() {
        return ourInstance;
    }

    private T1() {//因为这里是构造器 只要创建对象就会先调用构造器
        ComboPooledDataSource comboPooledDataSource = new ComboPooledDataSource();
        try {
            comboPooledDataSource.setDriverClass("com.mysql.cj.jdbc.Driver");
            comboPooledDataSource.setJdbcUrl("jdbc:mysql://47.101.201.210/Test?useSSL=FALSE&serverTimezone=UTC");
            comboPooledDataSource.setUser("root");
            comboPooledDataSource.setPassword("Sb1996350.");
            comboPooledDataSource.setMaxPoolSize(3);//最大连接数
            comboPooledDataSource.setMinPoolSize(1);//最小连接数
            dataSource = comboPooledDataSource;
            Connection connection = dataSource.getConnection();//这里需要dataSource中的getConnection这个方法来返回连接对象
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public Connection getdataSource() throws Exception {
        return dataSource.getConnection();
    }

    public static void main(String[] args) throws Exception {
        Connection connection = new T1().getdataSource();
        connection.setAutoCommit(false);//开启事务  为什么要开启事务 因为在代码中不是编译过了就算成功了,逻辑过了才算成功
        connection.commit();//提交事务
        //开启事务还有一个好处,事务有排它锁,当你修改数据时能保证数据的唯一型
        connection.close();
    }
}

了,里面是加载好的数据库连接 
目录
相关文章
|
Java 数据库连接 应用服务中间件
原生JDBC使用C3p0数据源和dbcp数据源
原生JDBC使用C3p0数据源和dbcp数据源
147 0
|
SQL Java 数据库连接
联表查询 && 索引 && 事务 && JDBC使用 &&CPU工作原理 && 线程概念 && Thread类的用法
联表查询 && 索引 && 事务 && JDBC使用 &&CPU工作原理 && 线程概念 && Thread类的用法
192 0
|
9月前
|
SQL 分布式计算 Java
大数据-96 Spark 集群 SparkSQL Scala编写SQL操作SparkSQL的数据源:JSON、CSV、JDBC、Hive
大数据-96 Spark 集群 SparkSQL Scala编写SQL操作SparkSQL的数据源:JSON、CSV、JDBC、Hive
202 0
|
11月前
sharding-jdbc 兼容 MybatisPlus的动态数据源
【8月更文挑战第2天】要使 `Sharding-JDBC` 与 `MyBatisPlus` 的动态数据源兼容,需引入相关依赖,配置数据源及分库分表策略,并在 `MyBatisPlus` 中设置参数以协同工作。可能还需自定义代码处理数据源切换。示例代码框架展示整合方式,实际应用中需按具体业务场景详细配置并处理异常情况,如数据一致性问题。
542 1
|
设计模式 Java 数据库连接
【Spring源码】JDBC数据源访问实现
我们再来看看阅读线索三,这方面我们从设计模式进行入手。阅读线索三:从这个模块可以学到什么我们看下以下代码,PreparedStatement实例的是由PreparedStatementCreator实现的。再来看看PreparedStatementCreator接口,一共有三个子类实现。也就是说PreparedStatement的三种不同实现被封装到三个子类中,而具体需要哪种实现,只需要传入不同。
125 1
【Spring源码】JDBC数据源访问实现
|
SQL druid Java
JDBC、C3P0、DBCP、Druid 数据源连接池使用的对比总结.md2
JDBC、C3P0、DBCP、Druid 数据源连接池使用的对比总结.md
78 0
|
SQL druid Java
JDBC、C3P0、DBCP、Druid 数据源连接池使用的对比总结.md1
JDBC、C3P0、DBCP、Druid 数据源连接池使用的对比总结.md
169 0
|
SQL 算法 Java
jdbc(ikun)实现事务的开启,提交,回滚代码示例
jdbc(ikun)实现事务的开启,提交,回滚代码示例
|
XML Java 数据库连接
【Spring】JDBC、AOP、事务
【Spring】JDBC、AOP、事务
|
SQL Java 关系型数据库
SpringBoot整合JDBC与默认数据源
SpringBoot整合JDBC与默认数据源
156 0