Ir para o conteúdo
jafm

[Resolvido] Insert update e delete em SP

Mensagens Recomendadas

jafm

Olá

Tenho um SP que me insere dados vindos de um txt... uso este SP várias vezes, que vai buscar informação a um txt

Tenho já implementado nele um sistema de update, de forma a que ele atualize a informação.

No entanto agora, verifiquei uma lacuna neste SP, que é a inexistência de apagar a informação que já não se encontra no txt.

IF NOT EXISTS
(SELECT ID FROM Artigo
WHERE ID = @ID)
INSERT INTO Artigo (ID, Nome, Descricao) VALUES (@ID,@Nome, @Descricao)
ELSE
UPDATE Artigo set Nome=@Nome, Descricao=@Descricao WHERE ID=@ID

Como é que eu consigo fazer delete a informação existente na base dados mas que já não se encontra no ficheiro txt?

Editado por Caça
GeSHi

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
jafm

Não percebi esta parte

IN (1, 2, 3, ...)

coloquei da seguinte forma

delete from Artigo where ID in (ID,Novo,Descricao)

e não apaga os que os ficheiros txt que se encontram na bd que já não se encontram no txt

Editado por Caça
GeSHi

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
Caça

Ai tens de colocar os IDs dos artigos que estão no txt

DELETE FROM Artigo WHERE ID NOT IN (1, 2, 3, ...)

Editado por Caça

Pedro Martins

Não respondo a duvidas por PM

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
jafm

Mas eu não tenho acesso ao ids que deixaram de vir no txt,

delete from Artigo where ID not in (ID)

coloquei da seguinte forma e não apagou a informação que se encontrava no txt

Editado por jafm

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pmg

Apaga todos os registos da tabela no principio da 'stored procedure'

delete from artigo

-- processa txt

  • Voto 1

What have you tried?

Não respondo a dúvidas por PM

A minha bola de cristal está para compor; deve ficar pronta para a semana.

Torna os teus tópicos mais atractivos e legíveis usando a tag CODE para colorir o código!

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
jafm

Pois, mas não queria alterar muita a estrutura do SP. E também pensei melhor e optei por utilizar um sistema de updade

as
update Artigo set Estado=' '
IF NOT EXISTS
(SELECT ID FROM Artigo
WHERE ID = @ID)
INSERT INTO Artigo (ID, Novo, Descricao, Estado) VALUES (@ID, @Novo ,@Descricao, 'A')
ELSE
UPDATE Artigo set Novo=@Novo,Descricao=@Descricao, Estado='A' WHERE ID=@ID

Só que nesta query só me está a atualizar o ultimo registo:(

Editado por jafm
GeSHi

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites

Crie uma conta ou ligue-se para comentar

Só membros podem comentar

Criar nova conta

Registe para ter uma conta na nossa comunidade. É fácil!

Registar nova conta

Entra

Já tem conta? Inicie sessão aqui.

Entrar Agora

×

Aviso Sobre Cookies

Ao usar este site você aceita os nossos Termos de Uso e Política de Privacidade. Este site usa cookies para disponibilizar funcionalidades personalizadas. Para mais informações visite esta página.