Jump to content

***SOLVED Counting duplicates in a MySql query


switchdoc

Recommended Posts

Hello all,

  I am hoping you can help me with what I am sure is a very simple issue.

I need to keep track of the date and number of times certain links are clicked. To do that I've written a little script that pushes in the linkID and the date it was visited to a mysql db when that page is visited.

The DB looks something like this: 

[code]
     LinkID  clickdate 
      604   2006-11-08
      111   2006-11-08
      111   2006-11-08
      111   2006-11-08
      229   2006-11-09
      662   2006-11-09
      183   2006-11-25
      229   2006-11-09
      183   2006-11-09

[/code]

You'll note that LinkID 111 got hit 3 times on the same day. LinkID 183 got hit twice.

When I output this I want to show

LinkID: 111 Hits: 3
LinkID: 183 Hits: 2
LinkID: 229 Hits: 1

etc...

I can't figure out the correct way to count this out of the query.

Doing a select all and running it through a while loop lets me pull everything out, but somewhere there in the middle I have to add up the duplicates.

Any thoughts appreciated!!

-Switch

Link to comment
Share on other sites

Oops.. you want them grouped by LinkID only right?  Ignoring the date?

[code]SELECT LinkID, sum(1) as Hits
FROM table
GROUP BY LinkID[/code]

"Select *" will not work because it selects clickdate without aggregating it (in theory anyway.. I have not tried this in mysql)
Link to comment
Share on other sites

Switchdoc, do you want seperate lines for each LinkID/clickdate combination (day-by-day stats), or just a seperate line for each LinkID (summary)?  From your first post I thought you wanted to ignore clickdate, but now I am unsure..

Nicklas, what output does it produce?  The query doesn't specify which value clickdate should take after grouping..
Link to comment
Share on other sites

Well,

I just went back and looked and I think I screwed you all up.

The scoop is I need ALL hits for each link in a date range

So if the user selects 11/3 - 11/21

Each time the link appears in that date range, I need to count it so I can say

LinkID 111 Hits 3
LinkID 237 Hits 56

Sorry for the confusion.

-Switch 
Link to comment
Share on other sites

[quote]Nicklas, what output does it produce?[/quote]

Im sorry, I forgot to add [i]clickdate[/i] in my query when I posted it,

my query looks like this
[code=php:0]SELECT *, COUNT(LinkID) AS total FROM your_table GROUP BY LinkID, clickdate[/code]


The data in my database looks like this:

[code]LinkID  clickdate
604  2006-11-08
111 2006-11-08
111 2006-11-08
111 2006-11-08
229 2006-11-09
662 2006-11-09
183 2006-11-25
229 2006-11-09
183 2006-11-09[/code]

After the query, it looks like this

[code]LinkID  clickdate  total
111 2006-11-08 3
183 2006-11-09 1
183 2006-11-25 1
229 2006-11-09 2
604 2006-11-08 1
662 2006-11-09 1[/code]

Link to comment
Share on other sites

Hey all,

Thanks for all the replies! The answer just came via an email to a buddy I'd sent out earlier. Here is what he ended up having me do so I could get the hit count and use the page name (from another table) rather than just ID:



[code]
$query = "select count(t1.linkid),t2.pagename from page_counter as t1 inner join pages as t2 on t2.linkid=t1.linkid where t1.clickdate>='$sd' and t1.clickdate<='$ed' group by t1.linkid";
$result = mysql_query($query) OR DIE ("there was an error" .mysql_error());
while ($line = mysql_fetch_array($result,MYSQL_NUM)){list($count,$name) = $line;
[/code]

Then I can echo out the page name ($name) and the hits($count) into a table using the while loop.

Thanks again for all your replies!

-Switch

Link to comment
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.