gpt4 book ai didi

php - 每周逐页计数,然后创建新的表条目

转载 作者:行者123 更新时间:2023-11-29 11:45:47 25 4
gpt4 key购买 nike

我创建了一个页面计数器,并且想要跟踪用户单击该页面的次数。

到目前为止,我可以跟踪他们点击该页面的次数,但我现在想对其进行设置,以便一周结束后它将创建一个新条目。

我的 mysql_query 查找是基于用户名的,因为我正在跟踪多个用户。

这是我用于跟踪选定页面的用户的代码:

<?php

include"lib/settings.php";

date_default_timezone_set("America/Los_Angeles");

$track_users_clicks = $_SESSION['username'];

$todays_date = date("m/d/Y H:i:s a");

$query = "SELECT * FROM page_count WHERE `username`=".sql_val($track_users_clicks);
$result = mysql_query($query) or die("<b>A fatal MySQL error occured</b>.<br />Query: ".$query."<br />Error: (".mysql_errno().") ".mysql_error());
while ($row = mysql_fetch_assoc($result)) {
$username = $row['username'];
$counter_snippet = $row['counter_snippet'];
$date_time = $row['date_time'];
}//end while


if ($_SERVER['REMOTE_ADDR']){

$query_update = 'UPDATE page_count SET
`counter_snippet` = '.sql_val($counter_snippet + 1).',
`date_time` = '.sql_val($todays_date).'
WHERE `username` = '.sql_val($track_users_clicks);
$result = mysql_query($query_update) or die("<b>A fatal MySQL error occured</b>.<br />Query: ".$query_update."<br />Error: (".mysql_errno().") ".mysql_error());

}


?>

到目前为止,这是我每周跟踪用户的方法:

<?php

include"lib/settings.php";

date_default_timezone_set("America/Los_Angeles");

//$track_users_clicks = $_SESSION['username'];

$todays_date = date("m/d/Y");

$begin_date = date("m/d/Y");

$end_date = date( "m/d/Y", strtotime($begin_date."+7 day" ) );

$user_log = "trevor.hanes" .$end_date;

$track_users_clicks = "trevor.hanes";


$query_begin = "SELECT * FROM date_time WHERE `username`=".sql_val($track_users_clicks);
$result = mysql_query($query_begin) or die("<b>A fatal MySQL error occured</b>.<br />Query: ".$query_begin."<br />Error: (".mysql_errno().") ".mysql_error());
while ($row = mysql_fetch_assoc($result)) {
$username = $row['username'];
$counter_snippet = $row['counter_snippet'];
$start_date = $row['start_date'];
//$end_date = $row['end_date'];
}

if ($todays_date >= $end_date){

$query_start = 'INSERT INTO date_time (
`username`,
`start_date`,
`end_date`,
`user_log`
) VALUES (
'.sql_val($track_users_clicks).',
'.sql_val($todays_date).',
'.sql_val($end_date).',
'.sql_val($user_log).'
)';
$result = mysql_query($query_start) or die("<b>A fatal MySQL error occured</b>.<br />Query: ".$query_start."<br />Error: (".mysql_errno().") ".mysql_error());

}
else

{
if ($_SERVER['REMOTE_ADDR']){

if ($end_date >= $todays_date){

$query_update = 'UPDATE date_time SET
`counter_snippet` = '.sql_val($counter_snippet + 1).'
WHERE `end_date` = '.sql_val($end_date);
$result = mysql_query($query_update) or die("<b>A fatal MySQL error occured</b>.<br />Query: ".$query_update."<br />Error: (".mysql_errno().") ".mysql_error());

}}}

echo $begin_date;
echo "<BR>";
echo $end_date;
echo "<BR>";
echo $user_log;
?>

所以我的问题是,一旦我更改日期晚于结束日期,它就会继续创建新的表条目。而不是为新的一周创建一个新的表条目然后更新点击率。

关于我做错了什么的任何想法。

最佳答案

首先,您需要使用准备好的语句。准备好的语句将防止恶意代码对您的数据库产生深远的影响。例如,如果您的用户权限配置不当,有人可以通过将以下文本放入 $_SESSION['username'] 中来删除您的整个表:

; DROP TABLE page_count;

这看起来像是一个关于 PDO(在 PHP 中使用准备好的语句的最常见方法)的不错的教程,地址:http://wiki.hashphp.org/PDO_Tutorial_for_MySQL_Developers

无论如何,要真正回答您的问题,请使用如下查询:

SELECT *, YEARWEEK(date_time) as week,
FROM page_count WHERE `username` = :USERNAME
GROUP BY week;

YEARWEEK 文档: http://www.techonthenet.com/mysql/functions/yearweek.php

关于php - 每周逐页计数,然后创建新的表条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34979940/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com