[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的更多相关文章

  1. Mysql数据库表排序规则不一致导致联表查询,索引不起作用问题

    Mysql数据库表排序规则不一致导致联表查询,索引不起作用问题 表更描述: 将mysql数据库中的worktask表添加ishaspic字段. 具体操作:(1)数据库worktask表新添是否有图片字 ...

  2. MySQL多表查询之外键、表连接、子查询、索引

    MySQL多表查询之外键.表连接.子查询.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为 ...

  3. [20190226]测试使用bbed恢复索引.txt

    [20190226]测试使用bbed恢复索引.txt --//上午做tab$删除恢复测试时发现,tab$的索引i_tab1很小.可以尝试使用bbed解决这个问题.--//首先在普通表上做一个测试看看. ...

  4. oracle查询不走索引的一些情况(索引失效)

    Oracle建立索引的目的是为了避免全表扫描,提高查询的效率. 但是有些情况下发现即使建立了索引,但是写出来的查询还是很慢,然后会发现是索引失效导致的,所以需要了解一下那些情况会导致索引失效,即查询不 ...

  5. Mongodb 笔记03 查询、索引

    查询 1. MongoDB使用find来进行查询.find的第一个参数决定了要返回哪些文档,这个参数是一个文档,用于指定查询条件.空的查询会匹配集合的全部内容.要是不指定查询,默认是{}. 2. 可以 ...

  6. 为何在查询中索引未被使用 (Doc ID 1549181.1)

        To Bottom * 为何在查询中索引未被使用 (Doc ID 1549181.1) To Bottom 文档内容 用途   排错步骤   高速检查   表上是否存在索引?   索引是否应该 ...

  7. MongoDB的第二天(更新,删除,查询,索引)

    Mongodb的更新方式有三种 update函数,操作符更新,save函数 update: 语法格式:db.COLLECTION_NAME.update({查询条件},{更新内容},{更新参数(可选) ...

  8. mysql中的回表查询与索引覆盖

    了解一下MySQL中的回表查询与索引覆盖. 回表查询 要说回表查询,先要从InnoDB的索引实现说起.InnoDB有两大类索引,一类是聚集索引(Clustered Index),一类是普通索引(Sec ...

  9. elasticsearch查询篇索引映射文档数据准备

    elasticsearch查询篇索引映射文档数据准备 我们后面要讲elasticsearch查询,先来准备下索引,映射以及文档: 我们先用Head插件建立索引film,然后建立映射 POST http ...

随机推荐

  1. Chapter 4 Invitations——6

    The snow washed away for good after that one dangerously icy day. 在危险的冰天雪地之后,这场雪洗走了很多. Mike was disa ...

  2. Nginx 配置https 服务

    一.HTTPS 服务 为什么需要HTTPS? 原因:HTTP不安全 1.传输数据被中间人盗用.信息泄露 2.数据内容劫持.篡改 HTTPS协议的实现 对传输内容进行加密以及身份验证 HTTPS加密校验 ...

  3. HTML语法介绍

    一 基本标签(块级标签和内联标签) <hn>: n的取值范围是1~6; 从大到小. 用来表示标题. <p>: 段落标签. 包裹的内容被换行.并且也上下内容之间有一行空白. &l ...

  4. java反射注解妙用-获取所有接口说明

    转载请注明出处:https://www.cnblogs.com/wenjunwei/p/10293490.html 前言 最近在做项目权限,使用shiro实现restful接口权限管理,对整个项目都进 ...

  5. Git+Gitlab+Ansible的roles实现一键部署Nginx静态网站(一)--技术流ken

    前言 截止目前已经写了<Ansible基础认识及安装使用详解(一)--技术流ken>,<Ansible常用模块介绍及使用(二)--技术流ken><Ansible剧本介绍及 ...

  6. Linux--Introduction and Basic commands(Part one)

    Welcome to Linux world! Introduction and Basic commands--Part one J.C 2018.3.11 Chapter 1 What Is Li ...

  7. Docker在Linux上运行NetCore系列(二)把本地编译好的镜像发布到线上阿里云仓库

    转发请注明此文章作者与路径,请尊重原著,违者必究. 系列文章:https://www.cnblogs.com/alunchen/p/10121379.html 开始 本篇文章结束在本地创建完成镜像后, ...

  8. c# 服务

    注:服务里的timer System.Timers.Timer time=new System.Timers.Timer();  time.Interval = 3000;  //设置计时器事件间隔执 ...

  9. 【Java并发编程】23、ConcurrentHashMap原理分析(1.7和1.8版本对比)

    jdk 1.8版本 ConcurrentHashMap在1.8中的实现,相比于1.7的版本基本上全部都变掉了.首先,取消了Segment分段锁的数据结构,取而代之的是数组+链表(红黑树)的结构.而对于 ...

  10. Javascript继承1:子类的的原型对象----类式继承

    //声明父类 function Parent(){ this.parentValue = true; this.favorites = ['看书'] } //为父类添加公有方法 Parent.prot ...