[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. 剑指offer--2

    前言:继续笔记分享! 面试题6:暂无好的解决方法先搁浅一下 面试题7: #include<stdio.h> #include<stdlib.h> typedef struct ...

  2. 【EF6学习笔记】(七)读取关联数据

    本篇参考原文链接:Reading Related Data 本章主要讲述加载显示关联数据: 数据加载分为以下三种 Lazy loading 这种加载方式在于需要用到这个导航属性数据的时候,才会去数据库 ...

  3. 微软改名部又出动啦!微软宣布VSTS改名为Azure DevOps

    本篇为翻译,原文地址:https://azure.microsoft.com/en-us/blog/introducing-azure-devops/ 作者:Jamie Cool,Azure DevO ...

  4. 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)

    摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...

  5. Spring DAO模块

    Spring的DAO模块提供了对JDBC.Hibernate.Mybatis等DAO层支持,本节介绍DAO模块对JDBC的支持.DAO模块依赖ommons-dbcp.jar.commons-pool. ...

  6. [JavaScript] 前端模块加载简单实现(require)

    模块加载的简单实现 (function(win) { var baseUrl; var paths; var script_cache = {}; var script_queue = []; var ...

  7. 从零开始学安全(二十五)●用nmap做端口扫描

    以上是常用的端口扫描 -T 用法 每个级别发包时间  当没有使用T 时默认的使用T3级别发包 半开扫描  先探测主机是否存活 再用-sS  扫描端口   容易造成syn 包攻击 就是利用僵尸主机  进 ...

  8. 16.QT-QMap和QHash解析

    QMap QMap原型为class QMap <K,T>,其中K表示键,T表示值,K和T属于映射关系. QMap会根据K来自动进行升序键排序 QMap中的K类型必须重载operator & ...

  9. mybatis_06SQL片段

    个人概要: SQL片段在使用if where的基础上,将if,where语句装到SQL标签内,在数据库操作元素内引用 Mybatis提供了SQL片段的功能,可以提高SQL的可重用性. <!--声 ...

  10. 月薪25K的90后程序员,他们都经历了什么?

    如果说薪资是检验一家公司对程序员认可的标准,那么年纪轻轻就能达到月薪 25K,一定程度上说明了公司对他创造的价值的认可. 深访10+ 名月薪25K的程序员,发现他们最常见的三种成长途径是…… 在公司发 ...