AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79023649
Accepted
Simon
Simon
Asked: 2024-09-25 23:09:07 +0800 CST2024-09-25 23:09:07 +0800 CST 2024-09-25 23:09:07 +0800 CST

O script plsql está gerando 'ERROR na linha 1 DECLARE', não vejo o motivo

  • 772

Boa tarde comunidade,

Tenho um script PLSQL executado no ORACLE 19 que está exibindo um erro que não entendo.

O script descarta qualquer índice existente antes de recriá-los. Os objetos são definidos em uma lista de tipo-off para evitar repetição de instruções

  • remover um índice inexistente está OK (basta capturar a exceção e continuar)
  • criar um índice que está falhando deve continuar a criar os índices restantes até o fim

Meu script PLSQL é

set serveroutput on;
WHENEVER SQLERROR EXIT SQL.SQLCODE;

DECLARE
    index_not_exists EXCEPTION;
    table_not_exists EXCEPTION;
    PRAGMA EXCEPTION_INIT (index_not_exists, -1418);
    PRAGMA EXCEPTION_INIT (table_not_exists, -942);

    TYPE ind_list IS TABLE OF VARCHAR(100) NOT NULL;
    ind_to_drop ind_list := ind_list('sst_ind1', 'sst_ind2');
    /* first index is wrong because col0 does not exist */
    ind_to_create ind_list := ind_list('create index sst_ind1 on sst_table(col0)', 'create index sst_ind2 on sst_table(col2)');

    sql_to_exec varchar(200);
    is_all_index_created boolean := TRUE;

BEGIN
    BEGIN
        EXECUTE IMMEDIATE 'drop table sst_table cascade constraints purge';
    EXCEPTION
        WHEN table_not_exists THEN
        NULL;
    END;

    EXECUTE IMMEDIATE 'create table sst_table (col1 number, col2 number)';
    EXECUTE IMMEDIATE 'create index sst_ind1 on sst_table (col1)';
    EXECUTE IMMEDIATE 'create index sst_ind2 on sst_table (col2)';

    FOR l_index IN ind_to_drop.FIRST..ind_to_drop.LAST LOOP
        BEGIN
            sql_to_exec := 'drop index ' || ind_to_drop(l_index);
            dbms_output.put_line(sql_to_exec);
            EXECUTE IMMEDIATE sql_to_exec;
        EXCEPTION
            WHEN index_not_exists THEN
                dbms_output.put_line('no index ' || ind_to_drop(l_index));
        END;
    END LOOP;

    FOR l_index IN ind_to_create.FIRST..ind_to_create.LAST LOOP
        BEGIN
            dbms_output.put_line(ind_to_create(l_index));
            EXECUTE IMMEDIATE ind_to_create(l_index);
        EXCEPTION
            WHEN OTHERS THEN
                dbms_output.put_line('ERROR WITH ' || ind_to_create(l_index));
                is_all_index_created := FALSE;
        END;
    END LOOP;

    IF NOT is_all_index_created THEN
        RAISE_APPLICATION_ERROR(-20001, 'PROBLEM CREATING INDEX');
    END IF;

END;
/

exit

Quando executo meu script pelo sqplus tenho o ERRO abaixo não entendi

sqlplus xxxxx/yyyyy@zzzzzz @ubscls_6711.sql

SQL*Plus: Release 11.2.0.4.0 Production on Wed Sep 25 17:04:11 2024

Copyright (c) 1982, 2013, Oracle.  All rights reserved.


Connected to:
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production

drop index sst_ind1
drop index sst_ind2
create index sst_ind1 on sst_table(col0)
ERROR WITH create index sst_ind1 on sst_table(col0)
create index sst_ind2 on sst_table(col2)
DECLARE
*
ERROR at line 1:
ORA-20001: PROBLEM CREATING INDEX
ORA-06512: at line 49


Disconnected from Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production

Alguém pode me ajudar a consertar meu problema? Provavelmente é simples, mas não consigo encontrar o motivo.

Obrigado

oracle
  • 2 2 respostas
  • 35 Views

