Accueil > > > SQL SERVER – AGRÉGER DES CHAMPS VARCHAR
SQL SERVER – AGRÉGER DES CHAMPS VARCHAR
Information sur la source
Description
Comment à partir d'une table comme celle-ci : Champ ----- A B C D E faire pour récuprer une chaîne de caractères de ce type : "A, B, C, D, E" Et bien voici les solutions. La première fonctionne sur toutes les éditions de SQL Server 7 à 2005. La seconde fonctionne sur toutes les éditions de SQL Server 2005 uniquement (Express incluse).
Source
- -- Création de la table
- IF OBJECT_ID('MaTable') IS NULL
- CREATE TABLE MaTable (Champ varchar(10))
- GO
-
- -- Remplissage
- INSERT INTO MaTable (Champ) VALUES ('A')
- INSERT INTO MaTable (Champ) VALUES ('B')
- INSERT INTO MaTable (Champ) VALUES ('C')
- INSERT INTO MaTable (Champ) VALUES ('D')
- INSERT INTO MaTable (Champ) VALUES ('E')
- INSERT INTO MaTable (Champ) VALUES ('F')
- INSERT INTO MaTable (Champ) VALUES ('G')
- INSERT INTO MaTable (Champ) VALUES ('H')
-
- -- 1ère méthode avec SQL Server 7, 2000 et 2005
- DECLARE @machaine varchar(200)
-
- SET @machaine = ''
-
- SELECT @machaine = @machaine + Champ + ',' FROM MaTable
-
- SELECT @machaine
-
- -- 2ème méthode avec SQL Server 2005 uniquement
-
- SELECT champ + ',' as 'text()'
- FROM MaTable
- FOR XML PATH('')
-
- -- Supprime la table de travail
- DROP TABLE MaTable
- GO
-- Création de la table
IF OBJECT_ID('MaTable') IS NULL
CREATE TABLE MaTable (Champ varchar(10))
GO
-- Remplissage
INSERT INTO MaTable (Champ) VALUES ('A')
INSERT INTO MaTable (Champ) VALUES ('B')
INSERT INTO MaTable (Champ) VALUES ('C')
INSERT INTO MaTable (Champ) VALUES ('D')
INSERT INTO MaTable (Champ) VALUES ('E')
INSERT INTO MaTable (Champ) VALUES ('F')
INSERT INTO MaTable (Champ) VALUES ('G')
INSERT INTO MaTable (Champ) VALUES ('H')
-- 1ère méthode avec SQL Server 7, 2000 et 2005
DECLARE @machaine varchar(200)
SET @machaine = ''
SELECT @machaine = @machaine + Champ + ',' FROM MaTable
SELECT @machaine
-- 2ème méthode avec SQL Server 2005 uniquement
SELECT champ + ',' as 'text()'
FROM MaTable
FOR XML PATH('')
-- Supprime la table de travail
DROP TABLE MaTable
GO
Conclusion
Il existe une 3ème méthode consistant à créer une fonction d'agrégat définie par l'utilisateur avec .net via Visual Studio (avec votre langage préféré).
A préciser vous ne pourrez pas utiliser ces 2 méthode avec GROUP BY. Seule la solution de développer une fonction en .net le pourrait, elle ne fonctionnera que sur SQL Server 2005.
Bon testS...
Sources du même auteur
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
création d'une automatique d'une base de données SQLServer [ par MokhTelnet ]
bonjourj'ai besoin de savoir comment on peut créer une base de données SQLServer lors de l'installation d'une application.mon client ne veux se charge
Commande DOS pour SQLServer 7 [ par MokhTelnet ]
y a t'il une commande dos pour SQLSERVER 7 ?(comme la commande sqlplus pour oracle)
création automatique d'une base de données SQLServer [ par MokhTelnet ]
bonjour j'ai besoin de savoir comment on peut créer une base de données SQLServer lors de l'installation d'une application. mon client ne veux se char
Problème SQLSERVER/php [ par LeJulius ]
Je travaille actuellement sous SQL SERVER 2000 en lien avec du PHP 4.2.0 Mon problème est le suivant :Mes tables sql contiennent des caractères accent
Requete utilisant un IF (?) [ par Gamer_man ]
Bonjour :)J'ai un petit probleme avec une requete...J'explique un peu :Sur mon site, il est possible de poster des commentaires en etant membre ou en
aides requetes [ par thebadskull ]
bonjour, j'ai des requetes SQL a faire dans le cadre d'un exercices, mais sur la 100aine que j'ai eu, je n'arrive pas du tout a en faire quelques unev
convertir string en money [ par chris81 ]
comment puis je faire pour convertir un string pour l'inserer dans mon champ de type moneymercihttp://www.correzeweb.comhttp://www.localetv.com
convertion de date sous ms sql serveur et sp [ par jimmy69 ]
Bonjour a tous , j'ai trouve ce code sur un forum qui fonctionne parfaitement ...et qui affiche donc la date au format
Comparaison VARCHAR/TEXT [ par Athalus ]
Bonjour,J'aurais voulu savoir s'il était possible de comparer des variables de type VARCHAR et des variables de type TEXT dans une requète ?
Supprimer une date antérieure à une autre [ par billou_13 ]
Bonjour, Alors, voila je dois faire une requête SQL permettant de supprimer toutes les informations d'une table où les dates seraient ant&#
|
Derniers Blogs
[SHAREPOINT 2010] CRéER ET PACKAGER UNE APPLICATION SILVERLIGHT POUR SHAREPOINT 2010[SHAREPOINT 2010] CRéER ET PACKAGER UNE APPLICATION SILVERLIGHT POUR SHAREPOINT 2010 par neodante
L'intégration native de Silverlight dans SharePoint 2010 représente une avancée majeure dans la conception des applications sur la plateforme SharePoint. Et pour cause, Silverlight repousse les limites du Web de SharePoint en offrant une expérience plus r...
Cliquez pour lire la suite de l'article par neodante [MIX10] KEYNOTE PREMIèRE JOURNéE - WINDOWS PHONE 7 ET SILVERLIGHT 4[MIX10] KEYNOTE PREMIèRE JOURNéE - WINDOWS PHONE 7 ET SILVERLIGHT 4 par cyril
Comme l'année dernière, me revoici à Las Vegas pour Mix10. Ce matin a eu lieu le premier keynote animé par Scott Guthrie. Le keynote s'est déroulé en 2 parties : Silverlight 4.0 et Windows Phone 7 Silverlight 4.0 Le taux de pénétration de Silverli...
Cliquez pour lire la suite de l'article par cyril [MIX10] RELEASE CANDIDATE DE SILVERLIGHT 4 ET RIA SERVICES[MIX10] RELEASE CANDIDATE DE SILVERLIGHT 4 ET RIA SERVICES par Audrey
C'est enfin officiel, grâce au MIX 2010, les Release Candidate de Silverlight 4 et de RIA Services sont sorties ! Pour les télécharger, voici les liens : Silverlight 4 RC : http://silverlight.net/getstarted/silverlight-4/ RIA Services RC : http://www.micr...
Cliquez pour lire la suite de l'article par Audrey PREMIERES IMPRESSIONS SUR WINDOWS PHONE 7PREMIERES IMPRESSIONS SUR WINDOWS PHONE 7 par odewit
Il est toujours passionnant de decouvrir une nouvelle plate-forme. C'est bien entendu le cas pour Windows Phone 7. Mais au-dela de la passion technique, j'ai le sentiment qu'il s'agit d'un coup de maitre en termes d'ergonomie (tres fluide et epuree) e...
Cliquez pour lire la suite de l'article par odewit [WINDOWSPHONE7] LECTEUR DE FLUX RSS[WINDOWSPHONE7] LECTEUR DE FLUX RSS par Vko
Parce que j'aime pas tester à moitié, je me suis amusé à développer un petit lecteur de flux RSS avec un look qui vous rappellera surement quelque chose :) La RC de Visual Studio est plutôt molle mais fonctionne correctement. L'émulateur est pas...
Cliquez pour lire la suite de l'article par Vko
Forum
ALFRESCALFRESC par DARCIA33
Cliquez pour lire la suite par DARCIA33 MCDMCD par debinfo
Cliquez pour lire la suite par debinfo
Logiciels
Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor
|