Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Transaktioner

Postades av 2001-05-29 11:23:00 - Andreas Hillqvist, i forum sql-server/msde, Tråden har 2 Kommentarer och lästs av 1031 personer

Jag vill avbryta min transaktion om några fel uppstår. Finns det något smidigare sätt en att kontrollera @@ERROR efter varje sats?

BEGIN TRANSACTION
EXEC dbo.spUpdateStageGroup '{8A949ED0-1D99-4EB7-A201-7C7A6BD9429B}', Null, '{3FBFEC4D-4093-11D5-BC60-00A024419708}', '{2152A647-EE12-4C7F-B93E-01ECD2563A86}', 1
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spUpdateStageGroup '{5E8D0274-8EFE-4BAA-86AD-4C4039E35BF1}', '{8A949ED0-1D99-4EB7-A201-7C7A6BD9429B}', '{3FBFEC4D-4093-11D5-BC60-00A024419708}', '{5B50534B-B0D2-4AAC-A853-71ECF1F18F5B}', 2
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spUpdateStageGroup '{76E1613C-5177-4C73-8596-396FDCB883A7}', '{8A949ED0-1D99-4EB7-A201-7C7A6BD9429B}', '{3FBFEC4D-4093-11D5-BC60-00A024419708}', '{5B50534B-B0D2-4AAC-A853-71ECF1F18F5B}', 3
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spInsertStageGroup '{4AFFAFE1-2A5C-4F14-9E34-5A55654819C4}', '{8A949ED0-1D99-4EB7-A201-7C7A6BD9429B}', '{3FBFEC4D-4093-11D5-BC60-00A024419708}', '{BDB54DE4-3A39-4678-96AB-90C788CF2A6D}', 4
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spInsertStageGroup '{BCD5CE5B-FA1C-4BF7-A325-A5F27ACEEEED}', '{8A949ED0-1D99-4EB7-A201-7C7A6BD9429B}', '{3FBFEC4D-4093-11D5-BC60-00A024419708}', '{2152A647-EE12-4C7F-B93E-01ECD2563A86}', 5
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spDeleteStageGroup '{77D1A381-EA36-461B-A733-2156CA3CD0A7}'
IF @@ERROR <> 0 GOTO BATCH_ERROR

EXEC dbo.spDeleteStageGroup '{999734D9-F67D-446E-9515-9FE597959078}'
IF @@ERROR <> 0 GOTO BATCH_ERROR


COMMIT TRANSACTION
GOTO BATCH_EXIT

BATCH_ERROR:
ROLLBACK TRANSACTION

BATCH_EXIT:


Svara

Sv: Transaktioner

Postades av 2001-05-30 09:15:00 - Christoffer Hedgate

Nej, inte vad jag kan komma på. @@error nollställs ju så fort man kör ett nytt statement så det går inte att vänta och kolla den senare. Ett alternativ kan vara att försöka göra ROLLBACK på transaktionen inifrån de procedurer du anropar. Jag har försökt testa detta, men kommer inte undan att jag får några varningar. Det fungerar dock som tänkt, men bör nog testas mer ändå. Säg till om du kommer fram till något.


create table foobar (a int)
go

create procedure bar
(@a int)
as
begin

if @a < 10
begin
print 'rollback görs nu...'
rollback tran mytran
end
else
begin
print 'ok'
end

end
go

create procedure foo
(@b int)
as
begin

begin tran mytran

insert into foobar values (@b)

exec bar @a=@b

commit tran mytran
end
go


-- Testa...
/*
exec foo 8

select @@trancount

select * from foobar
*/


Svara

Sv: Transaktioner

Postades av 2001-05-30 12:01:00 - Andreas Hillqvist

Jag tror jag hittade det jag sökte:

Errors During Transaction Processing

If a severe error prevents the successful completion of a transaction, SQL Server automatically rolls back the transaction and frees all resources held by the transaction. If the client's network connection to SQL Server is broken, any outstanding transactions for the connection are rolled back when the network notifies SQL Server of the break. If the client application fails or if the client computer goes down or is restarted, this also breaks the connection, and SQL Server rolls back any outstanding connections when the network notifies it of the break. If the client logs off the application, any outstanding transactions are rolled back.

If a run-time statement error (such as a constraint violation) occurs in a batch, the default behavior in SQL Server is to roll back only the statement that generated the error. You can change this behavior using the SET XACT_ABORT statement. After SET XACT_ABORT ON is executed, any run-time statement error causes an automatic rollback of the current transaction. Compile errors, such as syntax errors, are not affected by SET XACT_ABORT.

It is the responsibility of the programmer to code the application to specify the correct action (COMMIT or ROLLBACK) if a run-time or compile error occurs.


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 154
27 952
271 704
855
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies