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

MS SQL Server Discussion :

[MSSQL 2005] Retourner une erreure dans une SP


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Webmaster
    Inscrit en
    Mars 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2006
    Messages : 88
    Points : 50
    Points
    50
    Par défaut [MSSQL 2005] Retourner une erreure dans une SP
    Bonjour,

    Je fais actuellement mon premier "gros" site en ASP.NET 2.0 avec une base MS-SQL 2005 et je fais donc quasimment tout passer par les procédures stockées. Par contre là je vais avoir besoin d'aide, j'explique mon soucis.

    J'ai une page inscription et une procédure stockée sp_mship_AddUser avec plusieurs paramètres et ce que je veux c'est qu'il y ait un test sur les paramètres "@email, @username" pour vérifier si cet email et/ou ce pseudo sont déjàs utilisés et dans ce cas retourner un message d'erreur que je récupérerais pour le traiter au niveau ASP.NET.

    Est-ce possible? Ma SP actuelle est :

    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
    ALTER PROCEDURE dbo.sp_mship_AddUser
    	@fullname nvarchar(50),
    	@address nchar(200),
    	@zipcode nchar(10),
    	@city nchar(30),
    	@country nchar(20),
    	@state nchar(75),
    	@phone nchar(25),
    	@sexe tinyint,
    	@dateofbirth datetime,
    	@lang nchar(6),
    	@hear nchar(30),
    	@question nchar(75),
    	@answer nchar(75),
    	@pincode smallint,
    	@email nvarchar(255),
    	@username nvarchar(16),
    	@password nvarchar(255),
    	@rememberme tinyint
    AS
     
    INSERT INTO T_MEMBERS
    	(fullname, address, zipcode, city, country, state, phone, sexe, dateofbirth, hear, secret_question, secret_answer, pincode, email, username, password, rememberme, lang)
    VALUES
        (@fullname, @address, @zipcode, @city, @country, @state, @phone, @sexe, @dateofbirth, @hear, @question, @answer, @pincode, @email, @username, @password, @rememberme, @lang)
     
    RETURN
    Comment retourner un message après avoir effectués les 2 tests (mails & pseudo)? Ou alors il faut d'abord vérifier ca puis ensuite lancer cette procédure mais ca ferait lourd...

    Merci d'avance!

  2. #2
    Membre du Club
    Profil pro
    Webmaster
    Inscrit en
    Mars 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2006
    Messages : 88
    Points : 50
    Points
    50
    Par défaut
    Pour résumer, je souhaite effectuer les tests pour vérifier si le paramètre email existe déjà dans ma table et la même chose pour le paramètre username. Puis si c'est pas le cas on ajoute l'user et on retourne le message "OKADDED", si le pseudo existe déjà "NOKUSERNAME" et si l'email existe déjà "NOKEMAIL".

    Le message retourné est traité sur ma page ASP.NET et j'affiche soit un message de succès soit une erreur. Est-ce possible ou ca ne peut retourner que des "rows" ou des int?

    Merci à vous.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 434
    Points : 502
    Points
    502
    Par défaut
    Très simple :

    tu ajoutes dans les paramètres de ta procédure stockée un paramètre de type OUTPUT : disons @EXISTDEJA

    Dans ta proc stockée, tu fais un test style
    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
     
    CREATE PROCEDURE dbo.sp_mship_AddUser
    @Email nvarchar(255),
    @EXISTDEJA int OUTPUT
     
     
    SET @EXISTDEJA = 0
     
    IF EXISTS (select Email from T_MEMBERS where Email = @Email)
    SET @EXISTDEJA = 1
     
    if (@EXISTSDEJA = 0)
    BEGIN
    --ton code d'insertion
    END
     
    RETURN
    Et dans ton code behind tu testes la valeur de la variable @EXISTEDEJA

    Regarde l'aide SQL surle mot OUTPUT, tu trouveras plein d'exemples

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/03/2013, 13h00
  2. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  3. [POO] dans une classe, appeler une fonction dans une méthode
    Par arnaudperfect dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2007, 23h04
  4. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 10h13
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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