mirror of
https://github.com/Mibew/design.git
synced 2025-01-22 18:10:33 +03:00
Calculate page statistics that older one day
This commit is contained in:
parent
49894f7d9e
commit
18dd2c01e4
@ -197,15 +197,23 @@ function calculate_page_statistics() {
|
|||||||
// Start transaction
|
// Start transaction
|
||||||
$db->query('START TRANSACTION');
|
$db->query('START TRANSACTION');
|
||||||
|
|
||||||
$visited_pages = $db->query(
|
// Get last record date
|
||||||
"SELECT FLOOR(p.visittime / (24*60*60)) * 24*60*60 AS date, " .
|
$result = $db->query(
|
||||||
|
"SELECT MAX(date) as start FROM {visitedpagestatistics}",
|
||||||
|
array(),
|
||||||
|
array('return_rows' => Database::RETURN_ONE_ROW)
|
||||||
|
);
|
||||||
|
|
||||||
|
$start = empty($result['start']) ? 0 : $result['start'];
|
||||||
|
$today = floor(time() / (24*60*60)) * 24*60*60;
|
||||||
|
|
||||||
|
// Calculate statistics
|
||||||
|
$db->query(
|
||||||
|
"INSERT INTO {visitedpagestatistics} (" .
|
||||||
|
"date, address, visits, chats" .
|
||||||
|
") SELECT FLOOR(p.visittime / (24*60*60)) * 24*60*60 AS date, " .
|
||||||
"p.address AS address, " .
|
"p.address AS address, " .
|
||||||
// 'visittimes' is not calculated pages count. It means that
|
|
||||||
// 'visittimes' is count of NEW visited pages, not total count.
|
|
||||||
"COUNT(DISTINCT p.pageid) AS visittimes, " .
|
"COUNT(DISTINCT p.pageid) AS visittimes, " .
|
||||||
// 'chattimes' is total count of threads related with a page
|
|
||||||
// address, not a visited page row. It means that 'chattimes' is
|
|
||||||
// TOTAL chats count from this page, not only new.
|
|
||||||
"COUNT(DISTINCT t.threadid) AS chattimes " .
|
"COUNT(DISTINCT t.threadid) AS chattimes " .
|
||||||
"FROM {visitedpage} p " .
|
"FROM {visitedpage} p " .
|
||||||
"LEFT OUTER JOIN {chatthread} t ON (" .
|
"LEFT OUTER JOIN {chatthread} t ON (" .
|
||||||
@ -213,66 +221,25 @@ function calculate_page_statistics() {
|
|||||||
"AND DATE(FROM_UNIXTIME(p.visittime)) = " .
|
"AND DATE(FROM_UNIXTIME(p.visittime)) = " .
|
||||||
"DATE(FROM_UNIXTIME(t.dtmcreated))) " .
|
"DATE(FROM_UNIXTIME(t.dtmcreated))) " .
|
||||||
"WHERE p.calculated = 0 " .
|
"WHERE p.calculated = 0 " .
|
||||||
|
"AND (p.visittime - :start) > 24*60*60 " .
|
||||||
|
"AND (:today - p.visittime) > 24*60*60 " .
|
||||||
"GROUP BY date, address " .
|
"GROUP BY date, address " .
|
||||||
"ORDER BY date",
|
"ORDER BY date",
|
||||||
array(),
|
|
||||||
array('return_rows' => Database::RETURN_ALL_ROWS)
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach($visited_pages as $visited_page) {
|
|
||||||
// Check is there statistics for current visited page in database.
|
|
||||||
$count_result = $db->query(
|
|
||||||
"SELECT COUNT(*) AS count " .
|
|
||||||
"FROM {visitedpagestatistics} " .
|
|
||||||
"WHERE date = :date AND address = :address",
|
|
||||||
array(
|
array(
|
||||||
':date' => $visited_page['date'],
|
':start' => $start,
|
||||||
':address' => $visited_page['address']
|
':today' => $today
|
||||||
),
|
|
||||||
array('return_rows' => Database::RETURN_ONE_ROW)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (! empty($count_result['count'])) {
|
|
||||||
// Stat already in database. Update it.
|
|
||||||
$db->query(
|
|
||||||
"UPDATE {visitedpagestatistics} SET " .
|
|
||||||
"visits = visits + :visits, " .
|
|
||||||
// Do not add chat because of it is total count of chats
|
|
||||||
// related with this page.
|
|
||||||
// TODO: Think about old threads removing. In current
|
|
||||||
// configuration it can cause problems with wrong
|
|
||||||
// 'by page' statistics.
|
|
||||||
"chats = :chats " .
|
|
||||||
"WHERE date = :date " .
|
|
||||||
"AND address = :address " .
|
|
||||||
"LIMIT 1",
|
|
||||||
array(
|
|
||||||
':date' => $visited_page['date'],
|
|
||||||
':address' => $visited_page['address'],
|
|
||||||
':visits' => $visited_page['visittimes'],
|
|
||||||
':chats' => $visited_page['chattimes']
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
} else {
|
|
||||||
// Create stat row in database.
|
|
||||||
$db->query(
|
|
||||||
"INSERT INTO {visitedpagestatistics} (" .
|
|
||||||
"date, address, visits, chats" .
|
|
||||||
") VALUES ( " .
|
|
||||||
":date, :address, :visits, :chats" .
|
|
||||||
")",
|
|
||||||
array(
|
|
||||||
':date' => $visited_page['date'],
|
|
||||||
':address' => $visited_page['address'],
|
|
||||||
':visits' => $visited_page['visittimes'],
|
|
||||||
':chats' => $visited_page['chattimes']
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mark all visited pages as 'calculated'
|
// Mark all visited pages as 'calculated'
|
||||||
$db->query("UPDATE {visitedpage} SET calculated = 1");
|
$db->query(
|
||||||
|
"UPDATE {visitedpage} SET calculated = 1 " .
|
||||||
|
"WHERE (:today - visittime) > 24*60*60 " .
|
||||||
|
"AND calculated = 0",
|
||||||
|
array(
|
||||||
|
':today' => $today
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
// Remove old tracks from the system
|
// Remove old tracks from the system
|
||||||
track_remove_old_tracks();
|
track_remove_old_tracks();
|
||||||
|
Loading…
Reference in New Issue
Block a user