Précédent   Forum des professionnels en informatique > Logiciels > Solutions d'entreprise > Business Intelligence > SAS > SAS Base
SAS Base Forum d'entraide sur SAS base : étape data, procédures non statistiques, procédures non graphiques, SQL
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 04/04/2008, 22h34   #1
Futur Membre du Club
 
Inscription : avril 2007
Messages : 153
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 153
Points : 17
Points : 17
Par défaut fonction pourcentage sql

bonjour j ai un petit soucis concernnt une requete de pourcentage sous sql que je voudrais aprrs la faire sous sas
en fait j ai une table nommée commande avce champs modelivraison = soi normal ouexpress et codplateforme (crteil,montreul,paris...)
je voudrais calculer le pourcentage de commande express par plateforme at ja rrive pas avce ma requete

Code :
1
2
3
4
5
SELECT codplateforme ,
	(((SELECT count(*) FROM commande WHERE modelivraison LIKE 'express') *100)/count(*))
	AS Pourcentage
	FROM commande
	GROUP BY codplateforme;
je trouve pas l erreur :s
nita2006 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/04/2008, 18h09   #2
Candidat au titre de Membre du Club
 
Inscription : mars 2008
Messages : 13
Détails du profil
Informations forums :
Inscription : mars 2008
Messages : 13
Points : 13
Points : 13
Bonjour,

La fonction COUNT utilise dans les deux cas le GROUP BY ce qui empêche d'avoir le grand total.

Je te propose deux méthodes :
  • un produit cartésien sur deux sous sélections (total par plateforme et grand total) qui tu pourras optimiser avec un left join si tu as des variables clés en plus.
  • un proc freq avec un ods

Véronique
__________________________
Véronique Bourcier
www.sasreference.fr
Blog pour se former au SAS

0.1 Créer un data set COMMANDE pour l'exemple

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
DATA commande;
   length cod_plat $8 mod_livr $7;  
   input cod_plat $ mod_livr $;
   datalines;
crteil    EXPress
crteil    EXPress
montreul  Express
paris     express
paris     express
Paris     express
montreul  Normal
paris     NORMAL
;
run;
0.2 Voir le data set d'origine;

Code :
1
2
proc print DATA=commande;
run;
0.3 Optionnel s'assurer que les codes de platforme et les modes de livraisons ont la même notation. Ici je choisi de tout mettre en majuscule. J'en profite pour ne sélectionner que les modes de livraison express. Mais je peux aussi faire le choix de l'ajouter après.

Code :
1
2
3
4
5
6
proc sql;
   CREATE TABLE com AS
   SELECT upcase(cod_plat) AS cod_plat, upcase(mod_livr) AS mod_livr
   	  FROM commande
	  WHERE upcase(mod_livr)='EXPRESS';
quit;
1. Method 1

Code :
1
2
3
4
5
6
7
8
9
proc sql;	    
   SELECT cod_plat, (cnt_expr_plat*100/cnt_expr_tot) AS  pct
      FROM 
         (SELECT cod_plat, count(*) AS cnt_expr_plat
          FROM com
          GROUP BY cod_plat),
         (SELECT DISTINCT count(*) AS cnt_expr_tot
          FROM com);
quit;
2. Method 2

2.1 Je fais ma sélection sur le mode de livraison si ce n'est pas déjà fait. J'ai utilisé ODS TRACE ON / LISTING ; ODS TRACE OFF ; pour trouver le nom donné à la sortie. Je renomme de data set de sortie METHOD2.


Code :
1
2
3
4
proc freq DATA = com; *(WHERE=(mod_livr='EXPRESS'));
   TABLE cod_plat*mod_livr;
   ods output CrossTabFreqs=method2;
quit;
2.2 Je ne garde que les variables qui m'intéresse

Code :
1
2
3
4
DATA method2 (DROP=_type_);
   SET method2 (keep=cod_plat mod_livr percent _type_ 
                     WHERE=(_type_='11'));
run;
2.3 Et cela donne :

Code :
1
2
proc print DATA=method2;
run;
v_bourcier est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/04/2008, 10h07   #3
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
bonjour,
Je crois que le code suivant répondra à ton problème.
Code :
1
2
3
4
5
6
7
8
9
10
 
 
proc sql;
SELECT codplateforme ,
	(((SELECT count(*) FROM commande b WHERE modelivraison LIKE 'express' 
 AND a.codplateforme=b.codplateforme) *100)/count(*)),count(*),(SELECT count(*) FROM commande b WHERE modelivraison LIKE 'express' AND a.codplateforme=b.codplateforme)
	AS Pourcentage
	FROM commande a
	GROUP BY codplateforme;
	quit;
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/04/2008, 11h46   #4
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
Je rajouterai qu'il me semble qu'en SQL, si l'on utilse un AGRAGAT(COUNT, SUM...), on ne pleut pas utiliser de GROUP BY ! Le HAVING est d'usage pour traiter les agragats !
pierre24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/04/2008, 11h51   #5
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
C'est faut.
L'agragation en sql c'est un group by.
http://access.developpez.com/sql/#L1.2.1
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/04/2008, 11h57   #6
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
Bonjour,
La having permet d'utiliser les fonctions (sum, count..) pour faire des filtres.
On ne peut pas utiliser un having sans un group by!!!!!
Exemple :
Code :
1
2
3
4
5
6
7
8
/*Sélection des magasins qui ont des ventes > à 100 */
/*le where ne nous permettra pas de faire cette opéartion*/
proc sql;
SELECT  magasin, sum(vente)
FROM toto
GROUP BY magasin
HAVING sum(vente)> 100;
quit;
Cordialement
bahraoui 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 23h38.


 
 
 
 
Partenaires

Hébergement Web