sql >> Database >  >> RDS >> Mysql

Hoe unieke bezoekers per datuminterval selecteren?

U moet uw gegevens aggregeren. Probeer deze zoekopdracht:

SELECT DATE(data_timestamp), COUNT(visitor_id)
FROM analytics_table
WHERE DATE(data_timestamp) BETWEEN '2011-05-01' AND '2011-05-31'
GROUP BY 1

Zo vult u uw maandelijkse gegevens in (WAARSCHUWING:ONGETEST! ):

<?php
$sql = "SELECT DATE(data_timestamp), COUNT(visitor_id)
FROM analytics_table
WHERE DATE(data_timestamp) BETWEEN '2011-05-01' AND '2011-05-31'
GROUP BY 1";

$rs = mysql_query($rs);
$date1 = $datex = '2011-05-01';
$date2 = '2011-05-31';

$arrayData = $tmpArray = array();

while( $r = mysql_fetch_array($rs) )
{
   $tmpArray[$r['date']] = $r['count'];
}

while( $datex <= $date2)
{
   if( isset($tmpArray[$datex]) )
   {
      $arrayData[$datex] = $tmpArray[$datex];
   }
   else
   {
      $arrayData[$datex] = 0;
   }
   list( $y, $m, $d) = explode('-', $datex);
   $datex = date('Y-m-d', mktime(0, 0, 0, $m, $d, $y));
}


?>

deze zoekopdracht gebruik:

  • DATE() om de datum uit uw gegevens te halen en
  • COUNT() om de totale gegevens vanaf die bepaalde datum te tellen.
  • en GROUP BY om uw gegevens te groeperen op basis van het veld dat u selecteert.


  1. Is merge-statement beschikbaar in MySQL

  2. Geen bewerkingen toegestaan ​​nadat verbinding is gesloten MYSQL

  3. Voer meerdere sql delete-query's uit in mysql voor php

  4. DEFAULT-waarde invoegen in een kolom wanneer een parameter NULL is