IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 2021-11-9 JDBC-数据库事务2 -> 正文阅读

[大数据]2021-11-9 JDBC-数据库事务2

一、事务的ACID属性

  1. 原子性atomicity
    原子性是事务一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生

  2. 一致性consistency
    事务必须使数据库从一个一致性状态变换到另外一个一致性状态

  3. 隔离性 isolation
    事务的隔离性指一个事务的执行不能被其他事务干扰,即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰

  4. 持久性 durability
    持久性指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来的其他操作和数据库故障不应该对其有任何影响。

二、四种隔离级别

  1. READ UNCOMMITTED
  2. READ COMMITTED
  3. REPEATABLE READ
  4. SERIALIZABLE
  • 查看当前的隔离级别
select @@transaction_isolation
select @@global.transaction_isolation

在这里插入图片描述

  • 设置当前mysql连接的隔离级别
set transaction isolation level read committed;
  • 设置数据库系统全局的隔离级别
set transaction isolation level read committed;

三、Java设置数据库隔离级别

    @Test
    public void testTransactionSelect() throws Exception {
        Connection conn=JDBCUtils.getConnection();
      //  System.out.println(conn.getTransactionIsolation());
        String sql="select user,password,balance from user_table where user=?";
        ArrayList<User> users = getInstance(conn, User.class, sql, "CC");

        for(User u:users)
        {
            System.out.println(u);
        }


    }

    @Test
    public void testTransactionUpdate() throws Exception {
        Connection conn=JDBCUtils.getConnection();
        conn.setAutoCommit(false);
        //设置数据库隔离级别
        conn.setTransactionIsolation(Connection.TRANSACTION_READ_UNCOMMITTED);
        
        String sql="update user_table set balance=? where user=?";
        update(conn,sql,4000,"CC");

        System.out.println("修改结束");

    }



    //考虑事务的查询 version2.0
    public <T> ArrayList<T> getInstance(Connection conn,Class<T> cl, String sql, Object...args) throws Exception
    {
        //Connection conn= null;
        PreparedStatement ps = null;
        ResultSet resultSet = null;
        try {
            conn = JDBCUtils.getConnection();
            conn.setAutoCommit(false);
            ps = conn.prepareStatement(sql);

            for(int i=0;i<args.length;i++)
            {
                ps.setObject(i+1,args[i]);
            }

            resultSet = ps.executeQuery();

            ResultSetMetaData metaData = resultSet.getMetaData();
            int columnCount=metaData.getColumnCount();
            //创建集合对象
            ArrayList<T> list=new ArrayList<>();
            while (resultSet.next())
            {
                //创建一个对象,属于cl类
                T t = cl.newInstance();
                for(int i=0;i<columnCount;i++) {
                    Object columnValue = resultSet.getObject(i + 1);
                    String columnLabel = metaData.getColumnLabel(i + 1);

                    Field field = cl.getDeclaredField(columnLabel);
                    field.setAccessible(true);
                    field.set(t, columnValue);
                }
                list.add(t);

            }

            return list;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
//            conn.close();
//            ps.close();
//            resultSet.close();
            JDBCUtils.closeResource(null,ps,resultSet);
        }


        return null;

    }
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-10 12:28:04  更:2021-11-10 12:29:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 5:20:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码