2 respostas

  • Voted
  1. Best Answer
    Alex Poole
    2024-09-25T23:38:16+08:002024-09-25T23:38:16+08:00

    Ele está fazendo o que você disse que deveria... sua pergunta afirma que:

    • criar um índice que está falhando deve continuar a criar os índices restantes até o fim

    Há um comentário no código que diz:

    o primeiro índice está errado porque col0 não existe

    A saída mostra:

    create index sst_ind1 on sst_table(col0)
    ERROR WITH create index sst_ind1 on sst_table(col0)
    

    ... para que a criação do índice falhe como esperado (escondendo o erro real, o que não ajuda, como @Koen disse); então ele continua e mostra:

    create index sst_ind2 on sst_table(col2)
    

    ... que aparentemente tem sucesso. Então ele continuou a criar os índices restantes.

    Você está usando o sinalizador is_all_index_createdpara manter o controle de quaisquer problemas. Isso está sendo definido como falso pela falha esperada. Então, no final do seu código, você tem:

        IF NOT is_all_index_created THEN
            RAISE_APPLICATION_ERROR(-20001, 'PROBLEM CREATING INDEX');
        END IF;
    

    e esse é o erro que você está vendo:

    DECLARE
    *
    ERROR at line 1:
    ORA-20001: PROBLEM CREATING INDEX
    ORA-06512: at line 49
    

    Você está recebendo um erro porque seu código diz para gerar esse erro, então não há nada a corrigir, já que você quer/espera que a primeira criação de índice falhe.


    No início do script você tem

    WHENEVER SQLERROR EXIT SQL.SQLCODE;
    

    então seu script sairá com o código -20001, indicando uma falha, em vez de zero, indicando sucesso. Você pode não ver -20001, no entanto, ele pode ser modificado para um intervalo menor; scripts Unix-y se envolvem se o código de saída estiver fora do intervalo permitido, então você pode ver -33 ou 233, por exemplo. (O que é um motivo para evitar usar isso, pois alguns códigos de erro reais se envolveriam em zero e pareceriam sucesso... é mais seguro ... EXIT FAILURE)

    • 2
  2. Koen Lostrie
    2024-09-25T23:26:45+08:002024-09-25T23:26:45+08:00

    O script manipula quaisquer exceções que são levantadas, mas não mostra qual é o erro. Dê uma olhada neste bloco no script.

            EXCEPTION
                WHEN OTHERS THEN
                    dbms_output.put_line('ERROR WITH ' || ind_to_create(l_index));
                    is_all_index_created := FALSE;
            END;
    

    O que ele faz é: se ocorrer qualquer tipo de erro, então imprima na tela que ... há um erro.

    Isso não é muito útil. Há algumas funções internas para lhe dar mais informações. SQLERRMfornece o código de erro e a descrição do erro, SQLCODEmostrará apenas o código de erro, dbms_utility.format_error_backtracemostra a pilha completa.

    Para o seu caso, SQLERRMprovavelmente deve ser o suficiente.

            EXCEPTION
                WHEN OTHERS THEN
                    dbms_output.put_line('ERROR WITH ' || ind_to_create(l_index));
                    dbms_output.put_line(SQLERRM);
                    is_all_index_created := FALSE;
            END;
    
    • 0

relate perguntas

  • Oracle - Execuções Restantes

  • Servidor ODBC Informix: Erro ao extrair o nome do mês da data

  • Oracle sqlldr: as restrições não são reativadas após o término do carregamento do lote

  • importando um arquivo csv para o banco de dados oracle

  • Buscando registros de horas anteriores no Oracle

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle?

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Quando devo usar um std::inplace_vector em vez de um std::vector?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Marko Smith

    Estou tentando fazer o jogo pacman usando apenas o módulo Turtle Random e Math

    • 1 respostas
  • Martin Hope
    Aleksandr Dubinsky Por que a correspondência de padrões com o switch no InetAddress falha com 'não cobre todos os valores de entrada possíveis'? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer Quando devo usar um std::inplace_vector em vez de um std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB Por que o GCC gera código que executa condicionalmente uma implementação SIMD? 2024-02-17 06:17:14 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve