Précédent   Forum des professionnels en informatique > Logiciels > Solutions d'entreprise > Business Intelligence > SAS > Débutez
Débutez Forum concentrant les premières questions que l'on se pose en tant que débutant
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/05/2011, 16h34   #1
Invité de passage
 
Femme
Chargée d'études
Inscription : mars 2008
Messages : 42
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : France, Hérault (Languedoc Roussillon)

Informations professionnelles :
Activité : Chargée d'études

Informations forums :
Inscription : mars 2008
Messages : 42
Points : 4
Points : 4
Par défaut Compter des observations à l'aide du SQL de SAS

Bonjour,

Je travaille actuellement sous SAS. Je rencontre une difficulté. Voici un exemple de table que je possède

N° id date code postal

1 01/01/2010 34000
1 31/12/2010 57000

J'ai ici un client qui début 2010 habitait dans le 34 puis fin 2010 il habitait dans le 57.

Bien sûr dans mon fichier j'ai plus de 2 clients

J'aimerais sur la période 2010 connaitre ceux qui ont changé de code postal.

Je débute en SQL alors je suis un peu perdue, je ne vois pas trop comment faire..est-ce au moins possible comment cela?

sinon peut-être sous access

merci de votre aide.


PS : j'espère avoir été claire dansmes explications.


Lahli57
lahli57 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/05/2011, 16h40   #2
Membre Expert
 
Homme
Biostatisticien
Inscription : juin 2009
Messages : 1 143
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Irlande

Informations professionnelles :
Activité : Biostatisticien
Secteur : Industrie Pharmaceutique

Informations forums :
Inscription : juin 2009
Messages : 1 143
Points : 1 760
Points : 1 760
Bonjour,

oui je pense avoir saisi

L'idée est très simple: compter le nombre de code postal par identifiant et année, et retenir ceux qui ont deux valeurs différentes.

Code :
1
2
3
4
5
6
7
proc sql;
CREATE TABLE demenagement(WHERE=(nbcodepost>1)) AS
SELECT *, count (DISTINCT codepostal) AS nbcodepost
FROM tablentree
GROUP BY id, year(date)
;
quit;
Dans l'idée ça devrait ressembler à cà mais il peut y avoir des coquilles (je n'ai pas testé le code)

Manoutz
Manoutz est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 04/05/2011, 16h54   #3
Invité de passage
 
Femme
Chargée d'études
Inscription : mars 2008
Messages : 42
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : France, Hérault (Languedoc Roussillon)

Informations professionnelles :
Activité : Chargée d'études

Informations forums :
Inscription : mars 2008
Messages : 42
Points : 4
Points : 4
Re-Bonjour,

Merci pour la rapidité de la réponse

Alors, vu que je débute, je n'ai pas vraiment tout compris (dsl...)
et plus spécifiquement la clause where, et count distinct.


Code :
WHERE=(nbcodepost>1)) AS SELECT *, count (DISTINCT codepostal) AS nbcodepost
dsl pour la question qui peut paraître bête, mais les débuts sont durs durs
lahli57 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/05/2011, 17h08   #4
Membre Expert
 
Homme
Biostatisticien
Inscription : juin 2009
Messages : 1 143
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Irlande

Informations professionnelles :
Activité : Biostatisticien
Secteur : Industrie Pharmaceutique

Informations forums :
Inscription : juin 2009
Messages : 1 143
Points : 1 760
Points : 1 760
Aucun soucis (et d'ailleurs c'est bien que tu cherches à comprendre).

la requète:

va chercher les infos dans tableentree

et affiche toutes les données en entrée (le * dans le select)

Je demande de compter les différents codes postaux
Code :
 count (DISTINCT codepostal)
dans une variable que j'appelle nbcodepost.

Je demande de faire le comptage par ID et année

Code :
GROUP BY id, year(date)
et stocke tout ca dans une nouvelle table
Code :
CREATE TABLE demenagement
en ne retenant que les nbcodepost qui sont >1 (ce qui veux dire: pour l'id numéro tant , à l'année tant, il y a au au moins deux codes postaux): .
Manoutz est déconnecté   Envoyer un message privé Réponse avec citation 20
Vieux 04/05/2011, 17h17   #5
Invité de passage
 
