为了账号安全,请及时绑定邮箱和手机立即绑定

【学习打卡】第三天--Redis入门第八章redis的事务

标签:
PHP

课程名称 :Redis 入门

课程章节 :Redis  事务

讲师:慕神


课程内容:

redis 特性


多数据库:从0开始 最多有16个数据库 默认链接的是0号数据库

选择数据库连接        select 1


移动key到数据库1    move key  1


开启事务                    multi        


提交事务                    exec


回滚事务                    discard

Redis一个实例包含多个数据库:默认16个

客户端默认连接0号数据库

select 1 #选择1号数据库

move name 1 #移动 name 到1号数据库


事务:

事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。

  事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)。这个四个特性也简称为ACID特性。

  原子性:事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。

  一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。

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

提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。      

为什么事务非正常结束时会影响数据库数据的正确性,请列举一例说明之。

  答:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。

  例如某工厂的库存管理系统中,要把数量为Q的某种零件从仓库1移到仓库2存放。

  则可以定义一个事务T,T包括两个操作;Q1=Q1-Q,Q2=Q2+Q。如果T非正常终止时只做了第一个操作,则数据库就处于不一致性状态,库存量无缘无故少了Q。


multi:开启事务

exec:提交,执行的命令被原子化执行

discard:回滚

课程收获:redis 的事务和数据库引擎的事务还是有区别的,通过学习事务可以很好的理解事务的四个特性,理解程序在运行时为了保证一致性所做的一些方法,对我们以后程序的开发很有用处。


https://img1.sycdn.imooc.com//62f614cf00016cd703760585.jpg




点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消