当前位置:  开发笔记 > 数据库 > 正文

如何在Oracle中检查索引

如何解决《如何在Oracle中检查索引》经验,为你挑选了1个好方法。

我正在为依赖于Oracle数据库的产品编写模式升级脚本.在一个领域,我需要在表上创建一个索引 - 如果该索引尚不存在.有没有一种简单的方法可以检查是否存在我知道Oracle脚本名称的索引?

它与SQL Server中的类似:IF NOT EXISTS(SELECT*FROM SYSINDEXES WHERE NAME ='myIndex')//然后创建myIndex



1> erikkallen..:

从user_indexes中选择count(*),其中index_name ='myIndex'

但是,sqlplus不支持IF ...所以你必须使用匿名的PL/SQL块,这意味着EXECUTE IMMEDIATE来做DDL.

DECLARE
    i INTEGER;
BEGIN
    SELECT COUNT(*) INTO i FROM user_indexes WHERE index_name = 'MYINDEX';
    IF i = 0 THEN
        EXECUTE IMMEDIATE 'CREATE INDEX myIndex ...';
    END IF;
END;
/

编辑:正如所指出的,Oracle以非全部大写形式存储未加引号的对象名称.

推荐阅读
刘美娥94662
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有