Erro de chamadas recursivas em procedures aninhadas – mysql recursão stored-procedures

Pergunta:


Tenho algumas procedures MySQL para fazer o seguinte:

  • O código principal vai sempre chamar a procedure CALL sp_syncTabela.

  • A sp_syncTabela vai checar se existe outra procedure específica para o tableName passado como argumento. Se existir, será chamada; se não, a procedure “padrão” sp_syncExecuteQuery será chamada no lugar.

  • Por exemplo, eu tenho a sp_syncTabela_caixa na database. Então, quando eu executo CALL sp_syncTabela (..."caixa"...), ela vai internamente chamar CALL sp_syncTabela_caixa. Mas uma chamada a CALL sp_syncTabela (..."outra"...) vai apenas usar a procedure padrão sp_syncExecuteQuery.

  • Todas as procedures específicas têm o formato sp_syncTabela_???, como a “caixa” possui. Essas procedures servem para executar outras tarefas personalizadas além de chamar CALL sp_syncExecuteQuery.

  • A lógica é: A tabela referenciada pelo argumento tableName possui uma procedure específica? Se tiver, faça algumas tarefas personalizadas à tabela e depois chame sp_syncExecuteQuery; mas se não tiver, apenas execute sp_syncExecuteQuery sem nenhuma tarefa extra.

Eu não vejo nenhuma chamada recursiva, mas estou recebendo o erro

Error Code: 1444. The prepared statement contains a stored routine
call that refers to that same statement. It’s not allowed to execute a
prepared statement in such a recursive manner.

Isso está acontecendo depois de executar CALL sp_syncTabela ("I", 33, "caixa", "id='20',fundo='11.11',abertura_user_id='2',abertura_data='2014-11-11 18:24:33',fechamento_user_id=NULL,fechamento_data=NULL,", "id=20").

Agora, os códigos:

CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_syncTabela`(IN action VARCHAR(10), IN tableName VARCHAR(50), IN columnData VARCHAR(4000))
BEGIN
    DECLARE res Int;

    SELECT Count(*) INTO res FROM information_schema.Routines WHERE routine_name = Concat("sp_syncTabela_", tableName);

    CASE res
        WHEN 0 THEN CALL sp_syncExecuteQuery (action, tableName, columnData);
        ELSE 
        BEGIN
            SET @querySync = Concat("CALL sp_syncTabela_", tableName, " ("", action, "", "", tableName, "", "", columnData, "");");
            PREPARE tablePreviewQuery FROM @querySync;
            EXECUTE tablePreviewQuery;  
        END;
    END CASE;
END


CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_syncTabela_caixa`(IN action VARCHAR(10), IN tableName VARCHAR(50), IN columnData VARCHAR(4000))
BEGIN
    /* Apenas uma procedure específica de exemplo, com uma tarefa adicional antes de chamar sp_syncExecuteQuery */

    INSERT INTO configuration (name, value) VALUES ("Última chamada à sp_syncTabela_caixa", Cast(Now() as Char)) 
        ON DUPLICATE KEY UPDATE value = Cast(Now() as Char);
    CALL sp_syncExecuteQuery (action, tableName, columnData);

END


CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_syncExecuteQuery`(IN action VARCHAR(10), IN tableName VARCHAR(50), IN columnData VARCHAR(4000))
BEGIN

    CASE action
        WHEN "I" then CALL sp_generateInsertQuery (tableName, columnData, @queryToExecute);
        WHEN "U" then CALL sp_generateUpdateQuery (tableName, columnData, @queryToExecute);
        WHEN "D" then CALL sp_generateDeleteQuery (tableName, columnData, @queryToExecute);
        ELSE Begin End;
    END CASE;

    PREPARE tablePreviewQuery FROM @queryToExecute;
    EXECUTE tablePreviewQuery;  
END

Já procurei ajuda em vários sites, em português e inglês, por palavras-chave como ‘nested procedures’, ‘recursive errors’, e similares. E, além de tudo, não vejo onde há recursividade nesse processo. Quando executo diretamente a sp_syncTabela_caixa, não ocorre nenhum erro.

Autor da pergunta Ulisses

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *