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

Accès aux données Discussion :

Probleme Stored procedure


Sujet :

Accès aux données

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Points : 19
    Points
    19
    Par défaut Probleme Stored procedure
    bonjour,

    Apres l'execution de la stored procedure, les deux tables Address, ContactInformation sont rempli mais la table EndUser est vide, pouvez vous me dire pq ?

    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
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
     
    ALTER PROCEDURE [dbo].[EndUser_Insert]
     
    @FirstName          nvarchar(50),
    @LastName          nvarchar(50),
    @AddressLine          nvarchar(50),
    @AddressLine2    nvarchar(50),
    @City                    nvarchar(50),
    @State                  nvarchar(50),
    @PostalCode        nvarchar(50),
    @Phone                nvarchar(50),
    @Phone2              nvarchar(50),
    @Fax                    nvarchar(50),
    @Email                 nvarchar(50),
    @EndUserTypeID int,
    @Password           nvarchar(50),
    @IsSubscribed      bit
     
    AS
     
    --Start the transaction
    BEGIN TRANSACTION
     
    DECLARE @AddressID int
    DECLARE @ContactInformationID int
     
    INSERT INTO Address
    (AddressLine,
    AddressLine2,
    City,State,
    PostalCode)
    VALUES
    (@AddressLine,
    @AddressLine2,
    @City,
    @State,
    @PostalCode)
    SET @AddressID = @@IDENTITY
     
    -- Roll back the transaction if there are any errors
     
    IF @@ERROR <> 0
    BEGIN
    -- Roll back the transaction
    ROLLBACK
     
    -- Raise an error and return
    RAISERROR ('Error INSERT INTO Address.', 16, 1)
    RETURN
    END
     
    INSERT INTO ContactInformation
    (Phone,
    Phone2,
    Fax,
    Email)
    VALUES
    (@Phone,
    @Phone2,
    @Fax,
    @Email)
    SET @ContactInformationID = @@IDENTITY
     
    -- Roll back the transaction if there are any errors
     
    IF @@ERROR <> 0
    BEGIN
    -- Roll back the transaction
    ROLLBACK
    -- Raise an error and return
     
    RAISERROR ('Error INSERT INTO ContactInformation', 16, 1)
    RETURN
    END
     
    INSERT INTO EndUser
    (EndUserTypeID,
    FirstName,
    LastName,
    AddressID,
    ContactInformationID,
    Password,
    IsSubscribed)
    VALUES
    (@EndUserTypeID,
    @FirstName,
    @LastName,
    @AddressID,
    @ContactInformationID,
    @Password,
    @IsSubscribed)
     
    SELECT @@IDENTITY
    -- Roll back the transaction if there are any errors
    IF @@ERROR <> 0
    BEGIN
    -- Roll back the transaction
    ROLLBACK
    -- Raise an error and return
    RAISERROR ('Error INSERT INTO EndUser', 16, 1)
    RETURN
    END
    COMMIT

  2. #2
    Rédacteur
    Avatar de WOLO Laurent
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Mars 2003
    Messages
    2 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 741
    Points : 4 414
    Points
    4 414
    Par défaut
    Parce que @@ERROR est réinitialisé après chaque Ordre T-SQL, donc si tu dois faire ton rollback juste après l'insert pas après autre chose.
    Je te conseillerais d'utiliser BEGIN TRY et END TRY si tu as la version 2005 ou supérieure.

    Découvrez la FAQ de MS SQL Server.
    La chance accorde ses faveurs aux esprits avertis !

Discussions similaires

  1. Probleme Performance Procedure stockee
    Par DaxTaz dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 16/09/2005, 18h43
  2. [Debutant][Store procedure][performance] plan d'acces
    Par Carmen dans le forum Débuter
    Réponses: 2
    Dernier message: 11/01/2005, 09h20
  3. Apropos des Transactions au sein d'un Stored Procedure
    Par Sarbacane dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 16/11/2004, 08h21
  4. [Stored Procedure]Only constants, expressions, or variables
    Par nmerydem dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 20/10/2004, 18h29
  5. Probleme Oracle + Procedure Stockee
    Par ForumWWW dans le forum Bases de données
    Réponses: 5
    Dernier message: 09/07/2004, 16h00

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