Jump to content
Fórum Script Brasil
  • 0

Variável em consulta com parametro usando IN no where


Mackaulim
 Share

Question

Olá !! preciso muito de um help de quem tem um pouco mais de experiência......

Preciso enviar esse valor dessa váriavel para o IN dentro do where do select porém já tentei de várias formas e não consegui 

o Original seria assim 

SELECT  max(aging_liberacao) as aging_lib 
FROM bd.gd_ob 

where projeto = '00003' and mrp in ('O08', 'OM2')

 

tentei assim 

SET @mrps =  '''O08'',''OM2''';   e assim  SET @mrps =  Concat(Concat('''O08''',','),'''OM2''');

SELECT  max(aging_liberacao) as aging_lib 
FROM bd.gd_ob 
where projeto = '00003' and mrp in (select @mrps)  -- Com select e sem também

sei que há possibilidade de realizar pela linguagem de programação, porém é uma consulta muito grande para carregar no processamento.

Pelo que entendi o problema é a passagem do parâmetro, pois quando envio apenas 1 elemento ('O08' por exemplo) ele funciona, mas é preciso passar mais, podendo ser 2,3,4,5 não é uma quantidade fixa por isso uso o IN.

Alguém poderia me ajudar ? 

Edited by Mackaulim
Erro de ortografia e coerência ortográfica
Link to comment
Share on other sites

1 answer to this question

Recommended Posts

  • 0

Boa noite.

Você pode criar esta procedure

DELIMITER $$

CREATE PROCEDURE `bd`.`exemplo`(IN variavel VARCHAR(100))
BEGIN
   SET @preparable_stmt = CONCAT("SELECT  max(aging_liberacao) as aging_lib 
       FROM bd.gd_ob 
       WHERE projeto = '00003' AND mrp IN(", variavel, ")"); 
   PREPARE stmt FROM @preparable_stmt;
   EXECUTE stmt;
   -- DEALLOCATE PREPARE stmt;
END$$

DELIMITER ;

e executá-la assim:

CALL exemplo('"O08",'"OM2"');

 

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share



  • Forum Statistics

    • Total Topics
      149.6k
    • Total Posts
      646.1k
×
×
  • Create New...