Flyway——Oracle创建前缀索引

文章目录

前言

索引有助于提升数据库表的查询速率,极大的缩减查询的时间。但索引的创建需要考虑的因素很多,并非索引越多越好!

创建一般索引的语法

oracle创建一般的常见索引,语法如下所示:

摘录于:努力的小羽儿------oracle创建索引

sql 复制代码
--创建索引
CREATE [UNIQUE] INDEX <索引名>
ON <基本表名> (<列名> [<次序>],[,<列名> [<次序>]]...); 
--说明:
--UNIQUE:规定索引的每一个索引值只对应于表中的唯一记录。
--<次序>:建立索引时指定列名的索引表是ASC(升序)或DESC(降序)。
 
--索引的创建语句(简洁)
create index 索引名 on 表名(列名);
 
--标准语法
create index 索引名 on 表名(列名) tablespace 表空间名;
 
--tablespace 表空间名 可以省略,以下皆省略
 
--创建唯一索引
create unique index 索引名 on 表名(列名);
 
--复合索引/组合索引
create index 索引名 on 表名(列名1, 列名2, 列名3, ...);
 
--反向键索引
create index 索引名 on 表名(列名) reverse;
 
--删除索引
drop index 索引名 on 表名;
 
--降序索引​
​CREATE INDEX 索引名 ON 表名(列名 desc) ;  --升序asc
 
--查看某个表中的所有索引
select * from all_indexes where table_name = '表名'
 
--查看某个表中建立了索引的所有列
​select * from all_ind_columns where table_name = '表名'

前缀索引

前缀索引这个词在Mysql中出现的比较多,在oracle中也能创建类似的索引。

索引的创建,会让数据库额外维护一个对应的索引B+树。

如果索引的字段很大,将导致创建索引B+树的大小越大。

如果又想对大数据字段加索引,又想不占用太多的内存,则可以采取前缀索引

创建可执行脚本,案例如下所示:

sql 复制代码
-- 增加 IMES_INDICATOR_CALCLOG 前缀索引
DECLARE
  CNT INTEGER;
BEGIN
   select COUNT(0)
    INTO CNT
    from user_indexes
    where table_name = upper('IMES_INDICATOR_CALCLOG')
    and index_name = upper('logid_index');

  IF CNT = 0 THEN
    EXECUTE IMMEDIATE 'create index logid_index on IMES_INDICATOR_CALCLOG left(logid,12)';
  END IF;
END;
/

IMES_INDICATOR_CALCLOG中的logid是一个uuid的数据,增加前缀索引,则使用到了LEFT函数。

相关推荐
尚雷558021 小时前
Oracle ASM 存储更换与整体迁移实战整理
数据库·oracle·ocr·asm
DarkAthena1 天前
【DuckDB】一条 SQL 同时连接 Oracle 和 GaussDB
oracle·gaussdb·duckdb
尚雷55801 天前
Oracle 18C 物理 DataGuard 搭建部署完整文档(适合开发测试)
数据库·oracle·dataguard
倔强的石头1061 天前
深度解析:数据库内核如何通过逻辑推理与常值推导突破去重性能瓶颈
数据库·oracle
为什么不问问神奇的海螺呢丶1 天前
Oracle database SYSAUX 表空间占用率过高处理方案
数据库·oracle
在繁华处1 天前
从零搭建轻灵(五):记忆系统与生产化特性
java·jvm·oracle
betazhou1 天前
LOG_ARCHIVE_DEST_2 ORA-01033: ORACLE initialization or shut
数据库·oracle·oracle19c adg
这个DBA有点耶2 天前
数据迁移避坑指南:从Oracle到国产数据库的兼容性问题
数据库·数据仓库·sql·oracle·dba
king_harry2 天前
Oracle DG4ODBC + PostgreSQL ODBC 驱动 + DBLINK 实现oracel访问postgresql
postgresql·oracle·异构数据库访问·dg4odbc
一只fish2 天前
Oracle官方文档翻译《Database Concepts 26ai》第10章-SQL
数据库·oracle