一、事务(Transaction):简单理解就是一个业务需求的最小处理单位。
如:从A银行卡转账100元到B银行卡,事务就包括两部分,1、从A卡减掉100元 2、从B卡加上100元。这两个部分只要一个部分出错,就要整体“回滚”,那这就是一个事务。
事务是恢复和并发控制的基本单位。来源:事务(程序执行单元)_360百科
事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。
原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。
一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
持久性(durability)。持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。
二、会话Session代表的是客户端与服务器的一次交互过程,这个过程可以是连续也可以是时断时续的。来源:关于会话(session),你应该了解这些-CSDN博客
会话:可以包含N个事务
如:你登陆网银之后,可以重复转账步骤多次,第二次转账失败,并不影响你第一次转账成功。
三、线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。来源:线程(计算机术语)_百度百科
线程:一个事情,一个人干和多个人干的问题
如:比如植树,任务是植树100棵,一个人(线程)干5天,那五个人(线程)干1天。