Linux-------事务(面试常问)

一、事务

1.什么是事务,为什么需要事务

所谓事务,是一个操作序列,这些操作要么执行,要么都不执行,它是一个不可分割的工作单位。

为什么需要事务?例如:银行转账的问题,从一个账号扣款并使另一个账号入账,这两个操作要么都执行,要么都不执行。所以,应该把它们看成是一个事务。

2.事务四大特性

  1. 原子性:略
  2. 一致性:数据库总是从一个一致性的状态转换到另一个一致性的状态。
  3. 隔离性:略
  4. 持久性:一旦事务提交,则其所做的修改就会永久保存到数据库中。此时即使系统崩溃,修改的数据也不会丢失。

3.隔离级别

  1. READ UNCOMMITTED未提交读:如果一个会话的隔离级别为未提交读,则在其他会话中事务的操作都可以立即在此会话中被看到。所以会产生脏读的问题,即看到其他会话中还没有被提交的事务。
  2. READ COMMUTTED提交读:如果一个会话的隔离级别为提交读,则在其他会话中只有事务提交后才可以在此会话中被看到。
  3. REPEATABLE READ可重复读(面试常问):如果一个会话的隔离级别为可重复读,则在其他会话中,即使事务提交了,在此会话中也不会被看到。所以会产生幻读的问题,即在可重复读的会话中看不到其他会话中被提交的事务。
  4. SERIALIZABLE可串行化

4.注意事项

  • Mysq可在每个会话中设置当前的隔离级别
  • 隔离级别越高,并发性越低
  • 每个会话的隔离级别只对当前隔离级别起作用

二、视图

1.什么是视图?

视图(View)是一种虚拟存在的表,对于使用视图的用户来说基本上是透明的。视图并不在数据库中实际存放数据,它的数据来自定义视图时使用的基本表,并且是在使用视图时动态生成的。

2.为什么要使用视图?

  • 简化复杂的sql操作,在编写查询后,可以方便的重用它而不必知道它的查询细节
  • 保护数据,可以给用户授予表的特定部分的访问权限而不是整个表
  • 使用表的组成部分而不是整个表

三、索引

1.索引是什么?

索引是一种特殊的文件,它包含着对数据表里所有记录的引用指针。简单讲,就像一本书前面的目录,能加快查询速度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值