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 :

utilisation de sp_executesql ?


Sujet :

MS SQL Server

  1. #1
    Candidat au Club
    Inscrit en
    Avril 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut utilisation de sp_executesql ?
    Bonjour,

    j'ai une procédure qui reçoi plusieurs paramètres parmi lequels @Qte,@signe,ce dérnier peut prendre les valeurs:=,<,>,...

    Est ce que si possible d'execute une requête a l'aide de sp_executesql sous la form:

    select * from produit where Quantite @signe @Qte

    Si oui comment ?

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Il vous suffit de construire la requête SQL au fur et à mesure en stockant celle-ci dans une variable de type NVARCHAR, et de la passer en paramètre à sp_executeSQL:

    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
    CREATE PROCEDURE PsTest
    	@signe NVARCHAR(2),
    	@qte INT
    AS
    BEGIN
    	IF @signe NOT IN (N'<', N'>', N'<=', N'>=', N'=')
    	BEGIN
    		RAISERROR('Signe %s invalide !', 16, 1, @signe)
    	END
    	ELSE
    	BEGIN
    		DECLARE @SQL NVARCHAR(256),
    				@Params NVARCHAR(64)
     
    		SELECT @SQL = N'SELECT mesColonnes ' +
    					'FROM dbo.produit ' +
    					'WHERE Quantite ' + @signe + ' @qte_IN',
    				@Params = N'@qte_IN INT'
     
    		-- PRINT @SQL
     
    		EXEC sp_executeSQL @SQL, @qte
    	END
    END
    Pensez toujours à écrire le nom des colonnes même s'il s'agit de toutes les colonnes de votre table et à qualifier le nom des objets au moins par le nom du schéma auquel ils appartiennent, ça n'en sera que plus performant et plus propre

    @++

  3. #3
    Candidat au Club
    Inscrit en
    Avril 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci elsuket ,
    ça marche,il suffit d'affecter le paramètre @qte à @qte_IN :


    EXEC sp_executeSQL @SQL, @Params,@qte_IN=@qte


  4. #4
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    OK

    Il me semblait que ça marchait sans, merci pour le tuyau

    @++

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

Discussions similaires

  1. utiliser les tag [MFC] [Win32] [.NET] [C++/CLI]
    Par hiko-seijuro dans le forum Visual C++
    Réponses: 8
    Dernier message: 08/06/2005, 15h57
  2. Réponses: 4
    Dernier message: 05/06/2002, 14h35
  3. utilisation du meta type ANY
    Par Anonymous dans le forum CORBA
    Réponses: 1
    Dernier message: 15/04/2002, 12h36
  4. [BCB5] Utilisation des Ressources (.res)
    Par Vince78 dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/04/2002, 16h01
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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