Jump to content
Robson Freitas

Criar Trigger para alterar registro somente na modificação de um campo em sql server

Recommended Posts

Tenho uma tabela de cadastro do SQL Server, tenho uma coluna que apresenta o status desse cadastro ('A','I','S','C').

 

Criei um campo com nome Update_data, que receberá um datatime toda vez que o cliente alterar o status do cadastro. Isso também vale para um insert.

 

Estou com dúvidas, pois nunca criei uma Trigger em sql server.

 

Ex: da minha tabela

 ID | Processo | status | Update_data

  1 | A33      | A      | null

2   | A34      | I      | null

3    | A55      |     A | null

 

Não consegui avançar no seguinte exemplo abaixo trigger: 

CREATE TRIGGER atualizaData

ON cadastro

AFTER INSERT,UPDATE

AS

IF INSERT OR UPDATE(status)

BEGIN
UPDATE cadastro SET Update_data = GETDATE()

WHERE id = id_que_foi_modifica/inserida

END

 

Ao final, será atualizado com a data atual somente se houver modificação ou inserção no campo da situação.

Share this post


Link to post
Share on other sites

creio que basta

 

CREATE TRIGGER atualizaData

ON cadastro

BEFORE INSERT,UPDATE

AS

BEGIN

  NEW.Update_data = GETDATE()

END;

 

Ao menos no Oracle é assim

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Robson Barros da Rocha
      Bom dia povo. Tenho um problema, e não uma dúvida. Eu executo no SQL Server esta query para agrupar os resultados cujo tenha o código do comprovante repetido:
      SELECT * FROM SHOP_Pedidos WHERE show='1' GROUP BY comprovante As colunas são:
      ID = Se preenche automaticamente
      comprovante = Recebe o código do comprovante
      productName = Nome do produto
      productValue = Valor do produto
      dateSent = Data que o produto foi enviado
      show = Enviado (1) e não enviado (0)
       
      A query que mostrei acima, não retorna dados porque aparece esse erro: "Column 'SHOP_Pedidos.id' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause." Certo, então aí que está o problema. Vendo o erro, eu troquei a * pela coluna comprovante, e resultou, mas a consulta só retorna a coluna comprovante (por conta do SELECT estar especificando somente ele. 
       
      A dúvida é: Tem como recuperar todos as colunas, assim como mysql?
    • By alecram28
      Boa noite. Preciso fazer um select que me retorne os dados desse select:
      hjgnvbcbn
    • By José Peixoto
      Olá,
       
      há alguma forma de fazer uma trigger só ser executada depois que a outra executar? 
       
      Por exemplo: a trigger2 só é disparada quando a trigger1 fizer o commit das informações.
       
      Obrigado desde já :)
    • By luca0202
      ola fiz a instalação de um programa que eu fiz e deu o seguinte erro : SQL state: 42000 SQL error code 8179
      Não foi possivel encontrar a instrução preparada como o identificador - 1.
      O que pode ser ? estou usando componentes dbexpress
    • By gustavo491
      Tenho esse modelo de banco de dados com algumas informações cadastradas e preciso buscar atráves de um select  os Campeonato e Modalidades que uma pessoa não tem vinculo, porém já tentei de diversas maneira e não consegui exito, máximo que consegui foi buscar as modalidades que não existe ninguém cadastrado.

×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.