返回顶部
首页 > 资讯 > 数据库 >oracle 优化--索引
  • 351
分享到

oracle 优化--索引

2024-04-02 19:04:59 351人浏览 泡泡鱼
摘要

一、事务1、简介事务是数据处理的核心,是业务上的一个逻辑单元,它能够保证其中对数据所有的操作,要么全部成功,要么全部失败。DBMS通过事务的管理来协调用户的并发行为,减少用户访问资源的冲突。 1)

一、事务

1、简介

事务是数据处理的核心,是业务上的一个逻辑单元,它能够保证其中对数据所有的操作,要么全部成功,要么全部失败。DBMS通过事务的管理来协调用户的并发行为,减少用户访问资源的冲突。

oracle  优化--索引

 

1)显示提交:当事务遇到COMMIT指令时,将结束事务并永久保存所有的更改的数据。

2)显示回滚:当事务遇到ROLLBACK指令时,也将结束事务的执行,但是此时它回滚所有更改的数据到事务开始时的原始值,即取消更改,数据没有变化。

3)DDL语句:一旦用户执行了DDL(数据定义语言,如create,drop等)语句,则之前的所有DML(数据操作语言)操作作为一个事务提交,这种提交称为隐示提交。

4)正常结束程序:如果oracle数据库应用程序正常结束,如使用sqlplus工具更改了数据,而正常退出该程序(exit),则oracle自动提交事务。

5)非正常地结束程序:当程序崩溃或意外终止时,所有数据更改都被回滚,这种回滚成为隐示回滚。

 

2、事务的特点

事务有4个特性,简写为ACID特性。

1)原则性:以转账操作为例,转出账户余额减少和转入余额增加是两个DML语句,但是必须作为一个不可分割的完整操作。要么同时成功,要么同时失败,只转出而没有转入显然是不可接受的。

2)一致性:无论是在事务前、事务中、事务后,数据库始终处于一致的状态。例如:转账前分别是2000和1000,总金额是3000,转账300后分别是1700和1300,总金额还是3000.这就叫做一致性。不一致就是在某个时间点查询到的总金额不是3000.

3)隔离性:在某个时间段,肯定有很多人都在转账,每个人的转账都是在自己的事务中,所以在一个数据库中,会有很多事物同时存在。虽然同时存在很多事物,但是事物之间不会相互影响。

4)持久性:如果事物提交成功,则数据修改永远生效,如果是回滚,则数据完全没有没修改,就相当于没有这件事情发生。

 

二、索引

 

1.索引是oracle的一个对象,是与表关联的可选结构,提供了一种快速访问数据的途径,提高了数据库检索性能。索引使数据库程序无需对整个表进行扫描,就可以在其中找到所需要的数据。就像书的目录,可以通过目录快速查找所需信

息,无需阅读整本书。

 

 

2.、索引的分类

 

1)B树索引结构

4、创建索引的语法

create [unique] index 索引名称 on 表名(列名)[tablespace 表空间名称]

 

解释:

[unique]用于指定唯一索引,默认情况下为非唯一索引

[tablespace]为索引指定表空间

 

1)创建标准索引

SQL> CREATE INDEX index_name ON tablename(columnname)

     TABLESPACE index_tbs;

2)重建索引

SQL> ALTER INDEX index_name REBUILD;

 

合并索引碎片

SQL>ALTER INDEX index_name COALESCE;

 

3)删除索引

SQL> DROP INDEX index_name;

例1:

1)在雇员表(emp)中,为雇员名称(ename)列创建b树索引。

oracle  优化--索引

5、创建唯一索

n 确保在定义索引的列中没有重复值

n Oracle 自动在表的主键列上创建唯一索引

n 使用CREATE UNIQUE INDEX语句创建唯一索引

语法如下:

SQL> CREATE UNIQUE INDEX index_name

     ON tablename(columnname);

例:在薪水级别(salgrade)表中,为级别编号grade列创建唯一索引。

oracle  优化--索引

6、反向键索引

与常规B树索引相反,反向键索引在保持列顺序的同时反转索引列的字节。反向键索引通过反转索引键的数据值,使得索引的修改平均分布到整个索引树上。主要应用于所多个实例同时访问一个数据库的场景中

 

