精华内容
下载资源
问答
  • 但是在现在一个事务里、父的操作还没提交。子插入大量数据需要半分钟到一分钟。因为父的状态没有改变。导致页面上的操作能够重复操作。重复操作带来的是数据库里面大量的重复数据。这个有啥办法解决吗?
  • 事务表与非事务表

    千次阅读 2018-10-08 14:04:32
    事务表与非事务表 版权声明:转载自 浅然的专栏 https://blog.csdn.net/w_linux/article/details/79666086 该博客详解MySQL中的事务 一、事务定义 ...

    事务表与非事务表

    版权声明:转载自 浅然的专栏 https://blog.csdn.net/w_linux/article/details/79666086

    该博客详解MySQL中的事务

    一、事务定义

    • Transaction
    • 事务:一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)
    • 一个完整的业务需要批量的DML(insert、update、delete)语句共同联合完成
    • 事务只和DML语句有关,或者说DML语句才有事务。这个和业务逻辑有关,业务逻辑不同,DML语句的个数不同

    二、转账操作理解事务

    关于银行账户转账操作,账户转账是一个完整的业务,最小的单元,不可再分————————也就是说银行账户转账是一个事务

    以下是银行账户表t_act(账号、余额),进行转账操作

    actno       balance
    1           500
    2           100
    

    转账操作

    update t_act set balance=400 where actno=1;
    update t_act set balance=200 where actno=2;
    

    以上两台DML语句必须同时成功或者同时失败。最小单元不可再分,当第一条DML语句执行成功后,并不能将底层数据库中的第一个账户的数据修改,只是将操作记录了一下;这个记录是在内存中完成的;当第二条DML语句执行成功后,和底层数据库文件中的数据完成同步。若第二条DML语句执行失败,则清空所有的历史操作记录,要完成以上的功能必须借助事务


    三、事务四大特征(ACID)

    • 原子性(A):事务是最小单位,不可再分
    • 一致性(C):事务要求所有的DML语句操作的时候,必须保证同时成功或者同时失败
    • 隔离性(I):事务A和事务B之间具有隔离性
    • 持久性(D):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)

    四、关于事务的一些术语

    • 开启事务:Start Transaction
    • 事务结束:End Transaction
    • 提交事务:Commit Transaction
    • 回滚事务:Rollback Transaction

    五、和事务相关的两条重要的SQL语句(TCL)

    • commit:提交
    • rollback:回滚

    六、事务开启的标志?事务结束的标志?

    开启标志:

    - 任何一条DML语句(insert、update、delete)执行,标志事务的开启
    

    结束标志(提交或者回滚):

    -  提交:成功的结束,将所有的DML语句操作历史记录和底层硬盘数据来一次同步
    -  回滚:失败的结束,将所有的DML语句操作历史记录全部清空
    

    七、事物与数据库底层数据

    在事物进行过程中,未结束之前,DML语句是不会更改底层数据,只是将历史操作记录一下,在内存中完成记录。只有在事物结束的时候,而且是成功的结束的时候,才会修改底层硬盘文件中的数据


    八、在MySQL中,事务提交与回滚

    在MySQL中,默认情况下,事务是自动提交的,也就是说,只要执行一条DML语句就开启了事物,并且提交了事务

    以上的自动提交机制是可以关闭的

    对t_user进行提交和回滚操作
    提交操作(事务成功)
    • start transaction
    • DML语句
    • commit

    mysql> start transaction;#手动开启事务
    mysql> insert into t_user(name) values('pp');
    mysql> commit;#commit之后即可改变底层数据库数据
    mysql> select * from t_user;
    +----+------+
    | id | name |
    +----+------+
    |  1 | jay  |
    |  2 | man  |
    |  3 | pp   |
    +----+------+
    3 rows in set (0.00 sec)
    
    回滚操作(事务失败)
    • start transaction
    • DML语句
    • rollback

    mysql> start transaction;
    mysql> insert into t_user(name) values('yy');
    mysql> rollback;
    mysql> select * from t_user;
    +----+------+
    | id | name |
    +----+------+
    |  1 | jay  |
    |  2 | man  |
    |  3 | pp   |
    +----+------+
    3 rows in set (0.00 sec)
    

    九、事务四大特性之一————隔离性(isolation)

    1. 事物A和事物B之间具有一定的隔离性
    2. 隔离性有隔离级别(4个)
      • 读未提交:read uncommitted
      • 读已提交:read committed
      • 可重复读:repeatable read
      • 串行化:serializable

    1、 read uncommitted

    - 事物A和事物B,事物A未提交的数据,事物B可以读取到
    - 这里读取到的数据叫做“脏数据”
    - 这种隔离级别最低,这种级别一般是在理论上存在,数据库隔离级别一般都高于该级别
    

    2、read committed

    - 事物A和事物B,事物A提交的数据,事物B才能读取到
    - 这种隔离级别高于读未提交
    - 换句话说,对方事物提交之后的数据,我当前事物才能读取到
    - 这种级别可以避免“脏数据”
    - 这种隔离级别会导致“不可重复读取”
    - Oracle默认隔离级别
    

    3、repeatable read

    - 事务A和事务B,事务A提交之后的数据,事务B读取不到
    - 事务B是可重复读取数据
    - 这种隔离级别高于读已提交
    - 换句话说,对方提交之后的数据,我还是读取不到
    - 这种隔离级别可以避免“不可重复读取”,达到可重复读取
    - 比如1点和2点读到数据是同一个
    - MySQL默认级别
    - 虽然可以达到可重复读取,但是会导致“幻像读”
    

    4、serializable

    - 事务A和事务B,事务A在操作数据库时,事务B只能排队等待
    - 这种隔离级别很少使用,吞吐量太低,用户体验差
    - 这种级别可以避免“幻像读”,每一次读取的都是数据库中真实存在数据,事务A与事务B串行,而不并发
    

    十、隔离级别与一致性关系

    这里写图片描述

    十一、设置事务隔离级别

    方式一

    • 可以在my.ini文件中使用transaction-isolation选项来设置服务器的缺省事务隔离级别。

    • 该选项值可以是:

    – READ-UNCOMMITTED
    – READ-COMMITTED
    – REPEATABLE-READ
    – SERIALIZABLE
    
    •   例如:
    [mysqld]
    transaction-isolation = READ-COMMITTED
    

    方式二

    • 通过命令动态设置隔离级别
      • 隔离级别也可以在运行的服务器中动态设置,应使用SET TRANSACTION ISOLATION LEVEL语句。
      • 其语法模式为:

            SET [GLOBAL | SESSION] TRANSACTION ISOLATION LEVEL <isolation-level>
            其中的<isolation-level>可以是:
        –   READ UNCOMMITTED
        –   READ COMMITTED
        –   REPEATABLE READ
        –   SERIALIZABLE
        •   例如: SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
    

    十二、隔离级别的作用范围

    •   事务隔离级别的作用范围分为两种: 
    –   全局级:对所有的会话有效 
    –   会话级:只对当前的会话有效 
    •   例如,设置会话级隔离级别为READ COMMITTED :
    mysql> SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
    或:
    mysql> SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
    •   设置全局级隔离级别为READ COMMITTED : 
    mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
    

    十三、查看隔离级别

    •   事务隔离级别的作用范围分为两种: 
    –   全局级:对所有的会话有效 
    –   会话级:只对当前的会话有效 
    •   例如,设置会话级隔离级别为READ COMMITTED :
    mysql> SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
    或:
    mysql> SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
    •   设置全局级隔离级别为READ COMMITTED : 
    mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
    
    展开全文
  • 事务表和非事务表

    千次阅读 2019-07-23 00:12:06
    比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务! 最常见的两种数据库引擎: Innodb 数据库引擎...

    在学习 触发器的过程中,看到了非事务表的概念。所以大致了解了一下,在这里记录一下。

    事务概念

    先回顾一下事务的概念:

    MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

    • 最常见的两种数据库引擎: Innodb 数据库引擎的数据库或表支持事务;MyISAM存储引擎的数据库或表不支持事务。
    • 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
    • 事务用来管理 insert,update,delete 语句

    一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。

    • 原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。

    • 一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。

    • 隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。

    • 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。

    在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

    事务表

    事务表就是支持事务的表,可以进行Transaction事务回滚操作, InnoDB是一种数据库存储引擎,事务型数据库的首选引擎,支持ACID事务,支持行级锁定。

    非事务表

    非事务表,不支持事务的表,目前我知道的只有使用MyISAM存储引擎的表。
     

    SHOW ENGINES; 可检查mysqld服务器支持的存储引擎:

    SHOW VARIABLES LIKE 'have_%'; 可检查与你感兴趣的存储引擎有关的变量值

    展开全文
  • 条更新语句是否需要事务

    千次阅读 2019-06-14 09:05:52
    今天工作遇到了一个问题,才发现自己之前记忆的知识是错误的,不是对于事务的理解有问题,而是对于单表更新的场景理解错误,记录下这个知识点 条更新语句不需要事务 public int updateBySerial(Dto dto) { ...

    单条更新语句是否需要加事务

    今天工作遇到了一个问题,才发现自己之前记忆的知识是错误的,不是对于事务的理解有问题,而是对于单表更新的场景理解错误,记录下这个知识点

    单条更新语句不需要加事务

    public int updateBySerial(Dto dto) {
        return csRecordService.update(dto);
    }
    

    上面的代码,不需要添加事务,这种被称之为是隐性事务,因为如果执行失败了,是sql错误,数据库也不会更新成功,相当于自动回退事务了

    单条更新语句需要加事务

    还是上面的代码,如果业务上,需要判断每次只更新一条才认为是成功

    @Transactional(rollbackFor = Exception.class)
    public int updateBySerial(Dto dto) {
       int count = csRecordService.update(dto);
       if(count != 1){
           throw new Exception("更新条数错误");
       }
    }
    

    上面的代码,进行了业务判断,是需要添加事物的,不然虽然抛异常,但sql执行是成功的。

    这引申出来一个新问题

    上面的代码抛异常了,如果在外面进行了try-cache,sql会更新成功吗?

    public int update(Dto dto) {
        try {
            dao.updateBySerial(dto);
        } catch (Exception e) {
            log.error("修改失败");
        }
    }    
    

    答案是更新不会成功,虽然做了try-cache,但是事务切面是在里面做的,所以仍会回滚,这是事务机制的切面逻辑,在当前切面内,抛异常,事务会回滚。


    遗留一个问题,如果update方法上也有@Transactional(rollbackFor = Exception.class)事务注解,因为事务的传播行为,上面的sql会更新成功吗?

    展开全文
  • 【Oracle】会话临时事务临时

    千次阅读 2019-03-24 18:00:44
    会话临时事务临时 一、会话和事务临时的概述 会话临时: 顾名思义该类临时会与会话有一定关系,会话在数据在,会话亡数据亡(自动清除)。on commit preserve rows 事务临时: 由名可猜想该类临时...

    会话临时表和事务临时表

    一、会话和事务临时表的概述

    会话临时表:
    顾名思义该类临时表会与会话有一定关系,会话在数据在,会话亡数据亡(自动清除)。
    on commit preserve rows

    事务临时表:
    由名可猜想该类临时表会与事务有关,当进行事务提交或事务回滚时,临时表的数据就会被自动清除。
    on commit delete rows

    二、会话和事务临时表的练习

    会话临时表

    /*
    1.会话临时表
    */
    --创建表
    create global temporary table tmp_session_dept(tid int, tname varchar2(50), tphone int)
    on commit preserve rows;
    
    --插入数据
    insert into tmp_session_dept values(1,'Lisi',12345);
    insert into tmp_session_dept values(2,'Wangwu',11111);
    insert into tmp_session_dept values(3,'Zhaoliu',22222);
    
    commit;
    
    --在当前会话查询数据
    select * from tmp_session_dept;
    TID	TNAME	TPHONE
    1	Lisi	12345
    2	Wangwu	11111
    3	Zhaoliu	22222
    
    --打开另一个会话查询数据
    select * from tmp_session_dept;
    TID	TNAME	TPHONE
    
    

    由此可见,会话临时表插入的数据只在当前会话有效,在其他会话该临时表相当于没有数据。

    事务临时表

    /*
    2.事务临时表
    */
    --创建表
    create global temporary table tmp_trans_dept(tid int, tname varchar2(50), tphone int)
    on commit delete rows;
    
    --插入数据
    insert into tmp_trans_dept values(1,'Lisi',12345);
    insert into tmp_trans_dept values(2,'Wangwu',11111);
    insert into tmp_trans_dept values(3,'Zhaoliu',22222);
    
    commit;
    
    --在当前会话查询数据
    select * from tmp_trans_dept;
    TID	TNAME	TPHONE
    
    --打开另一个会话查询数据
    select * from tmp_session_dept;
    TID	TNAME	TPHONE
    
    

    由此可见,事务临时表插入的数据在事务提交后该临时表的数据已被启动清空。

    展开全文
  • Thinkphp 多表事务

    千次阅读 2017-01-23 12:20:25
    单表事务只需使用 M 函数实例化一个数据表对象,如果操作成功则提交,失败则回滚;对多表的事务处理也非常简便。先用 M 函数实例化一个空对象,使用 table 方法进行多个表的操作,如果操作成功则提交,失败则回滚。
  • 维度建模数仓领域中的事实大致分以下三种:事务事实,周期快照事实,累计事实事务事实与周期快照事实、累积快照事实虽然使用相同的一致性维度,但是它们在内容构成以及业务描述上还是有很大的区别...
  • 事务ACID理解

    万次阅读 多人点赞 2018-09-06 21:26:20
    事务管理(ACID) 谈到事务一般都是以下四点 原子性(Atomicity) 原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。 一致性(Consistency) 事务前后数据的完整性必须保持一致...
  • 数据库多操作事务处理

    千次阅读 2015-08-28 20:13:54
    需要同时插入多条数据时,这其中可能是同一个的多条记录,也可能是多个不同之间的数据同时更新。对此,我们需要保证其中的原子性和一致性,做到要么全部操作都能全部成功完成,否则全部不操作。 我们可以通过...
  • hive如何建立事务表

    千次阅读 2018-10-25 14:45:26
    1,开始(BEGIN),提交(CIMMIT)和回滚(ROLLBACK)还不支持 ...3,必须是桶,并且外部不能支持事务操作 4,Hive的transcation manager 需要设置为 org.apache.hadoop.hive.ql.lockmgr.DbTxnManager...
  • Hive事务表

    千次阅读 2018-01-26 16:25:47
    先启动 hiveserver2服务 然后以beeline形式启动./beeline -u jdbc:hive2://localhost:10000 -n root –silent=true配置thrift 需要允许某些用户 在hadoop的core-site.xml中添加 <name>hadoop.proxyuser.root.hos
  • 但是有时候在项目中需要一系列连续的操作,比如对多个同时执行插入新数据的操作,在其中一个出现异常时,就全部回滚,这时原配置文件里的的自动提交事务就不能符合需求了。 但是手动提交事务又不懂,又开始...
  • 事务级别临时操作 举例 create global temporary table student2_transcation( sno varchar2(10), sname varchar2(20), sage number(2), cno varchar2(2) )on commit delete rows;insert into student2_...
  • MySQL——事务(Transaction)详解

    万次阅读 多人点赞 2018-03-23 13:05:50
    该博客详解MySQL中的事务 ...一个完整的业务需要批量的DML(insert、update、delete)语句共同联合完成 事务只和DML语句有关,或者说DML语句才有事务。这个和业务逻辑有关,业务逻辑不同,DML语句的个数不同...
  • MySQL 的类型、存储引擎和事务

    万次阅读 2019-05-12 15:50:16
    MySQL 的类型 MySQL 的类型由存储引擎(Storage Engines)决定,MySQL 数据主要支类型 : 事务安全型(transaction-safe):BDB、InnoBDB 非事务安全型(non-transaction-safe):HEAP(Memory)、Archive、...
  • 直接用SM30的维护创建事务代码

    万次阅读 2016-11-09 09:37:09
    在SAP中,经常需要自定义数据库。而且可能需要人工维护数据库中的数据,可以通过SM30进行维护数据;但是SM30事务的权限太大,不适宜将SM30直接分配;因此,可以通过给维护分配事务代码,来达到控制权限的目的...
  • Hive ACID和事务表支持详解

    千次阅读 2019-04-28 19:17:10
    文章目录一、ACID介绍二、使用限制三、支持的一些新的语法四、主要设计和实现base和delta文件夹的基本结构事务表的读取delta文件的压缩1、 压缩类型2、Initiator 组件3、 Worker4、Cleaner5、 ...SHOW COMPACTIONS事务...
  • 事务update会锁吗?

    千次阅读 2019-02-21 14:31:59
    1.mysq由于默认是开启自动提交事务,所以首先得查看自己当前的数据库是否开启了自动提交事务。 命令:select @@autocommit; 结果如下: +--------------+ | @@autocommit | +--------------+ | 0 | +-----...
  • thinkphp3.2 多表事务的实例

    千次阅读 2017-08-28 12:16:59
    表事务不同于单表 1. 需要使用空白的Model 来开启以及使用事务2. 如果不是在Model里面, 需要使用 $model-&gt;table() 来进行insert update delelte操作 , 但是直接D() 操作试验了也是可以的3. 如果是特定的...
  • 深入理解 Hive ACID 事务表

    千次阅读 2019-06-11 21:30:58
    Apache Hive 0.13 版本引入了事务特性,能够在 Hive 上实现 ACID 语义,包括 INSERT/UPDATE/DELETE/MERGE 语句、增量数据抽取等。Hive 3.0 又对该特性进行了优化,包括改进了底层的文件组织方式,减少了对表结构的...
  • 数据量大的时候会出现锁情况.只须在查询上不加事务,写操作则加上. 只读事务: @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED) 读写事务: @Transactional (propagation=Propagation....
  • 最近需要通过JDBC对数据库做事务型操作,实践时发现,并没有达到想要的效果,表现在:1、每次执行executeUpdate()后,数据就马上能在DB中查到。但按理来说,我还没执行commit(),DB中不应该有这个数据;2、执行...
  • 为什么需要事务

    千次阅读 2017-12-09 10:51:43
    为什么需要事务? 我们还是从最经典的例子中讲解吧:转账 需求:jeff 给jack 转账1000元 假设转账分为两部完成 1. jeff减少1000 update test set money = money -500 where name= ‘jeff’ 2. jack增加1000 ...
  • 江湖传说:不了解数据库事务的程序员不是一个好的DBA。阅遍网上无数关于数据库事务的文章,都感觉云里雾里,不知所云。于是乎拍案而起,麻蛋,还是自己写吧。最后便有了这篇文章,它试图用通俗的文字来说明单机事务...
  • 行级锁与级锁本来就有许多不同之处,另外,事务的引入也带来了一些新问题。下面我们先介绍一点背景知识,然后详细讨论InnoDB的锁问题。 背景知识 1.事务(Transaction)及其ACID属性 事务是由一组SQ语句组成的...
  • 使用消息解决分布式事务

    千次阅读 2018-03-23 00:47:14
    需要进行1:更新订单的状态为已支付 2:扣减商品库存订单库:订单order:orderID、userID、status商品库:商品库存productStock:productStockID、productID、stock出库outStockBill:outStockBillID、...
  • InnoDB事务

    万次阅读 2019-08-05 21:10:40
    事务是数据库区别于文件系统的重要特性之一,InnoDB存储引擎中的事务符合ACID的特性,即 原子性(atomicity) 一致性(consistency) 隔离性(isolation) 持久性(durability) 本文参考了姜承尧先生的《MySQL...
  • 创建3张表:(不用设主外键) @Override  public void onCreate... System.out.println("同时创建3张数据库");  db.execSQL("CREATE TABLE "+ "test1" +" (test1_id INTEGER PRIMARY KEY AUTOINCREMENT, test
  • 91.Oracle数据库SQL开发之 修改内存——数据库事务的并发事务 欢迎转载,转载请标明出处: ORACLE数据库软件支持多个用户同时与数据库进行交互,每个用户都可以同时运行自己的事务。这种事务称为并发事务。  ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 606,435
精华内容 242,574
关键字:

单表需要事务