Femme
Chargée d'études
Inscription : mars 2008
Messages : 42
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : France, Hérault (Languedoc Roussillon)

Informations professionnelles :
Activité : Chargée d'études

Informations forums :
Inscription : mars 2008
Messages : 42
Points : 4
Points : 4
Merci pour les explications. C'est beaucoup plus simple expliqué ainsi ^^
Merci encore.

Je vais tester cela et continuer mes autres requêtes
lahli57 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/05/2011, 17h34   #6
Invité de passage
 
Femme
Chargée d'études
Inscription : mars 2008
Messages : 42
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : France, Hérault (Languedoc Roussillon)

Informations professionnelles :
Activité : Chargée d'études

Informations forums :
Inscription : mars 2008
Messages : 42
Points : 4
Points : 4
C'est encore moi dsl

J'ai une autre question.

Par exemple pour un id donné, j'ai le 31 janvier 2010 un CP= 34000, en fev,..., jusque admettons, 31 juillet,
ensuite le 31 aout jusqu'au 31 dec un autre CP.

Ce que jai grâce à ta requête c'est ça :

1 31 JAN 34000
1 28 FEV 34000
1 31 MAR 34000
1 .........
1
1 31 DEC 57000




J'aimerais maintenant, juste savoir que cet id a changé de cp, pas tout le détail..
alors là je ne sais pas si je suis claire lool car j'ai du mal à l'expliquer...

mais en fait, je ne sais pas quelle tête pourais avoir la table a créer....

Je vais me creuser un peu car j'ai moi mêm du mal à y voir clair ...
lahli57 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/05/2011, 17h40   #7
Membre Expert
 
Homme
Biostatisticien
Inscription : juin 2009
Messages : 1 143
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Irlande

Informations professionnelles :
Activité : Biostatisticien
Secteur : Industrie Pharmaceutique

Informations forums :
Inscription : juin 2009
Messages : 1 143
Points : 1 760
Points : 1 760
Plus la peine du coup, dans ta table sortie, de sélectionner toutes les colonnes de ta table entrée. Tu n'as plus besoin que ton ID.

Ce qui donne donc:

Code :
1
2
3
4
5
6
7
proc sql;
CREATE TABLE demenagement(WHERE=(nbcodepost>1)) AS
SELECT DISTINCT ID, count (DISTINCT codepostal) AS nbcodepost
FROM tablentree
GROUP BY id, year(date)
;
quit;
Manoutz est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/05/2011, 17h47   #8
Invité de passage
 
Femme
Chargée d'études
Inscription : mars 2008
Messages : 42
Détails du profil
Informations personnelles :
Sexe : Femme
Localisation : France, Hérault (Languedoc Roussillon)

Informations professionnelles :
Activité : Chargée d'études

Informations forums :
Inscription : mars 2008
Messages : 42
Points : 4
Points : 4
ah ben oui, select * sélectionne tous les champs...

et bien écoute je te remercie pour ton aide,

tout fonctionne bien, je vais tester tout ça .

merci encore

bonne soirée .

Lahli57
lahli57 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/05/2011, 14h44   #9
Membre Expert
 
Inscription : mars 2005
Messages : 1 010
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 010
Points : 1 258
Points : 1 258
Envoyer un message via Yahoo à bahraoui
Citation:
Envoyé par Manoutz Voir le message
Plus la peine du coup, dans ta table sortie, de sélectionner toutes les colonnes de ta table entrée. Tu n'as plus besoin que ton ID.

Ce qui donne donc:

Code :
1
2
3
4
5
6
7
proc sql;
CREATE TABLE demenagement(WHERE=(nbcodepost>1)) AS
SELECT DISTINCT ID, count (DISTINCT codepostal) AS nbcodepost
FROM tablentree
GROUP BY id, year(date)
;
quit;
Code :
1
2
3
4
5
6
7
8
proc sql;
CREATE TABLE demenagement AS
SELECT DISTINCT ID, count (DISTINCT codepostal) AS nbcodepost
FROM tablentree
GROUP BY id, year(date)
HAVING nbcodepost>1
;
quit;
__________________
Consultez les FAQs et les anciens postes avant de poser vos questions. Merci
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h47.


 
 
 
 
Partenaires

Hébergement Web