6、位图索引

位图索引适合低于基数的列,即该列的值是有限的几个。例如:雇员表中的工种(job)列,即便是几百万条雇员记录,工种也是有限的。Job列可以作为位图索引,类似的还有图书表中的图书类别列等。

oracle  优化--索引

 

位图索引不直接存储ROWID,而是存储字节位到ROWID的映射,减少响应时间,节省空间占用。位图索引不应当在频发发生insert、update、delete操作的表上使用,这是因为单个位图索引指向表的很多数据行,当修改索引项时需要将其指向的数据行全部定,这会严重降低数据库的并发处理能力。位图索引适合用于数据仓库和决策支持系统中

 

例:在雇员emp表中,为工种(job)列创建位图索引。

基本语法:

CREATE BITMAP  INDEX emp_job_bit_idx ON emp(job);

oracle  优化--索引

 

6、组合索引
类似sqlserver的复合索引,在表内多列上创建索引。索引中的列不必与表中的列顺序一致,也不必相互邻接。

 

 

 

6、基于函数的索引

需要创建的索引需要使用表中一列或多列的函数或表达式,也可以将基于函数的索引创建为B树索引或位图索引。

基本语法:

SQL> CREATE INDEX emp_ename_upper_idx

 

ON tablename (UPPER(columnname));

 

:在雇员(emp)表中,为雇员名称(ename)列创建小写函数索引

oracle  优化--索引

oracle  优化--索引

 

6、创建索引的原则

n 频繁搜索的列可以作为索引列

n 经常排序,分组的列可以作为索引

n 经常用作连接的列(主键/外键)可以作为索引

n 将索引放在一个单独的表空间中,不要放在有回退段、临时段和表的表空间中

n 对于大型索引而言,考虑使用NOLOGIN子句创建大型索引。

n 根据业务数据发生频率,定期重新生成或重新组织索引,进行碎片整理。

 

 

 

您可能感兴趣的文档:

--结束END--

本文标题: oracle 优化--索引

