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 :: список праздников в MySQL

 PHP.SU

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


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

> Без описания
esterio
Отправлено: 12 Апреля, 2013 - 11:13:53
Post Id



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


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


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




Нужно сделать список праздников. Проблема в том, что нужно сделать так чтобы было повторение каждый год. Подскажите как сделать.
 
 Top
vanicon
Отправлено: 12 Апреля, 2013 - 11:20:59
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 808
Дата рег-ции: Янв. 2010  
Откуда: Самара


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




А в чем проблема?
Можно по подробнее, что нужно сделать...


-----
Так было, так есть и так будет
 
 Top
esterio
Отправлено: 12 Апреля, 2013 - 11:30:56
Post Id



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


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


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




Сорри сидел с телефона. Знчит так. Есть ресурс где есть платная услуга. И есть праздники в момент которых услуга становится безплатной. Так вот прежней програмист(фрилансер от котороо достался проект) сделал следующее:

PHP:
скопировать код в буфер обмена
  1. $list = Holiday::model()->findAll();
  2. foreach ($list as $item)
  3. {
  4.         if (strtotime($item->starts) <= time() && strtotime($item->ends) >= time())
  5.         {
  6.                 $free = 'yes';
  7.                 break;
  8.         }
  9. }


Поля в БД значит следующие:
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE TABLE `holidays` (
  2.   `id` int(11) NOT NULL AUTO_INCREMENT,
  3.   `title` varchar(64) DEFAULT NULL,
  4.   `starts` varchar(32) DEFAULT NULL,
  5.   `ends` varchar(32) DEFAULT NULL,
  6.   PRIMARY KEY (`id`)
  7. ) ENGINE=MyISAM


И пример нового года
Цитата:
title: New Years Day
starts: January 1, 00:01
ends: January 2, 02:00


Короч я все ето дело переделал под TIMESTAMP. Но теперь трабл в том, что дата то раз в год. А нужно каждый год.
 
 Top
vanicon
Отправлено: 12 Апреля, 2013 - 11:35:19
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 808
Дата рег-ции: Янв. 2010  
Откуда: Самара


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




Ну а почему бы не сравнивать только день и месяц, типа если 23 февраля то - праздник и т.п


-----
Так было, так есть и так будет
 
 Top
esterio
Отправлено: 12 Апреля, 2013 - 11:38:53
Post Id



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


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


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




vanicon
И заставить админа водить так дату. Думаю такое решение не подойдет. Плюс должен быть диапазон с учетем времени

(Отредактировано автором: 12 Апреля, 2013 - 11:41:20)

 
 Top
EuGen Администратор
Отправлено: 12 Апреля, 2013 - 11:44:33
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Вообще говоря, смысла то решение фрилансера не лишено. Дело в том, что в разные годы праздники выпадают на разные дни недели и иногда они переносятся - например, объединяются с выходными, а рабочие дни переносятся. Либо же даются "отгулы" за те праздники, что выпали на выходные.
Поэтому здесь лучше вести актуальные праздники каждый год, комбинируя оба решения - к примеру, создать структуру: day, month, year, is_cycled - соответственно, со смыслом день, месяц, год и "зацикленность" (булево). Интервалы при этом хранить я не предлагаю, потому что нередко бывает, что праздники "разорваны" (как в мае нередко бывает), поэтому на каждый праздник - своя запись. При этом, если выставлен флаг is_cycled, то можно считать, что праздник повторяется каждый год.
Выбрать, является ли день праздником, можно будет так:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT COUNT(1) FROM `holidays` WHERE `day`=$iDay AND `month`=$iMonth AND (`year`=$iYear OR `is_cycled`)

- если записи находятся, то день - праздник.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
esterio
Отправлено: 12 Апреля, 2013 - 12:31:16
Post Id



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


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


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




Спасибо за разеснение. Сам что-то наподобие етого думал. Но щас нету времени так много правок вносить. Если чесно я вовсе все с 0 переписал. Но есть срокы в которые нужно вписатся. Думал есть способ попроще. Все равно спасибо
 
 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