Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Danilo Camargo

Como posso criar Triggers?

Recommended Posts

Olá, galera!

 

Estou desenvolvendo um projeto ERP para uma matéria da faculdade e estou tendo dificuldades com relação a TRIGGERS. O projeto foi dividido em grupos na sala, cada grupo ficou com um módulo, no meu caso, meu grupo ficou com o Módulo Estoque. O que eu gostaria de fazer é o seguinte: Sempre que houver um INSERT na tabela "est_moviment", chamar uma TRIGGER que atualize o campo "cad_prod_estoque" da tabela "est_cad_prod". Se na hora do INSERT na tabela "est_moviment", for selecionado no campo "mov_status_id" igual à saida, deverar subtrair do campo "cad_prod_estoque". E se for igual à entrada, devera somar. Segue o Código do banco abaixo:

 


 

CREATE TABLE `est_cad_prod` (
  `cad_prod_id` int(11) NOT NULL,
  `cate_prod_id` int(11) NOT NULL,
  `cad_prod_codigo` varchar(10) COLLATE utf8_bin NOT NULL,
  `cad_prod_est_min` int(20) NOT NULL,
  `cad_prod_nome` varchar(40) COLLATE utf8_bin NOT NULL,
  `cad_prod_descritivo` varchar(255) COLLATE utf8_bin NOT NULL,
  `cad_prod_data` date NOT NULL,
  `cad_prod_un_medida` varchar(3) COLLATE utf8_bin NOT NULL,
  `cad_prod_ncm` int(11) NOT NULL,
  `cad_prod_estoque` int(11) NOT NULL
)

CREATE TABLE `est_cate_prod` (
  `cate_prod_id` int(11) NOT NULL,
  `cate_prod_descritivo` varchar(40) COLLATE utf8_bin NOT NULL
)

CREATE TABLE `est_moviment` (
  `mov_id` int(11) NOT NULL,
  `mov_status_id` int(11) NOT NULL,
  `cad_prod_id` int(11) NOT NULL,
  `mov_qtde` int(11) NOT NULL,
  `mov_nf` int(5) NOT NULL,
  `mov_valor_uni` int(10) NOT NULL,
  `mov_data` date NOT NULL,
  `set_id` int(11) NOT NULL
)


CREATE TABLE `est_moviment_status` (
  `mov_status_id` int(11) NOT NULL,
  `mov_status` varchar(15) COLLATE utf8_bin NOT NULL
)


CREATE TABLE `est_requisicao` (
  `req_id` int(11) NOT NULL,
  `cate_prod_id` int(11) NOT NULL,
  `req_descricao` varchar(255) COLLATE utf8_bin NOT NULL,
  `req_data` date NOT NULL,
  `req_status` varchar(10) COLLATE utf8_bin NOT NULL
)


CREATE TABLE `est_requisicao_itens` (
  `req_itens_id` int(11) NOT NULL,
  `req_id` int(11) NOT NULL,
  `cad_prod_id` int(11) DEFAULT NULL,
  `set_id` int(11) NOT NULL,
  `req_itens_novo` varchar(40) COLLATE utf8_bin NOT NULL,
  `req_itens_qtde` int(11) NOT NULL
)


CREATE TABLE `est_setor` (
  `set_id` int(20) NOT NULL,
  `set_descritivo` varchar(20) COLLATE utf8_bin NOT NULL
)

 

Editado por DiF

Compartilhar este post


Link para o post
Compartilhar em outros sites

Fiz aqui um exemplo, assumindo que 1 seja entrada de produto (somar no estoque) e 2 seja saída de produto (subtrair do estoque) veja:

 

delimiter //
CREATE DEFINER=`root`@`localhost` TRIGGER `atualiza_estoque` 
AFTER INSERT ON `est_moviment` 

FOR EACH ROW 
BEGIN

   IF(NEW.mov_status_id = 1) THEN
       UPDATE est_cad_prod 
           SET cad_prod_estoque = cad_prod_estoque + NEW.mov_qtde
               WHERE NEW.cad_prod_id = cad_prod_id;
               
   ELSE
       UPDATE est_cad_prod
           SET cad_prod_estoque = cad_prod_estoque - NEW.mov_qtde
               WHERE NEW.cad_prod_id = cad_prod_id;
   END IF;

END;//
delimiter ;

 

  • Curtir 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • Autor do tópico
  •  Attilio Galzerano, funcionou perfeitamente. Muito obrigado pela ajuda, você nem imagina como estou grato. Que Deus lhe abençoe.

    • Curtir 1

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Crie uma conta ou entre para comentar

    Você precisar ser um membro para fazer um comentário






    Sobre o Clube do Hardware

    No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

    Direitos autorais

    Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

    ×