本文链接: https://lsjlt.com/news/44584.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • oracle 优化--索引
    一、事务1、简介事务是数据处理的核心,是业务上的一个逻辑单元,它能够保证其中对数据所有的操作,要么全部成功,要么全部失败。DBMS通过事务的管理来协调用户的并发行为,减少用户访问资源的冲突。 1)...
    99+
    2024-04-02
  • SQL索引(索引优化)
    #1.最左前缀匹配原则,非常重要的原则, create index ix_name_email on s1(name,email,) - 最左前缀匹配:必须按照从左到右的顺序匹配 select * from s1 wher ...
    99+
    2021-11-01
    SQL索引(索引优化)
  • Oracle 建立索引及SQL优化
    数据库索引: 索引有单列索引复合索引之说 如何某表的某个字段有主键约束和唯一性约束,则Oracle 则会自动在相应的约束列上建议唯一索引。数据库索引主要进行提高访问速度。 建设原则:  1、索引应该经常建在Where ...
    99+
    2015-01-04
    Oracle 建立索引及SQL优化
  • Oracle怎么进行索引优化
    Oracle进行索引优化主要通过以下几种方式来实现: 使用合适的索引类型:Oracle支持多种类型的索引,包括B树索引、位图索引...
    99+
    2024-04-09
    Oracle
  • MySQL索引优化
    一、单表 创建索引之前:type=ALL全表扫描,Extra里面的Using filesort(文件内部排序) 根据where后面的条件创建:CREATE INDEX idx_article_ccv ON articl...
    99+
    2019-01-06
    MySQL索引优化
  • mysql织梦索引优化之MySQL Order By索引优化
    在一些情况下,MySQL可以直接使用索引来满足一个ORDER BY 或GROUP BY 子句而无需做额外的排序。尽管ORDER BY 不是和索引的顺序准确匹配,索引还是可以被用到,只要不用的索引部分和所有的额外的ORDER B...
    99+
    2024-04-02
  • MySQL索引优化EXPLAIN
    日常在CURD的过程中,都避免不了跟数据库打交道,大多数业务都离不开数据库表的设计和SQL的编写,那如何让你编写的SQL语句性能更优呢? 先来整体看下MySQL逻辑架构图: MySQL整体逻辑架构图可以分为Server和存储引擎层。...
    99+
    2015-10-24
    MySQL索引优化EXPLAIN
  • MySQL优化(3):索引
    MySQL优化中,最重要的优化手段就是索引,也是最常用的优化手段   索引简介: 索引:关键字与数据位置之间的映射关系 关键字:从数据中提取,用于标识,检索数据的特定内容 目的:加快检索   索引检索为什么快: (1)关键字相对于...
    99+
    2014-05-17
    MySQL优化(3):索引
  • MySQL优化之索引
    SQL为什么需要优化? 对于初学者来说,能够写出实现功能的SQL语句而不出错,查询出所需要的结果,就已经能够满足日常使用了。但在某些场景,对性能的要求比较高,因此,要求SQL的执行响应速度快,就需要对SQL进行一定程度的优化。 在...
    99+
    2021-02-14
    MySQL优化之索引
  • mysql优化和索引
    表的优化1.定长与变长分离    如 int,char(4),time核心且常用字段,建成定长,放在一张表;    而varchar,text,blob这种...
    99+
    2024-04-02
  • centos7-mysql-索引优化
    索引优化,优化查询速度-------------------------------------------------------count,统计一个表总计行数myisam储存引擎有自带计数器,使用cou...
    99+
    2024-04-02
  • MySQL 5.7 索引优化
    提升查询性能最好的方法就是创建索引。索引项就像指向表中行的指针,让查询通过WHERE条件快速找到所要查询的行。MySQL所有的数据类型都可以创建索引。 不必要的索引会消耗系统的空间和MySQL在判断...
    99+
    2024-04-02
  • 搜索引擎优化
    研究 研究是 SEO 的基石。了解目标受众使用的搜索词至关重要。您可以使用 Google Keyword Planner 等工具来发现相关,并评估它们的搜索量和竞争度。 示例代码: import googleapiclient.disc...
    99+
    2024-03-04
    、网站排名、有机流量、研究、内容营销、链接建设
  • 索引优化十二--组合索引的优化技巧与总结
    组合索引经要素!      --3.仅等值无范围查询时,组合索引顺序不影响性能(比如where col1=xxx and col2=xxx,无论COL1+C...
    99+
    2024-04-02
  • MySQL索引优化分享
    2,explain的作⽤ 查看表的读取顺序,读取操作类型,有哪些索引可用,表之间关联,每张表中有哪些索引被优化器执⾏ 3,索引命中策略略分析     最左匹配原则 在索引字段上加入函数(不匹配索引)     is null/is not n...
    99+
    2016-09-28
    MySQL索引优化分享
  • MySQL索引优化深入
    创建 test 测试表 CREATE TABLE `test` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `c1` varchar(10) DEFAULT NULL,  `c2`...
    99+
    2016-11-27
    MySQL索引优化深入
  • sql索引优化思路
    【开发】SQL优化思路(以oracle为例) powered by wanglifeng https://www.cnblogs.com/wanglifeng717 单表查询的优化思路 单表查询是最简单也是最重要的模块,它是多表等查询的...
    99+
    2020-02-17
    sql索引优化思路
  • MySQL如何优化索引
    1.  MySQL如何使用索引 索引用于快速查找具有特定列值的行。如果没有索引,MySQL必须从第一行开始,然后遍历整个表以找到相关的行。表越大,花费越多。如果表中有相关列的索引,MySQL可以快速确定要在...
    99+
    2022-05-27
    MySQL 索引 MySQL 优化索引
  • MySQL 索引优化案例
    目录数据准备联合索引的首字段用范围查询强制走索引覆盖索引优化in和or什么时候会走索引like xx% 一般都会走索引,和数据量无关索引下推为什么范围查找没有用索引下推优化?如何选择索引Trace 工具深入优化order...
    99+
    2022-08-19
    MySQL索引优化 MySQL索引
  • MySQL--索引优化原则
    索引优化原则 1、最左前缀匹配原则,联合索引,mysql会从做向右匹配直到遇到范围查询(>、<、between、like)就停止匹配,比如a = 1 and b = 2 and c > 3...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作