Oprettet lør. d. 02. maj 2009 kl. 22:26:12

gil-galad
gil-galad (16.897 point. Point ude: 0)

Finde mest forekommende ord i række

Hej

Jeg har en række i min mysql database der indeholder en række lande. Det jeg vil lave er en top 3 liste over de lande der forekommer flest gange.

Jeg ved ikke helt hvordan jeg skal gribe dette an, om man evt kan lave det i sql forespørgelsen eller skal igang med php?

Skrevet lør. d. 02. maj 2009 kl. 23:13:23| #1

arne_v
arne_v (1.005.623 point)
Hvis vi nu antager at det er en kolonne med lande og ikke en række, så:

SELECT land,COUNT(*) AS n FROM dintabel ORDER BY COUNT(*) DESC LIMIT 3

Skrevet lør. d. 02. maj 2009 kl. 23:31:53| #2

gil-galad
gil-galad (16.897 point)
Tak for svaret.

Jeg prøver at skrive det ud således:

$query_lande_top = mysql_query("SELECT land,COUNT(*) AS n FROM data ORDER BY COUNT(*) DESC LIMIT 3 ");
while($row = mysql_fetch_array($query_lande_top)){
  echo $row['land'];
}

men får:
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in:.....


Hvad gør jeg galt? (kolonnen hedder 'land' og tabellen 'data')

Skrevet lør. d. 02. maj 2009 kl. 23:48:14| #3

arne_v
arne_v (1.005.623 point)
$query_lande_top = mysql_query("SELECT land,COUNT(*) AS n FROM data ORDER BY COUNT(*) DESC LIMIT 3 ") or die(mysql_error());

vil fortælle dig hvad problemet er.

Skrevet lør. d. 02. maj 2009 kl. 23:48:45| #4

arne_v
arne_v (1.005.623 point)
Jeg har glemt GROUP BY ....

SELECT land,COUNT(*) AS n FROM dintabel GROUP BY land ORDER BY COUNT(*) DESC LIMIT 3

Skrevet søn. d. 03. maj 2009 kl. 22:44:36| #5

gil-galad
gil-galad (16.897 point)
Dette virker perfekt:
$query_lande_top = mysql_query("SELECT land,COUNT(*) AS n FROM data GROUP BY land ORDER BY COUNT(*) DESC LIMIT 3") or die(mysql_error());
while($row = mysql_fetch_array($query_lande_top)){
  echo $row['land']."<br>";
}



lige et sidste spørgsmål:
Er der en måde hvorpå jeg kan se hvor mange gange hvert land så er forekommende i kolonnen?

Fx:

1: Danmark (200)
2: Polen (170)
3: Congo (12)


eller lign?

Skrevet søn. d. 03. maj 2009 kl. 22:50:50| #6

arne_v
arne_v (1.005.623 point)
echo $row['land']." " . $row['n']."<br>";

Skrevet søn. d. 03. maj 2009 kl. 22:51:12| #7

arne_v
arne_v (1.005.623 point)
Vi valgte n som alias for COUNT(*)

Skrevet søn. d. 03. maj 2009 kl. 23:15:17| #8

gil-galad
gil-galad (16.897 point)
Tak skal du have!

Smider du et svar?

Skrevet søn. d. 03. maj 2009 kl. 23:26:12| #9

arne_v
arne_v (1.005.623 point)
kommer her

Skrevet man. d. 04. maj 2009 kl. 18:32:56| #10


Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Ville ikke tildele at upload det til database eller komme...

Oprettet den 10. februar 2012 kl. 21.23
tobrukDk giver 15 point for svar | Giv et svar »

HTTP Post XML og modtag svar

Oprettet den 10. februar 2012 kl. 17.55
mrkaynex giver 200 point for svar | Giv et svar »

Inspion Economy søger en dygtig programmør, som kan...

Oprettet den 10. februar 2012 kl. 16.09
Kathja giver 15 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger