Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Действие до 23:59 или после 00:01
Форумы портала PHP.SU » PHP » Напишите за меня, пожалуйста » Действие до 23:59 или после 00:01

Страниц (1): [1]
 

1. webog - 10 Февраля, 2016 - 21:15:22 - перейти к сообщению
Всем добра!

Дело такое... Есть суточный лимит на сообщения. Допустим 50.
Остальные 50 не оплачиваем. Но ограничение 50 в сутки.
Вопрос: как подсчитать эти сутки?

В базе сообщение хранится так: id, user, date, text

Спасибо!
2. Мелкий - 10 Февраля, 2016 - 22:10:09 - перейти к сообщению
Варианта два, выбирайте исходя из требований:
select count(0) from tablename where date >= CURRENT_DATE and date < CURRENT_DATE + interval '1 day'
или
select count(0) from tablename where date > now() - interval '1 day'
Соответственно календарные сутки в первом случае или интенсивность написания сообщений.
3. webog - 10 Февраля, 2016 - 22:28:15 - перейти к сообщению
Мелкий, интересно, но дело в том, что дата каждый раз новая. Т.е. первое сообщение в 13:05 , а пятидисятое в 15:00 . Все, на этом платных нет. идут бесплатные.
Т.е. нет точки отсчета.
Я думал точку отсчета времени в куки писать, но так же не совсем удобно.
4. Мелкий - 10 Февраля, 2016 - 22:52:17 - перейти к сообщению
Как написанное мной противоречит написанному вами?
Если запрос вернул больше 50 - значит не тарифицируете новое сообщение.
5. webog - 19 Февраля, 2016 - 12:24:27 - перейти к сообщению
Мелкий пишет:
where date > now()


Какой формат поля date нужен?

Сейчас int(11) и хранится в UNIX.

TIMESTAMP достаточно будет?
6. Мелкий - 19 Февраля, 2016 - 12:52:00 - перейти к сообщению
date, datetime или timestamp
7. webog - 19 Февраля, 2016 - 13:00:56 - перейти к сообщению
Мелкий пишет:
timestamp


Поставил это. Время слетело, ну и ладно.
Как в базу правильно записать?

Так уже не катит time()

Вот так? -
8. Мелкий - 19 Февраля, 2016 - 13:13:58 - перейти к сообщению
Стандартный Y-m-d H:i:s
Имевшиеся данные можно было сконвертировать через FROM_UNIXTIME
9. webog - 19 Февраля, 2016 - 13:22:21 - перейти к сообщению
Мелкий пишет:
Имевшиеся данные можно было сконвертировать через FROM_UNIXTIME


Это как?

Остальное сделал, все ок.

Единственное:

select count(0) from tablename where date >= CURRENT_DATE and date < CURRENT_DATE + interval '1 day'
или
select count(0) from tablename where date > now() - interval '1 day'

В чем разница? Выдают одно и тоже.
10. Мелкий - 19 Февраля, 2016 - 13:27:18 - перейти к сообщению
webog пишет:
Это как?

alter table add column timestamp
update timestamp_field = FROM_UNIXTIME(int_field)
alter table drop column int_field
Переименовывание колонки по вкусу.

webog пишет:
В чем разница?

Мелкий пишет:
календарные сутки в первом случае или интенсивность написания сообщений.

создайте пару строк в 23 часа и посмотрите результат после полуночи.
11. webog - 19 Февраля, 2016 - 13:33:00 - перейти к сообщению
Первый - сколько за сутки всего.

Второй - тут походу так же ))

Мелкий пишет:
создайте пару строк в 23 часа и посмотрите результат после полуночи.


Хорошо, попробую.

По FROM_UNIXTIME спасибо! Спасибку нажал!

 

Powered by ExBB FM 1.0 RC1