当前位置: 首页 > 编程笔记 >

Oracle中实现MySQL show index from table命令SQL脚本分享

宗政松
2023-03-14
本文向大家介绍Oracle中实现MySQL show index from table命令SQL脚本分享,包括了Oracle中实现MySQL show index from table命令SQL脚本分享的使用技巧和注意事项,需要的朋友参考一下

实验数据初始化:


create table t as select * from hr.employees;

create index inx_t1 on t(employee_id,first_name desc,last_name);

create index inx_t2 on t(job_id,hire_date);

显示该表所有索引的信息。

以dba登录


set linesize 300;

set pagesize 100;

col c1 format a20;

col c2 format a20;

col c3 format a20;

col c4 format a20;

col c5 format a20;

col INDEX_NAME format a20;

select INDEX_NAME,

max(decode(COLUMN_POSITION,1,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c1,

max(decode(COLUMN_POSITION,2,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c2,

max(decode(COLUMN_POSITION,3,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c3,

max(decode(COLUMN_POSITION,4,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c4,

max(decode(COLUMN_POSITION,5,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c5

from (

select INDEX_NAME,COLUMN_NAME,COLUMN_LENGTH,COLUMN_POSITION,DESCEND

from dba_ind_columns 

where table_owner='LIHUILIN' 

AND table_name='T' 

order by INDEX_NAME,column_position

) group by INDEX_NAME;

以普通用户登录


set linesize 300;

set pagesize 100;

col c1 format a20;

col c2 format a20;

col c3 format a20;

col c4 format a20;

col c5 format a20;

col INDEX_NAME format a20;

select INDEX_NAME,

max(decode(COLUMN_POSITION,1,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c1,

max(decode(COLUMN_POSITION,2,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c2,

max(decode(COLUMN_POSITION,3,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c3,

max(decode(COLUMN_POSITION,4,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c4,

max(decode(COLUMN_POSITION,5,COLUMN_NAME||','||COLUMN_LENGTH||','||DESCEND,null)) c5

from (

select INDEX_NAME,COLUMN_NAME,COLUMN_LENGTH,COLUMN_POSITION,DESCEND

from user_ind_columns 

where table_name='T' 

order by INDEX_NAME,column_position

) group by INDEX_NAME;

但是可以看到,以倒序创建的索引字段,都是以SYS等命名。

Oracle把这种倒序创建的索引字段看成函数索引。

它的信息保存在user_ind_expressions视图。

user_ind_expressions视图的COLUMN_EXPRESSION字段类型是long型。

王工的版本可以解决这个问题


CREATE OR REPLACE FUNCTION long_2_varchar (

   p_index_name IN user_ind_expressions.index_name%TYPE,

   p_table_name IN user_ind_expressions.table_name%TYPE,

   p_COLUMN_POSITION IN user_ind_expressions.table_name%TYPE)

   RETURN VARCHAR2

AS

   l_COLUMN_EXPRESSION LONG;

BEGIN

   SELECT COLUMN_EXPRESSION

     INTO l_COLUMN_EXPRESSION

     FROM user_ind_expressions

    WHERE index_name = p_index_name

          AND table_name = p_table_name

          AND COLUMN_POSITION = p_COLUMN_POSITION;

   RETURN SUBSTR (l_COLUMN_EXPRESSION, 1, 4000); END; /



set linesize 300;

set pagesize 100;

col c1 format a20;

col c2 format a20;

col c3 format a20;

col c4 format a20;

col c5 format a20;

col INDEX_NAME format a20;

SELECT INDEX_NAME,

         MAX (DECODE (COLUMN_POSITION, 1, COLUMN_NAME || ' ' || DESCEND, NULL))

            c1,

         MAX (DECODE (COLUMN_POSITION, 2, COLUMN_NAME || ' ' || DESCEND, NULL))

            c2,

         MAX (DECODE (COLUMN_POSITION, 3, COLUMN_NAME || ' ' || DESCEND, NULL))

            c3,

         MAX (DECODE (COLUMN_POSITION, 4, COLUMN_NAME || ' ' || DESCEND, NULL))

            c4,

         MAX (DECODE (COLUMN_POSITION, 5, COLUMN_NAME || ' ' || DESCEND, NULL))

            c5

    FROM ( SELECT a.INDEX_NAME,

                   REPLACE (

                      DECODE (

                         descend,

                         'DESC', long_2_varchar (b.index_name,

                                                 b.table_NAME,

                                                 b.COLUMN_POSITION),

                         a.column_name),

                      '"',

                      '')

                      COLUMN_NAME,

                   a.COLUMN_LENGTH,

                   a.COLUMN_POSITION,

                   DESCEND

              FROM user_ind_columns a

                   LEFT JOIN

                   user_ind_expressions b

                      ON a.index_name = b.index_name

                         AND a.table_name = b.table_name

             WHERE a.table_name = 'T'

          ORDER BY INDEX_NAME, column_position)

GROUP BY INDEX_NAME;


 类似资料:
  • 本文向大家介绍Shell实现的Oracle启动脚本分享,包括了Shell实现的Oracle启动脚本分享的使用技巧和注意事项,需要的朋友参考一下 Usage: sh oracled [start|stop|restart] SIDs 其中SIDs是数据库名,多个名称之间用逗号分隔。缺省的操作是 restart ,也可以指定需要进行的操作( start | stop | restart )

  • 本文向大家介绍Oracle重建索引Shell脚本、SQL脚本分享,包括了Oracle重建索引Shell脚本、SQL脚本分享的使用技巧和注意事项,需要的朋友参考一下 索引是提高数据库查询性能的有力武器。没有索引,就好比图书馆没有图书标签一样,找一本书自己想要的书比登天还难。然而索引在使用的过程中,尤其是在批量的DML的情形下会产生相应的碎片,以及B树高度会发生相应变化,因此可以对这些变化较大的索引进

  • 问题内容: 我在尝试使用sqlplus将sql脚本运行到oracle时遇到问题。该脚本仅填充一些虚拟数据: 使用Oracle SQL Developer运行脚本时,脚本运行良好,但是使用sqlplus命令行工具时,将输出以下内容,然后将其挂起: 我正在使用以下命令行运行该工具,该命令在其他脚本中也可以正常运行: 有任何想法吗?谢谢。 问题答案: 您需要在脚本的末尾放置一个,或以(例如重定向的输入代

  • 本文向大家介绍Oracle中查看正在运行的SQL进程脚本分享,包括了Oracle中查看正在运行的SQL进程脚本分享的使用技巧和注意事项,需要的朋友参考一下 Oracle的show processlist Oracle show full processlist

  • 本文向大家介绍Shell脚本中实现切换用户并执行命令操作,包括了Shell脚本中实现切换用户并执行命令操作的使用技巧和注意事项,需要的朋友参考一下 今天公司同事来找到我说要在服务器上用另外一个用户执行python脚本,但设置到crontab里却老是root用户来执行,为了省事我就想了一个偷懒的办法,就是用shell脚本切换到那个用户,然后去执行那个python脚本.好了,这篇文章我只演示怎么用sh

  • 本文向大家介绍hive-shell批量命令执行脚本的实现方法,包括了hive-shell批量命令执行脚本的实现方法的使用技巧和注意事项,需要的朋友参考一下 如下所示: 以上这篇hive-shell批量命令执行脚本的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。