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 :

Fonction Table et dynamic SQL


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Lot (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2011
    Messages : 2
    Par défaut Fonction Table et dynamic SQL
    Bonjour,

    Voici ma fonction :
    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
    ALTER FUNCTION [dbo].[Synchro_GetIds]
    (
    @IdRequest int;
    )
    RETURNS @tt TABLE
    (
    Ids int NOT NULL
    )
    AS
    Begin
    DECLARE @myFirstRequest VARCHAR(8000);
     
    -- for obtain the filter request exemple : 'SELECT IDRETURN FROM DB_TEST where IDRETURN>1000'
    select @myFirstRequest=Request_Text from T_REQUEST
    where id_Request = @IdRequest
     
     
    insert into @tt
    SELECT E_D.ID from E_D where E_D.IDRETURN in (@myFirstRequest)
     
     
    return;
    END
    Comment puis-je faire pour que la chaîne de caractères correspondant à une requête SQL soit interprétée comme une commande SQL et non comme un paramètre ?

    Merci d'avance.

  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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXEC sp_executesql @myFirstRequest
    @myFirstRequest devrait être du NVARCHAR plutôt que du VARCHAR

  3. #3
    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 : 44
    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
    Par défaut
    Bonjour,

    Sergejack, je ne sais pas si c'est ce que vous suggérez, mis il n'est pas possible d'appeler une procédure stockée qui n'est pas étendue dans une fonction.

    Je suppose que ce que vous proposez d'appeler directement sp_executesql.
    Pour cela il faut une procédure stockée, pas une fonction :

    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
    CREATE PROCEDURE usp_Synchro_GetIds
    	@IdRequest int
    AS
    BEGIN
    	SET NOCOUNT ON
     
    	DECLARE @myFirstRequest varchar(max)
    		, @sql nvarchar(max);
     
    	SELECT	@myFirstRequest = Request_Text 
    	FROM	dbo.T_REQUEST
    	WHERE	id_Request = @IdRequest
     
    	SET	@sql = 'SELECT E_D.ID FROM E_D WHERE E_D.IDRETURN IN (' + @myFirstRequest + ')'
    	EXEC	sp_executesql @sql
    END
    A lire

    @++

Discussions similaires

  1. Chargement d'un XML en tables avec PL/SQL
    Par jenlin dans le forum PL/SQL
    Réponses: 7
    Dernier message: 21/03/2011, 12h55
  2. dynamic sql : exécuter des commandes sql d'une table
    Par bibi92 dans le forum Développement
    Réponses: 5
    Dernier message: 22/03/2010, 11h01
  3. Réponses: 1
    Dernier message: 19/03/2009, 10h53
  4. Réponses: 0
    Dernier message: 27/11/2007, 17h17
  5. Copie de tables access vers Sql ?
    Par franck06 dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 01/03/2005, 14h10

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