Avatar billede dd_ns Nybegynder
26. marts 2003 - 14:10 Der er 7 kommentarer

trigger...

Hvordan laver jeg lige sådan her...

Hvis c1 bliver ændret til 1 skal c2 ændres til 0
og
Hvis c2 bliver ændret til 1 skal c2 ændres til 0

Hvordan???
Avatar billede bjornicle Nybegynder
26. marts 2003 - 14:20 #1
declare @val bit
select @val = c1 from inserted
if @val = 1
  update table set c2 = 0
else
  update table set c2 = 1


noget i den retning :)
Avatar billede bjornicle Nybegynder
26. marts 2003 - 14:20 #2
oops, inserted skal vaere updated istedet
Avatar billede dd_ns Nybegynder
26. marts 2003 - 14:22 #3
Kan sku ikke lige få det til at fungere.... Kan du ikke lave en fuld en, altså med:
CREATE TRIGGER [TRIGGER NAME] ON [dbo].[tbl_data]
FOR INSERT, UPDATE, DELETE
AS
osv...
Avatar billede bjornicle Nybegynder
26. marts 2003 - 14:30 #4
CREATE TRIGGER [TRIGGER NAME] ON [dbo].[Table]
FOR UPDATE
AS

declare @val bit
select @val = c1 from inserted
if @val = 1
  update table set c2 = 0
else
  update table set c2 = 1


Nu har jeg ikke selv testet det, saa du skal maaske rette det til
Avatar billede bjornicle Nybegynder
26. marts 2003 - 14:31 #5
argh, igen skal det vaere updated og ikke inserted :)
Avatar billede dd_ns Nybegynder
26. marts 2003 - 15:21 #6
den siger fejl på det der kommer efter from...
Avatar billede bjornicle Nybegynder
26. marts 2003 - 15:32 #7
ok, det skulle vaere inserted alligevel, jeg bruger aldrig triggers selv da det ikke er den fedeste performance man faar, men jeg testede dette og det virkede:

CREATE TRIGGER [testctrig] ON [dbo].[testc]
FOR UPDATE
AS

declare @val bit
select @val = c1 from inserted
if @val = 1
  update testc set c2 = 0
else
  update testc set c2 = 1
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester