Plateforme Level Extreme
Abonnement
Profil corporatif
Produits & Services
Support
Légal
English
Select top 3
Message
De
20/10/2001 11:13:12
Charlie Schreiner
Myers and Stauffer Consulting
Topeka, Kansas, États-Unis
 
 
Information générale
Forum:
Visual FoxPro
Catégorie:
Codage, syntaxe et commandes
Titre:
Divers
Thread ID:
00571276
Message ID:
00571311
Vues:
23
Hi Cyril,
This article on my web site show how this can be done.
http://home.kscable.com/cschreiner/OutFoxed11.html


>Trying to use SELECT TOP. Have lots of records, like this:
>
> Group1, 01/01/2001
> Group1, 02/02/2001
> Group1, 03/03/2001
> Group1, 04/04/2001
>
> Group2, 01/01/2001
> etc
>
>I want to get the latest three records per group. Can't get the SQL right. This doesnt't do it:-
> Select top 3 thedbf.dDATE, thedbf.cGroup FROM thedbf order by 1 descend GROUP BY thedbf.cGroup
>
>Below is a little test program.
>Can you help?
>TIA
>Cyril.
>
>
>* Make sample data
>Use in select('thedbf')
>Create cursor thedbf (cGroup C(10), dDATE D)
>
>For iigroup = 1 to 9
> ciigroup = ltrim(str(iigroup))
> For ii = 1 to 9
> cii = '0'+ ltrim(str(ii))
> Insert into thedbf (cGroup, dDATE) values (ciigroup, ctod(cii+'/'+cii+'/2001'))
> Endfor
>Endfor
>*brow
>
>* Get top 3 per cGroup
>Select top 3 thedbf.dDATE, thedbf.cGroup FROM thedbf order by 1 descend GROUP BY thedbf.cGroup
Charlie
Précédent
Suivant
Répondre
Fil
Voir

Click here to load this message in the networking platform