Jump to content

[Resolvido] Insert update e delete em SP


Recommended Posts

Posted (edited)

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?

Edited by Caça
GeSHi
Posted (edited)

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

Edited by Caça
GeSHi
Posted (edited)

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

DELETE FROM Artigo WHERE ID NOT IN (1, 2, 3, ...)
Edited by Caça

Pedro Martins

Não respondo a duvidas por PM

Posted (edited)

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

Edited by jafm
Posted (edited)

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:(

Edited by jafm
GeSHi

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
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.