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 :

MSSQL2K: concatenation recursive dans un sous select


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Japon

    Informations forums :
    Inscription : Novembre 2007
    Messages : 125
    Par défaut MSSQL2K: concatenation recursive dans un sous select
    Bonjour, je souhaiterai trouver un moyen de rendre cela possible

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     SELECT  d.DealerId, 
       d.Name,    
       d.longdescription,
            NULL    as Origin, 
     
    (select  EntityId from dbo.DEALER_ENTITY_ACCESS where DealerId = d.DealerId)
     
     
        as entities
     FROM dbo.DEALER d
    si je fais cela , ca fonctionne, mais j'ai +-10 à 20 'entities'.
    Merci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     SELECT  d.DealerId, 
       d.Name,    
       d.longdescription,
            NULL    as Origin, 
    
    (select  top 1 EntityId from dbo.DEALER_ENTITY_ACCESS where DealerId = d.DealerId)
     
    
        as entities
     FROM dbo.DEALER d

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    Commencez par respectez ceci si vous voulez de l'aide :
    http://www.developpez.net/forums/showthread.php?t=96701

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Japon

    Informations forums :
    Inscription : Novembre 2007
    Messages : 125
    Par défaut
    Bonjour, c'est vrai que j'aurrai pu être plus claire !
    donc j'aurrai besoin d'une fonction aggregate qui ferai une concatenation direct de la liste des champ

    genre

    devise
    ------
    eu
    us
    jpy
    tbh

    deviendrai

    eu, us, jpy, tbh

    est ce plus claire ??

    bien à vous.

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DECLARE @DATA VARCHAR(8000);
    SET @DATA = '';
    SELECT @DATA = @DATA + COALESCE(devise +', ', '')
    FROM MaTable;
    SELECT @DATA;
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Japon

    Informations forums :
    Inscription : Novembre 2007
    Messages : 125
    Par défaut
    Merci,
    ceci a fonctionné, je l'ai adapté à mes besoins
    voici le bout de code, qui pourrait servir de base à autrui !

    ++

    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
     
    drop FUNCTION f_DEA_STR_AGG
    CREATE FUNCTION dbo.f_DEA_STR_AGG
    (@DealerId char(5))
    RETURNS varchar(2000)
    AS
    BEGIN
     
    	DECLARE @List varchar(2000)--,@DealerId char (5)
    	  SET @List = ''
    	  SELECT @List = @List +
    		CASE
    		  WHEN @List = '' THEN ''
    		  ELSE ','
    		END +EntityId
    		--CONVERT(varchar,EntityId)
    	  FROM DEALER_ENTITY_ACCESS WHERE DealerId = @DealerId
    	order by EntityId
    	 --print @List
    RETURN @List
    --return 'ok'
    END
     
    select dbo.f_DEA_STR_AGG('00014')

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

Discussions similaires

  1. WITH dans un sous select
    Par phili_b dans le forum Développement
    Réponses: 10
    Dernier message: 17/02/2010, 16h38
  2. [HQL] jointure implicite dans un sous-select
    Par Manopower dans le forum Hibernate
    Réponses: 1
    Dernier message: 09/09/2009, 11h45
  3. Selection de valeur de champs dans des sous formulaires
    Par Hydex dans le forum VBA Access
    Réponses: 5
    Dernier message: 05/06/2007, 15h17
  4. Sous-requête dans la clause Select
    Par Danger dans le forum WinDev
    Réponses: 2
    Dernier message: 24/05/2005, 17h33
  5. [firebird] sous select dans un select
    Par gdido dans le forum SQL
    Réponses: 2
    Dernier message: 14/05/2004, 09h57

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