[20180926]查询相似索引.txt
[20180926]查询相似索引.txt
--//有时候在表上建立索引比如A,B字段,可能又建立B字段索引,甚至A字段索引以及B,A字段索引,或者还建立C,A字段索引,
--//需要有1个脚本查询这些索引,可能还有必要删除一些索引,统一协调建立合适的索引.
--//优化需要,做一个记录.
1.环境:
SCOTT@test01p> @ ver1
PORT_STRING VERSION BANNER CON_ID
------------------------------ -------------- -------------------------------------------------------------------------------- ----------
IBMPC/WIN_NT64-9.1.0 12.1.0.1.0 Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production 0
2.建立测试例子:
SCOTT@test01p> create table t (a number,b number,c number);
Table created.
SCOTT@test01p> create index i_t_a_b on t(a,b);
Index created.
SCOTT@test01p> create index i_t_c_b on t(c,b);
Index created.
--//网上找到的例子:
SELECT TABLE_OWNER, TABLE_NAME, INDEX_NAME, COLUMN_NAME
FROM ALL_IND_COLUMNS
WHERE COLUMN_POSITION = 1
AND TABLE_OWNER = UPPER ('&&1')
AND (TABLE_OWNER, TABLE_NAME, COLUMN_NAME) IN (
SELECT TABLE_OWNER, TABLE_NAME, COLUMN_NAME
FROM (
SELECT TABLE_OWNER, TABLE_NAME, COLUMN_NAME, COUNT (*) TCOUNT
FROM ALL_IND_COLUMNS
WHERE TABLE_OWNER NOT IN ('SYS','SYSTEM','OUTLN','DBSNMP')
HAVING COUNT (*) > 1
GROUP BY TABLE_OWNER, TABLE_NAME, COLUMN_NAME))
ORDER BY TABLE_OWNER, TABLE_NAME, COLUMN_NAME, INDEX_NAME;
--//实际上这个例子在我们生产系统根本无法执行,表N多,1个小时都没有查询出来.而且像上面建立的索引是无法找到的.
--//因为它仅仅针对COLUMN_POSITION = 1的情况.
--//使用with改写如下:
/* Formatted on 2018/9/25 22:19:20 (QP5 v5.227.12220.39754) */
WITH t1
AS (SELECT TABLE_OWNER
,TABLE_NAME
,INDEX_NAME
,COLUMN_NAME
,COLUMN_POSITION
FROM ALL_IND_COLUMNS
WHERE TABLE_OWNER = UPPER ('&&1'))
,t2
AS ( SELECT DISTINCT TABLE_OWNER
,TABLE_NAME
,INDEX_NAME
,COLUMN_NAME
FROM t1
WHERE (TABLE_OWNER, TABLE_NAME, COLUMN_NAME) IN
(SELECT TABLE_OWNER, TABLE_NAME, COLUMN_NAME
FROM ( SELECT TABLE_OWNER
,TABLE_NAME
,COLUMN_NAME
,COUNT (*) TCOUNT
FROM T1
HAVING COUNT (*) > 1
GROUP BY TABLE_OWNER, TABLE_NAME, COLUMN_NAME))
ORDER BY TABLE_OWNER
,TABLE_NAME
,COLUMN_NAME
,INDEX_NAME)
,t3
AS ( SELECT TABLE_OWNER
,TABLE_NAME
,INDEX_NAME
,LISTAGG (column_name, ', ')
WITHIN GROUP (ORDER BY column_position)
AS column_group
FROM t1
GROUP BY TABLE_OWNER, TABLE_NAME, INDEX_NAME)
SELECT TABLE_OWNER
,TABLE_NAME
,INDEX_NAME
,column_group
FROM t3
WHERE (TABLE_OWNER, TABLE_NAME, INDEX_NAME) IN
(SELECT TABLE_OWNER, TABLE_NAME, INDEX_NAME FROM t2);
TABLE_OWNER TABLE_NAME INDEX_NAME COLUMN_GROUP
-------------------- -------------------- -------------------- ----------------------
SCOTT T I_T_A_B A, B
SCOTT T I_T_C_B C, B
--//补充:在生产系统使用不到1秒就执行完成.
--//换一个参数OE.
Enter value for 1: OE
old 8: WHERE TABLE_OWNER = UPPER ('&&1'))
new 8: WHERE TABLE_OWNER = UPPER ('OE'))
TABLE_OWNER TABLE_NAME INDEX_NAME COLUMN_GROUP
-------------------- -------------------- -------------------- -------------------------------------------------
OE INVENTORIES INVENTORY_IX WAREHOUSE_ID, PRODUCT_ID
OE INVENTORIES INV_PRODUCT_IX PRODUCT_ID
OE ORDER_ITEMS ITEM_ORDER_IX ORDER_ID
OE ORDER_ITEMS ORDER_ITEMS_PK ORDER_ID, LINE_ITEM_ID
OE ORDER_ITEMS ORDER_ITEMS_UK ORDER_ID, PRODUCT_ID
OE ORDER_ITEMS ITEM_PRODUCT_IX PRODUCT_ID
6 rows selected.
--//如果使用网上的脚本结果如下:
SCOTT@test01p> SELECT TABLE_OWNER, TABLE_NAME, INDEX_NAME, COLUMN_NAME
2 FROM ALL_IND_COLUMNS
3 WHERE COLUMN_POSITION = 1
4 AND TABLE_OWNER = UPPER ('&&1')
5 AND (TABLE_OWNER, TABLE_NAME, COLUMN_NAME) IN (
6 SELECT TABLE_OWNER, TABLE_NAME, COLUMN_NAME
7 FROM (
8 SELECT TABLE_OWNER, TABLE_NAME, COLUMN_NAME, COUNT (*) TCOUNT
9 FROM ALL_IND_COLUMNS
10 WHERE TABLE_OWNER NOT IN ('SYS','SYSTEM','OUTLN','DBSNMP')
11 HAVING COUNT (*) > 1
12 GROUP BY TABLE_OWNER, TABLE_NAME, COLUMN_NAME))
13 ORDER BY TABLE_OWNER, TABLE_NAME, COLUMN_NAME, INDEX_NAME;
old 4: AND TABLE_OWNER = UPPER ('&&1')
new 4: AND TABLE_OWNER = UPPER ('OE')
TABLE_OWNER TABLE_NAME INDEX_NAME COLUMN_NAME
-------------------- -------------------- -------------------- --------------------
OE INVENTORIES INV_PRODUCT_IX PRODUCT_ID
OE ORDER_ITEMS ITEM_ORDER_IX ORDER_ID
OE ORDER_ITEMS ORDER_ITEMS_PK ORDER_ID
OE ORDER_ITEMS ORDER_ITEMS_UK ORDER_ID
OE ORDER_ITEMS ITEM_PRODUCT_IX PRODUCT_ID
--//1.结果不同,存在遗漏.
--//2.明显感觉执行很慢.
--//3.显示不直观.
[20180926]查询相似索引.txt的更多相关文章
- Mysql数据库表排序规则不一致导致联表查询,索引不起作用问题
Mysql数据库表排序规则不一致导致联表查询,索引不起作用问题 表更描述: 将mysql数据库中的worktask表添加ishaspic字段. 具体操作:(1)数据库worktask表新添是否有图片字 ...
- MySQL多表查询之外键、表连接、子查询、索引
MySQL多表查询之外键.表连接.子查询.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为 ...
- [20190226]测试使用bbed恢复索引.txt
[20190226]测试使用bbed恢复索引.txt --//上午做tab$删除恢复测试时发现,tab$的索引i_tab1很小.可以尝试使用bbed解决这个问题.--//首先在普通表上做一个测试看看. ...
- oracle查询不走索引的一些情况(索引失效)
Oracle建立索引的目的是为了避免全表扫描,提高查询的效率. 但是有些情况下发现即使建立了索引,但是写出来的查询还是很慢,然后会发现是索引失效导致的,所以需要了解一下那些情况会导致索引失效,即查询不 ...
- Mongodb 笔记03 查询、索引
查询 1. MongoDB使用find来进行查询.find的第一个参数决定了要返回哪些文档,这个参数是一个文档,用于指定查询条件.空的查询会匹配集合的全部内容.要是不指定查询,默认是{}. 2. 可以 ...
- 为何在查询中索引未被使用 (Doc ID 1549181.1)
To Bottom * 为何在查询中索引未被使用 (Doc ID 1549181.1) To Bottom 文档内容 用途 排错步骤 高速检查 表上是否存在索引? 索引是否应该 ...
- MongoDB的第二天(更新,删除,查询,索引)
Mongodb的更新方式有三种 update函数,操作符更新,save函数 update: 语法格式:db.COLLECTION_NAME.update({查询条件},{更新内容},{更新参数(可选) ...
- mysql中的回表查询与索引覆盖
了解一下MySQL中的回表查询与索引覆盖. 回表查询 要说回表查询,先要从InnoDB的索引实现说起.InnoDB有两大类索引,一类是聚集索引(Clustered Index),一类是普通索引(Sec ...
- elasticsearch查询篇索引映射文档数据准备
elasticsearch查询篇索引映射文档数据准备 我们后面要讲elasticsearch查询,先来准备下索引,映射以及文档: 我们先用Head插件建立索引film,然后建立映射 POST http ...
随机推荐
- go builtin包
Go builtin包提供了go预先声明的函数.变量等的文档.这些函数变量等的实现其实并不是在builtin包里,只是为了方便文档组织. 这些内置的变量.函数.类型无需引入包即可使用. 默认提供的有: ...
- 分析windows .net程序dump文件的两种方式
1.WinDbg 按照自己系统版本下载对应windbg(https://debugging.wellisolutions.de/windbg-versions/),win10版本自动下载文件符号,体验 ...
- Spring Boot (三)模板引擎FreeMarker集成
一.FreeMaker介绍 FreeMarker是一款免费的Java模板引擎,是一种基于模板和数据生成文本(HMLT.电子邮件.配置文件.源代码等)的工具,它不是面向最终用户的,而是一款程序员使用的组 ...
- 【leet-code】542. 01 矩阵
题目描述 给定一个由 0 和 1 组成的矩阵,找出每个元素到最近的 0 的距离. 两个相邻元素间的距离为 1 . 示例 1: 输入: 0 0 0 0 1 0 0 0 0 输出: 0 0 0 0 1 0 ...
- JavaScript基础回顾一(类型、值和变量)
请看代码并思考输出结果 var scope = 'global'; function f(){ console.log(scope); var scope = 'local'; console.log ...
- MySQL集群结构说明
在以前,数据库的集群配置一直很难,难点在于MySQL主从结构的高可用和读写分离.万幸的是,Galera/GR的出现,让整个集群的配置都极大程度地简化了. 以下是一个简单的MySQL集群拓扑图: 1.M ...
- JavaScript 系列博客(一)
JavaScript 系列博客(一) 前言 本系列博客为记录学习 JavaScript 的学习笔记,会从基础开始慢慢探索 js.今天的学习笔记主要为 js 引入.定义变量以及 JavaScript 中 ...
- 第一册:lesson eighty five。
原文:Paris in the spring. A:Hello,Ken. B:Hi,George. A:Have you just been to the cinema? B:Yes,I have. ...
- 【转载】 Sqlserver查看数据库死锁的SQL语句
在Sqlsever数据库中,有时候操作数据库过程中会进行锁表操作,在锁表操作的过程中,有时候会出现死锁的情况出现,这时候可以使用SQL语句来查询数据库死锁情况,主要通过系统数据库Master数据库来查 ...
- oracle表空间大小的限制和DB_BLOCK_SIZE的概念
之前接触的项目表空间最大也不超过10G,所以导入数据库时一直使用导入本地的oracle数据库文件的方法,即根据dmp文件大小设置一个数据文件,设定表空间最大值. --创建表空间,数据文件为'F:\ap ...