Нужны советы о том, как лучше всего это сделать.Я пробовал примеры союзов, объединений и псевдонимов из нескольких вопросов о переполнении стека - ни один из них, кажется, не дает мне понять, куда я хочу пойти, не по своей вине.Я думаю, что я просто пытался решить эту проблему неправильно.
У меня есть одна таблица, в которой регистрируются все действия наших пользователей.Каждый журнал содержит столбец с идентификатором, а другой - с TIMESTAMP.Нет столбца, в котором указано, какой тип события.
Что я хочу сделать, так это получить счетчики в пределах диапазона и добавить виртуальный столбец с датой активации (первый доступ) независимо от того, находится ли он вдиапазон или нет.Бизнес-обоснование для этого заключается в том, что я хотел бы иметь отчеты, которые показывают активных пользователей в диапазоне, дату их активации и количество событий в диапазоне.
Вывод HTML этого будет выглядеть следующим образом: Пользователь / Всего посещений в диапазоне / Первое посещение (в диапазоне или нет) / Самое последнее посещение (в диапазоне)
Как яМы получили это далеко, сделав это:
$result = mysql_query("
SELECT user, MIN(timestamp), MAX(timestamp), count(user)
AS tagCount FROM " . $table . "
WHERE date(timestamp) BETWEEN '" . $startdate . "' AND '" . $enddate . "'
GROUP BY user
ORDER BY " . $orderby . " " . $order) or die(mysql_error());
Затем я зациклился:
$i = 1;
while($row = mysql_fetch_array($result)){
$user_name = str_replace("www.", "", $row['user']); // removing www from usernames
if( $i % 2 != 0) // used for alternating row colors
$iclass = "row";
else
$iclass = "row-bg";
echo "<div class=\"" . $iclass . "\"><div class=\"number\">" . $i . "</div><div class=\"number\">" . $row['tagCount'] . "</div><div class=\"name\">" . "<a href=\"http://" . $row['user'] . "\" target=\"_blank\">" . $server_name . "</a>" . "</div>" . "<div class=\"first\">" . $row['MIN(timestamp)'] . "</div><div class=\"recent\">" . $row['MAX(timestamp)'] . "</div></div>";
$i++;
}
МИН (метка времени), указанная выше, захватывает первую метку времени в диапазоне - я хочузахватить первую временную метку независимо от диапазона.
Как я могу это сделать?