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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Действие до 23:59 или после 00:01

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
webog
Отправлено: 10 Февраля, 2016 - 21:15:22
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Всем добра!

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

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

Спасибо!


-----
Hello!
 
 Top
Мелкий Супермодератор
Отправлено: 10 Февраля, 2016 - 22:10:09
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Варианта два, выбирайте исходя из требований:
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'
Соответственно календарные сутки в первом случае или интенсивность написания сообщений.


-----
PostgreSQL DBA
 
 Top
webog
Отправлено: 10 Февраля, 2016 - 22:28:15
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Мелкий, интересно, но дело в том, что дата каждый раз новая. Т.е. первое сообщение в 13:05 , а пятидисятое в 15:00 . Все, на этом платных нет. идут бесплатные.
Т.е. нет точки отсчета.
Я думал точку отсчета времени в куки писать, но так же не совсем удобно.


-----
Hello!
 
 Top
Мелкий Супермодератор
Отправлено: 10 Февраля, 2016 - 22:52:17
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Как написанное мной противоречит написанному вами?
Если запрос вернул больше 50 - значит не тарифицируете новое сообщение.


-----
PostgreSQL DBA
 
 Top
webog
Отправлено: 19 Февраля, 2016 - 12:24:27
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Мелкий пишет:
where date > now()


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

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

TIMESTAMP достаточно будет?

(Отредактировано автором: 19 Февраля, 2016 - 12:27:59)



-----
Hello!
 
 Top
Мелкий Супермодератор
Отправлено: 19 Февраля, 2016 - 12:52:00
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




date, datetime или timestamp


-----
PostgreSQL DBA
 
 Top
webog
Отправлено: 19 Февраля, 2016 - 13:00:56
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Мелкий пишет:
timestamp


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

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

Вот так? -


-----
Hello!
 
 Top
Мелкий Супермодератор
Отправлено: 19 Февраля, 2016 - 13:13:58
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Стандартный Y-m-d H:i:s
Имевшиеся данные можно было сконвертировать через FROM_UNIXTIME


-----
PostgreSQL DBA
 
 Top
webog
Отправлено: 19 Февраля, 2016 - 13:22:21
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Мелкий пишет:
Имевшиеся данные можно было сконвертировать через 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'

В чем разница? Выдают одно и тоже.


-----
Hello!
 
 Top
Мелкий Супермодератор
Отправлено: 19 Февраля, 2016 - 13:27:18
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




webog пишет:
Это как?

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

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

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

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


-----
PostgreSQL DBA
 
 Top
webog
Отправлено: 19 Февраля, 2016 - 13:33:00
Post Id


Частый гость


Покинул форум
Сообщений всего: 242
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)

[+]


Первый - сколько за сутки всего.

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

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


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

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


-----
Hello!
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB