Como concatenar um comando SQL dentro de uma MySQL Stored Procedure? – php mysql

Pergunta:


Na mostra a seguir, temos um exemplo já rodando em PHP.
O cenário da questão é a montagem de um “link de navegação” baseado numa estrutura de dados.

$node = '006002009';  // Esta informação é obtida dinamicamente.

$segmentos = strlen($node)/3;
$sql = 'SELECT ACESSO_SCRIPT FROM ACESSO_ADMIN WHERE ACESSO_NIVEL';
$or = '';

Loop de concatenação do comando SQL

for($x = 0; $x < $segmentos; $x++){  
$comp = $x+1;  
$sql.= $OR.'="'.substr($node,0,($indent*$comp)).'" ';  
$or = ' OR ACESSO_NIVEL';  
}

O resultado do loop gera a string:

SELECT ACESSO_SCRIPT FROM ACESSO_ADMIN WHERE ACESSO_NIVEL="006" OR ACESSO_NIVEL="006002" OR ACESSO_NIVEL="006002009"`

O desafio é conseguir a mesma concatenação do loop acima, dentro da Stored Procedure.
Lembrando que a SP receberia como parâmetro apenas o valor de $node. Esse valor é de comprimento variável e segue uma regra de composição em segmentos de 3 algarismos.

Autor da pergunta Bertonni Magnus

Adir Kuhn

Acho que algo assim deva resolver seu problema:

CREATE PROCEDURE batata(node CHAR(30))
BEGIN
    DECLARE segmentos INT;
    DECLARE jump INT;
    DECLARE contador INT;

    SET segmentos = LENGTH(node) / 3;
    SET jump = segmentos;
    SET contador = 1;

    SET @sql = 'SELECT ACESSO_SCRIPT FROM ACESSO_ADMIN WHERE ACESSO_NIVEL=';
    SET @sql = CONCAT(@sql, '"', node, '"', ' ');

    WHILE contador < segmentos DO
        SET @sql = CONCAT(@sql, 'OR ACESSO_NIVEL=', '"', SUBSTR(node, 1, jump), '"', ' ');

        SET contador = contador + 1;
        SET jump = jump * contador;
    END WHILE;

    PREPARE STMT FROM @sql;
    EXECUTE STMT;
END

Update:

Quanto a lógica não tem segredo está sendo utilizado o mesmo esquema que o do exemplo.
Criei uma procedure que espera uma variável que será chamada de ‘node’ do tipo char(30) (se precisar de uma string maior basta aumentar esse número)

Dentro da procedure tem 4 variaveis

segmento que vai calcular o número de segmentos do ‘node’ (node/3)
jump variavel usada para pegar parte do conteúdo da string com substr
contador pra fazer o controle do loop while
e sql que vai conter a string da SQL

apos setar o conteúdo inicial do @sql (SET @sql = ‘SELECT ACESSO_SCRIPT FROM ACESSO_ADMIN WHERE ACESSO_NIVEL=’;)

vou utilizando o comando do mysql CONCAT para concatenar as string de acordo com a lógica necessária.

Após o loop a query sql estará completa,

ai bastar preparar o statement a partir da variável @sql e executar

PREPARE STMT FROM @sql;
EXECUTE STMT;

se quiser debugar e ver a string basta apagar as linhas prepare ... e execute ... e por select @sql;

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 *