IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

[2005] RAISERROR : Incorrect syntax


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut [2005] RAISERROR : Incorrect syntax
    Bonjour,

    lors de la création d"un trigger je reçois un message d'erreur que j'ai du mal à comprendre.

    Msg 102, Level 15, State 1, Procedure vWORK_GenerateFederalNumber_IOINSERT, Line 47
    Incorrect syntax near ')'.
    J'ai essayé plusieurs variantes et je suis à cours d'idée...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
     
    CREATE TRIGGER vWORK_GenerateFederalNumber_IOINSERT
    ON vWORK_GenerateFederalNumber
    INSTEAD OF INSERT
    AS
    BEGIN
    	SET NOCOUNT ON
     
    	SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
    	SET XACT_ABORT ON
     
    	BEGIN TRANSACTION
    		DECLARE @FederalNumber AS INT
     
    		SELECT @FederalNumber = MAX(CAST(FederalNumber AS INT))
    		FROM tMembers
    		WHERE FederalNumber LIKE '7%';
     
    		WITH Assignment (
    			IdMember
    			, Row
    		)
    		AS
    		(
    			SELECT
    				I.IdMember
    				, ROW_NUMBER() OVER(ORDER BY IdMember ASC)
    			FROM inserted AS I
    			INNER JOIN tMembers AS M ON (
    				M.Id = I.IdMember
    			)
    			WHERE M.FederalNumber = ''
    		)
     
    		UPDATE tMembers
    		SET FederalNumber = CAST((@FederalNumber + A.Row) AS VARCHAR(50))
    		FROM Assignment AS A
    		WHERE tMembers.Id = A.IdMember
     
    	COMMIT TRANSACTION
     
    	IF @@ERROR <> 0 
    	BEGIN
    		DECLARE @ErrorMsg NVARCHAR(255)
    		SET @ErrorMsg = N'vWORK_GenerateFederalNumber FAILURE';
     
    		RAISERROR (@ErrorMsg, 17);
    	END
    END
    Merci pour votre aide.

  2. #2
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut
    Au temps pour moi, quand la severity est indiqué le state est obligatoire.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    RAISERROR (N'vWORK_GenerateFederalNumber FAILURE', 17, 1);

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [SQLServerException] Incorrect syntax near '@P0'
    Par manube dans le forum JDBC
    Réponses: 3
    Dernier message: 17/02/2011, 12h00
  2. Réponses: 2
    Dernier message: 14/04/2009, 10h03
  3. [VC++ 2005] Pointeur incorrect
    Par Rafoo dans le forum MFC
    Réponses: 3
    Dernier message: 25/09/2006, 15h44
  4. Réponses: 14
    Dernier message: 11/07/2006, 16h11
  5. Réponses: 3
    Dernier message: 07/06/2005, 14h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo