Oracle索引和事务

1. 什么是索引?有什么用?

1.索引是数据库对象之一,用于加快数据的检索,类似于书籍的目录。在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。
2.索引是建立在表上的可选对象;索引的关键在于通过一组排序后的索引键来取代默认的全表扫描检索方式,从而提高检索效率
3.索引在逻辑上和物理上都与相关的表和数据无关,当创建或者删除一个索引时,不会影响基本的表;
4.索引一旦建立,在表上进行DML操作时(例如在执行插入、修改或者删除相关操作时),oracle会自动管理索引,索引删除,不会对表产生影响
5.索引对用户是透明的,无论表上是否有索引,sql语句的用法不变
6.oracle创建主键时会自动在该列上创建索引

2. 索引的底层实现原理

当一列索引创建成功后,oracle系统会这个列复制一个份放入缓存,并按照一定规则做排序和去重,从而减少检索数据的范围。
但是索引不是创建的越多越好,因为一个索引的创建,就需要在缓存中开辟一个空间,过多的索引反而会加重数据库的检索速度。

3. 索引的设计理念

1.某个字段在条件查询中会被高频率的调用 where 条件
2.表关联的连接字段 on 条件
3.实际业务需求

4.索引的创建是不是越多越好?为什么?

1.首先数据量小的表不需要建立索引,因为小的表即使建立索引也不会有大的用处,还会增加额外的索引开销
2.不经常引用的列不要建立索引,因为不常用,即使建立了索引也没有多大意义
3.经常频繁更新的列不要建立索引,因为肯定会影响插入或更新的效率
4.索引并不是一劳永逸的,用的时间长了需要进行整理或者重建

5. 索引的分类

1.唯一索引主键会默认添加索引适用:主键2.BTREE索引(默认索引)1.oracle中最常用的索引;B树索引就是一颗二叉树;叶子节点(双向链表)包含索引列和指向表中每个匹配行的ROWID值2.所有叶子节点具有相同的深度,因而不管查询条件怎样,查询速度基本相同3.能够适应精确查询、模糊查询和比较查询    适用:列基数(列不重复值的个数)大时适合使用B树索引3.位图索引创建位图索引时,oracle会扫描整张表,并为索引列的每个取值建立一个位图(位图中,对表中每一行使用一位(bit,0或者1)来标识该行是否包含该位图的索引列的取值,如果为1,表示对应的rowid所在的记录包含该位图索引列值),最后通过位图索引中的映射函数完成位到行的ROWID的转换
适用:对于基数小的列适合简历位图索引(例如性别等)4.单列索引和复合索引如果索引建立在多个列上,只有它的第一个列被where子句引用时,优化器才会使用该索引,即至少要包含组合索引的第一列。即索引按照顺序被调用

6. 索引操作

查看索引
select * from user_indexes  where TABLE_NAME='EMPLOYEES';
创建BTREE索引
CREATE  INDEX   index_name  on  table_name(colum1,colum2…);
创建位图索引
CREATE  BITMAP  INDEX   index_name  on  table_name(colum1,colum2…);
修改索引
alter index index_name1 rename to index_name2;
删除索引
drop index index_sno;

(索引在全局唯一)

7. 图形化操作

事务

事务是操作数据库最小的单位,是1条或N条SQL语句组成的逻辑。

四大特性

数据库事务具有四大特性(ACID):
1. 原子性A(Atomic)       事务是一个整体,不可分割,一起成功or一起失败
2. 一致性C(Consistency)   事务执行前和执行后必须处于一致性状态
3. 隔离性I(Isolation)       多事务并发时,相互独立,互不影响
4. 持久性D(Durability)     数据库数据若不变更,会永久不变

事务会造成的问题

1. 脏读
脏读是指在一个事务处理过程里读取了另一个未提交的事务中的数据
2. 不可重复读
不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,被另一个事务修改并提交了。
3. 幻读
在读写一批数据时,发现读取到的数据不一致,就是发生了幻觉一样

以上问题,都是发生在多事务并发时,数据前后不一致造成的

数据库提供的四种隔离级别:

Read uncommitted(读未提交):最低级别,任何情况都会发生。
Read Committed(读已提交):可避免脏读的发生。
Repeatable read(可重复读):可避免脏读、不可重复读的发生。
Serializable(串行化):避免脏读、不可重复读,幻读的发生。

MySQL默认级别是 可重复读;
Oracle 仅支持读已提交和串行化,默认级别是 读已提交

锁机制
  1. 共享锁/乐观锁(Share Locks,即S锁)加了共享锁的数据对象可以被其他事务读取和修改
  2. 排它锁/悲观锁(Exclusive Locks,即X锁):当数据对象被加上排它锁时,其他的事务不能对它读取和修改
死锁
  1. 两张表T1,T2
  2. A用户已访问T1表,并加锁T1表,尝试访问T2表;访问不到T2表,就不撤T1表的锁
  3. B用户已访问T2表,并加锁T2表,尝试访问T1表;访问不到T1表,就不撤T2表的锁
  4. 两个用户就发生了死锁
上网查询还有什么锁机制
  1. 共享锁/乐观锁(Share Locks,即S锁)加了共享锁的数据对象可以被其他事务读取和修改
  2. 排它锁/悲观锁(Exclusive Locks,即X锁):当数据对象被加上排它锁时,其他的事务不能对它读取和修改

Oracle索引和事务相关推荐

  1. Oracle总结第二篇【视图、索引、事务、用户权限、批量操作】

    前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了-那么本篇主要总结关于Oralce视图.序列.事务的一些内容- 在数据库中,我们可以把各种的SQL语句分为四大类- (1 ...

  2. Oracle总结【视图、索引、事务、用户权限、批量操作】

    前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了-那么本篇主要总结关于Oralce视图.序列.事务的一些内容- 在数据库中,我们可以把各种的SQL语句分为四大类- (1 ...

  3. Oracle数据库之事务

    Oracle数据库之事务 1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个 ...

  4. 定时创建oracle索引,oracle数据库关于索引建立及使用的详细介绍

    索引的说明 索引是与表相关的一个可选结构,在逻辑上和物理上都独立于表的数据,索引能优化查询,不能优化DML操作,Oracle自动维护索引,频繁的DML操作反而会引起大量的索引维护. 如果SQL语句仅访 ...

  5. 理论+实操: MySQL索引与事务、视图、存储过程(软件开发用的多)、存储引擎MyISAM和InnoDB

    文章目录 一:索引的概念 二:索引的作用 三:索引的分类 3.1 普通索引 3.2 唯一性索引 3.3 主键 3.4 全文索引 3.5 单列索引与多列索引 四:创建索引的原则依据 五:创建索引的方法 ...

  6. 互联网行业中最常用的数据库——MySQL 索引、事务与存储引擎

    MySQL 索引.事务与存储引擎 一.MySQL 索引 1.1 索引的概念 1.2 索引的作用及缺点 1.2.1 优点 1.2.2 缺点 1.3 创建索引的原则依据 1.4 索引的分类和创建 1.4. ...

  7. 各种Oracle索引类型介绍

    各种Oracle索引类型介绍 逻辑上: Single column 单行索引 Concatenated 多行索引 Unique 唯一索引 NonUnique 非唯一索引 Function-based函 ...

  8. [转载]oracle索引的简单总结

    原文地址:oracle索引的简单总结作者:kindle 一.索引的概念: 数据库的索引类似于书籍的索引.在书籍中,索引允许用户不必翻阅完整个书就能迅速地找到所需要的信息.在数据库中,索引也允许数据库程 ...

  9. Oracle: 三、Oracle的隐藏事务与视图的创建

    内容简介 1,Oracle的隐藏事务.2,视图(View)的创建. 技术与环境 操作系统: windows 语言类别: SQL之PL/SQL thankyou: sunshine, 谢谢你的默默付出 ...

最新文章

  1. Rocket - tilelink - FIFOFixer
  2. vue-router常见问题解决方案。(滚轴回到顶部、页面跳转同一页面报错、手机电脑端路由跳转)
  3. Windows之在终端打开当前目录的命令
  4. wapper打成linux服务,Wrapper配置详解及高级应用(转)
  5. (计算机组成原理题目题型总结)第二章:数据的表示和运算
  6. 一筐鸡蛋筐拿鸡蛋的问题
  7. Unity-failed to update unity web player
  8. 网络工程师试题(二)2020-12-8
  9. 摩尔庄园不同服务器账号互通吗,摩尔庄园手游不同区可以一起玩吗 服务器互通情况分享...
  10. 采用python语言对csv文件写入、最可能采用的字符串方法_2020尔雅无人机原理与构造答案章节答案...
  11. 卸载office2010后 再安装2013 错误1706 安装程序找不到需要的文件
  12. 腾讯云服务器怎么增加容量,腾讯云服务器磁盘扩容问题小记
  13. Arcgis重采样时分辨率的设置
  14. 计算机课程成绩认定管理办法,全日制普通本科生课程学分成绩对接认定管理办法...
  15. 29、NeRV: Neural Reflectance and Visibility Fields for Relighting and View Synthesis
  16. MySQL有几部分_数据库系统有哪几部分组成?
  17. VLN论文英语表达积累
  18. WebGIS理论知识(七)—走进互联网地图
  19. 五一劳动节,微信公众号图文应该怎样排版?
  20. 数学建模,8月学习感想

热门文章

  1. ios启动时间优化--理论
  2. 英语学习笔记(一)语法
  3. python中常用的模块(cleandar模块,time模块,datetime模块,OS模块,shutil()模块,random模块)
  4. Leetcode题目分类指南(单独刷题或学习算法书籍配合使用)
  5. 信息安全主题的高清PPT背景图110张,打包下载
  6. OPenGL 学习笔记之 VAO VBO EBO 以及SHADER 并使用其绘制三角形
  7. SEO面试题与面试攻略
  8. 解读72篇DeepMind深度强化学习论文
  9. 【MySQL】查询优化
  10. Json字符串转对象和转List集合操作(json-lib版本)