sqlcmd goto est pas tout à fait-ends de travail script sur erreur
-
21-09-2019 - |
Question
J'utilise l'outil sqlcmd avec SQL Server pour exécuter des scripts. Les scripts ajouter / enregistrements de mise à jour. J'ai besoin sqlcmd de cesser d'exécuter et de donner une valeur non 0 retour si le script renvoie une erreur. Je pensais que ce qui suit fonctionnerait, mais il ne fonctionne pas.
DECLARE @intErrorCode INT
BEGIN TRAN T1;
SET IDENTITY_INSERT dbo.SomeTable ON
INSERT INTO dbo.SomeTable(some_type_id,some_type,code_definition,use_some_lookup,created_by,created_on,modified_by,modified_on,org_some)
VALUES(0,'yadayada','None','N','system',GETDATE(),'system',GETDATE(),'N')
SELECT @intErrorCode = @@ERROR
IF (@intErrorCode <> 0) GOTO PROBLEM
SET IDENTITY_INSERT dbo.SomeTable OFF
UPDATE dbo.SomeTable
SET some_type = 'Contract Analytical'
WHERE some_type_id = 2
SELECT @intErrorCode = @@ERROR
IF (@intErrorCode <> 0) GOTO PROBLEM
PROBLEM:
IF (@intErrorCode <> 0) BEGIN
PRINT 'Unexpected error occurred!'
ROLLBACK TRAN
SELECT @intErrorCode
RETURN
END
COMMIT TRAN T1;
La solution
vous commencez sqlcmd avec l'option -b
sur lot d'erreur abort arrêter en cas d'erreur.
Autres conseils
Si vous voulez une valeur de retour non nulle, vous pouvez retourner la valeur dans @intErrorCode
ala
RETURN @intErrorCode
La sélection qu'il retourne dans un jeu de résultats plutôt que la valeur de retour.
essayez d'utiliser try-catch:
DECLARE @intErrorCode INT
BEGIN TRY
BEGIN TRAN T1;
SET IDENTITY_INSERT dbo.SomeTable ON
INSERT INTO dbo.SomeTable (some_type_id,some_type,code_definition,use_some_lookup,created_by,created_on,modified_by,modified_on,org_some)
VALUES(0,'yadayada','None','N','system',GETDATE(),'system',GETDATE(),'N')
SET IDENTITY_INSERT dbo.SomeTable OFF
UPDATE dbo.SomeTable
SET some_type = 'Contract Analytical'
WHERE some_type_id = 2
END TRY
BEGIN CATCH
IF XACT_STATE()!=0
BEGIN
ROLLBACK TRANSACTION
END
SELECT
,ERROR_NUMBER() AS ErrorNumber --same as @@ERROR
,ERROR_SEVERITY() AS ErrorSeverity
,ERROR_STATE() AS ErrorState
,ERROR_PROCEDURE() AS ErrorProcedure
,ERROR_LINE() AS ErrorLine
,ERROR_MESSAGE() AS ErrorMessage
PRINT 'Unexpected error occurred!'
RETURN 999
END CATCH
COMMIT TRAN T1;
RETURN 0
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow