Précédent   Forum des professionnels en informatique > Bases de données > MS SQL-Server
MS SQL-Server Forum Microsoft SQL-Server. Avant de poster -> FAQ SQL-Server, Tutoriels SQL-Server
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 05/10/2011, 11h36   #1
Candidat au titre de Membre du Club
 
Inscription : juin 2007
Messages : 126
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 126
Points : 10
Points : 10
Par défaut Requête avec concaténation

Bonjour,

Je souhaite faire une requête qui concatène deux champs et je souhaite afficher les champs LineAmount, SalesPrice, etc.

Voici ma requête:
Code :
1
2
3
4
5
6
7
8
9
10
11
12
SELECT
       ItemID,
       CustAccount,
       (ItemID + ', ' + CustAccount) AS ArtClient,
       max(CREATEDDATETIME) AS DateMaxi
FROM SALESLINE
GROUP BY
       ItemID,
       CustAccount
ORDER BY 
       CustAccount,
       ItemID
Par contre comment faire pour afficher également les colonnes LineAmount et SalesPrice en laissant la concaténation sur ItemID et CustAccount ?

Par avance merci.
mimi1255 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/10/2011, 11h58   #2
Membre habitué
 
Avatar de sihammaster
 
Webmaster
Inscription : mai 2009
Messages : 238
Détails du profil
Informations professionnelles :
Activité : Webmaster
Secteur : Finance

Informations forums :
Inscription : mai 2009
Messages : 238
Points : 148
Points : 148
Envoyer un message via MSN à sihammaster
Bonjour,
Voila un lien traite la concaténation des champs:
http://sql.1keydata.com/fr/sql-concatener.php
sihammaster est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/10/2011, 13h27   #3
SLE
Membre chevronné
 
Avatar de SLE
 
Homme Serge LESPAGNARD
Consultant informatique
Inscription : janvier 2004
Messages : 588
Détails du profil
Informations personnelles :
Nom : Homme Serge LESPAGNARD
Âge : 38
Localisation : Belgique

Informations professionnelles :
Activité : Consultant informatique

Informations forums :
Inscription : janvier 2004
Messages : 588
Points : 732
Points : 732
Quelque chose comme ceci (jointure peut-être à adapter, si ItemID n'est pas PK) :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SELECT tmp.*, s.LineAmount, s.SalesPrice
FROM
(SELECT
       ItemID,
       CustAccount,
       (ItemID + ', ' + CustAccount) AS ArtClient,
       max(CREATEDDATETIME) AS DateMaxi
FROM SALESLINE
GROUP BY
       ItemID,
       CustAccount
ORDER BY 
       CustAccount,
       ItemID) AS tmp
INNER JOIN SALESLINE AS s ON tmp.ItemID = s.ItemID
ou

Code :
1
2
...
INNER JOIN SALESLINE AS s ON tmp.ItemID = s.ItemID AND tmp.CustAccount = s.CustAccount AND tmp.DateMaxi = s.CREATEDATETIME
SLE est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 21h07.


 
 
 
 
Partenaires

Hébergement Web