Boucle de condition type if then else en sql
Résolu/Fermé
juliusescalibus
Messages postés
39
Date d'inscription
jeudi 9 janvier 2014
Statut
Membre
Dernière intervention
3 octobre 2014
-
6 févr. 2014 à 08:14
juliusescalibus Messages postés 39 Date d'inscription jeudi 9 janvier 2014 Statut Membre Dernière intervention 3 octobre 2014 - 7 févr. 2014 à 08:01
juliusescalibus Messages postés 39 Date d'inscription jeudi 9 janvier 2014 Statut Membre Dernière intervention 3 octobre 2014 - 7 févr. 2014 à 08:01
A voir également:
- Boucle de condition type if then else en sql
- Excel cellule couleur si condition texte - Guide
- Clear type - Guide
- Télé samsung s'éteint et se rallume en boucle - Forum Téléviseurs
- If exist ✓ - Forum Autoit / batch
1 réponse
juliusescalibus
Messages postés
39
Date d'inscription
jeudi 9 janvier 2014
Statut
Membre
Dernière intervention
3 octobre 2014
7 févr. 2014 à 08:01
7 févr. 2014 à 08:01
voici la requete qui fonctionne :
select d.DO_NomCli,d.nbdevis,c.nbcdes,cast(round((cast(c.nbcdes as decimal(10,2))/cast(d.nbdevis as decimal(10,2))) * 100, 2)as decimal(10,2)) as TxTrsf from ( SELECT FinDevis.DO_NomCli, COUNT (DISTINCT FinDevis.do_piece) as nbdevis FROM FinDevis WHERE findevis.DO_Date BETWEEN '01/01/2012' AND '29/01/2014'
GROUP BY FinDevis.DO_NomCli ) as D
left outer join (
select FinCommande.DO_NomCli, COUNT (FinCommande.DO_Piece) as nbcdes from FinCommande where FinCommande.do_date between '01/01/2012' and '29/01/2014'
and (FinCommande.DO_Piece IN (SELECT DO_Piece FROM ACIBOIS.dbo.F_DOCLIGNE) or FinCommande.DO_Piece IN (SELECT DL_PieceBC FROM ACIBOIS.dbo.F_DOCLIGNE)) group by FinCommande.DO_NomCli ) as C ON D.DO_NomCli=C.DO_NomCli
order by d.DO_NomCli
si ca peut servir
select d.DO_NomCli,d.nbdevis,c.nbcdes,cast(round((cast(c.nbcdes as decimal(10,2))/cast(d.nbdevis as decimal(10,2))) * 100, 2)as decimal(10,2)) as TxTrsf from ( SELECT FinDevis.DO_NomCli, COUNT (DISTINCT FinDevis.do_piece) as nbdevis FROM FinDevis WHERE findevis.DO_Date BETWEEN '01/01/2012' AND '29/01/2014'
GROUP BY FinDevis.DO_NomCli ) as D
left outer join (
select FinCommande.DO_NomCli, COUNT (FinCommande.DO_Piece) as nbcdes from FinCommande where FinCommande.do_date between '01/01/2012' and '29/01/2014'
and (FinCommande.DO_Piece IN (SELECT DO_Piece FROM ACIBOIS.dbo.F_DOCLIGNE) or FinCommande.DO_Piece IN (SELECT DL_PieceBC FROM ACIBOIS.dbo.F_DOCLIGNE)) group by FinCommande.DO_NomCli ) as C ON D.DO_NomCli=C.DO_NomCli
order by d.DO_NomCli
si ca peut servir