[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 ...
随机推荐
- java-vip介绍
大叔Springboot+微服务+持续集成和交付VIP(价格:5000元) springboot部分 微服务部分 持久集成和交付部分 springboot部分 视频课(10讲) 项目源代码(api r ...
- 关于EF的三种分类----CodeFirst
新建StudentInfo.cs using System; using System.Collections.Generic; using System.ComponentModel.DataAnn ...
- java发送http get请求的两种方式
长话短说,废话不说 一.第一种方式,通过HttpClient方式,代码如下: public static String httpGet(String url, String charset) thro ...
- spring-boot(二)
学习文章来自:http://www.ityouknow.com/spring-boot.html web开发 spring boot web开发非常的简单,其中包括常用的json输出.filters. ...
- 第2章 细说Linux系统用户/组管理(1)
2.1 用户和组的基本概念 用户和组是操作系统中一种身份认证资源. 每个用户都有用户名.用户的唯一编号uid(user id).所属组及其默认的shell,可能还有密码.家目录.附属组.注释信息等. ...
- OJ:神秘的数组初始化
描述 填空,使得程序输出指定结果 #include <iostream> using namespace std; int main() { int * a[] = { // 在此处补充你 ...
- websocket 初识
websocket 初识 前言 其实很早就知道了 websocket 这个概念了,像现在大火的直播等使用的就是 websocket.之前找爬虫工作,对面问我爬过 websocket 网站没,很汗颜,那 ...
- [转]Cordova Android 返回键拦截(backbutton)和退出(再点击一次跳出)
本文转自:https://blog.csdn.net/aierJun/article/details/53944061 在Android原生webview里重写onBackPressed()就可以.@ ...
- WebBrowser引用IE版本问题,更改使用高版本IE
做了一个Winform的项目.项目里使用了WebBrowser控件.以前一直都以为WebBrowser是直接调用的系统自带的IE,IE是呈现出什么样的页面WebBrowser就呈现出什么样的页面.其实 ...
- C#.NET和C++结构体Socket通信与数据转换
最近在用C#做一个项目的时候,Socket发送消息的时候遇到了服务端需要接收C++结构体的二进制数据流,这个时候就需要用C#仿照C++的结 构体做出一个结构来,然后将其转换成二进制流进行发送,之后将响 ...