Avatar billede terrak Nybegynder
29. oktober 2004 - 18:11 Der er 3 kommentarer og
1 løsning

select count X where..

Jeg har et lille script som skal tælle besøgende. De besøgende bliver identificeret på deres IP adresse. Der registreres ikke en post hver gang en person besøger siden, kun hvis det er første gang - ellers er det et tal der bliver plusset med 1, ved hvert besøg.

Jeg vil så lave nogle små beregninger, så som total antal besøg, unikke besøgende og den "svære" del - besøgende som har besøgt siden mere end 1 gang.

Jeg kunne uden problemer fikse det ved at lave to seperate queries, men jeg ville helst have det i én, da jeg generelt gerne vil blive bedre til MySQL.

Dette skal koden gøre(query virker ikke):
select sum(`visits`) as `totalvisits`, count(`ip`) as `uniquevisits`, count(`ip` where `visits` > 1) as `frequentguest` from `taeller`


Sådan se det ud når man deler den i to(virker):
select sum(`visits`) as `totalvisits`, count(`ip`) as `uniquevisitors` from `taeller`
og
select count(`ip`) as `frequentguest` from `taeller` where `visits` > 1

Jeg bruger MySQL version 4.1.7

Tabelstruktur og data:
CREATE TABLE `taeller` (
  `refid` varchar(32) collate utf8_danish_ci NOT NULL default '',
  `ip` varchar(15) collate utf8_danish_ci NOT NULL default '',
  `visits` int(5) NOT NULL default '0'
)

INSERT INTO `taeller` VALUES ('cfcd208495d565ef66e7dff9f98764da', '80.197.67.74', 41);
INSERT INTO `taeller` VALUES ('cfcd208495d565ef66e7dff9f98764da', '80.197.67.75', 100);
INSERT INTO `taeller` VALUES ('cfcd208495d565ef66e7dff9f98764da', '80.197.67.70', 1);


Hvordan løser jeg det?
Avatar billede arne_v Ekspert
29. oktober 2004 - 19:07 #1
Prøv:

(select sum(`visits`) from `taeller`)
UNION
(select count(`ip`) from `taeller`)
UNION
(select count(`ip`) from `taeller` where `visits` > 1)

og læs en kolonne med 3 tal
Avatar billede arne_v Ekspert
29. oktober 2004 - 19:09 #2
eller:

select sum(`visits`) as `totalvisits`, count(`ip`) as `uniquevisitors`, sum(if(`visits`>1,1,0)) as `frequentguest`
from `taeller`
Avatar billede terrak Nybegynder
29. oktober 2004 - 20:13 #3
Det ser ud til at virke uden problemer (brugte sidstnævnte) - smid et svar :)
Avatar billede arne_v Ekspert
29. oktober 2004 - 20:14 #4
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester