Jump to content
  • Revista PROGRAMAR: Já está disponível a edição #60 da revista programar. Faz já o download aqui!

jafm

[Resolvido] Insert update e delete em SP

Recommended Posts

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?

Edited by Caça
GeSHi

Share this post


Link to post
Share on other sites
Caça

Faz um delete simples, tipo

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


Pedro Martins

Não respondo a duvidas por PM

Share this post


Link to post
Share on other 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

Edited by Caça
GeSHi

Share this post


Link to post
Share on other 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, ...)

Edited by Caça

Pedro Martins

Não respondo a duvidas por PM

Share this post


Link to post
Share on other 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

Edited by jafm

Share this post


Link to post
Share on other sites
pmg

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

delete from artigo

-- processa txt

  • Vote 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!

Share this post


Link to post
Share on other sites
Rui Carlos

Também me parece que apagar tudo no início é a melhor opção, até porque depois deixas de precisar do if e dos updates (assumindo que não tens ids repetidos no mesmo txt).

Share this post


Link to post
Share on other 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:(

Edited by jafm
GeSHi

Share this post


Link to post
Share on other sites
jafm

ninguém me consegue, ajudar explicar a razão por apenas o ultimo registo aparecer com o Estado a 'A'?

O UPDATE deveria estar noutro sitio?

Share this post


Link to post
Share on other sites
pmg

No teu query qual é o valor de @ID?

De onde é que vem?


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!

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

×

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.