Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Вывод записей с расписанием занятий
 
 автор: xopiledoci   (01.03.2017 в 17:42)   письмо автору
 
 

Здравствуйте. Дорогие мои, подскажите, помогите, пожалуйста!
Терпения нет биться больше с записью
и выводом этого чёртова расписания занятий в школе!

Нужно записать в базу данных сведения о занятиях.
Каждое занятие = одна запись в базе данных.

Таблица, куда вношу записи о занятиях:
CREATE TABLE `timetable` (
`id` int(10)
`group` int(10)
`teacher` int(10)
`cabinet` int(10)
`start` varchar(25)
`duration` tinyint(3)
);
ID, группа, учитель, кабинет, дата начала занятия, продолжительность (в мин.)

Дату начала занятия вношу по ISO 8601, а именно: Y.m.d\TH:i:sP
Например: 2017.03.01T06:00:00+00:00,
что соответствует в Москве занятию в 9 утра (UTC+3).

Главный вопрос: Как вывести все занятия,
которые буду между 27 февраля и 5 марта?

Обычный селект ничего не сделает:
SELECT ... WHERE `start` > "2017.02.26T21:00:00+00:00"


Как быть? Хочется, чтобы записи в базе данных были в формате ISO 8601,
чтобы можно было зайти в phpMyAdmin
и вручную если что исправить нужную запись,
так как если будут записи просто в Unix Epoch,
то глазами хрен поймёшь, где от какого числа.

  Ответить  
 
 автор: elenaki   (02.03.2017 в 12:24)   письмо автору
 
   для: xopiledoci   (01.03.2017 в 17:42)
 

А если BETWEEN? Вроде, он для работы с датами...
Я пользуюсь меткой времени. В базе я редко исправляю даты, а если нужно, есть скрипт перевода метки в дату и наоборот.

  Ответить  
 
 автор: xopiledoci   (02.03.2017 в 16:41)   письмо автору
 
   для: elenaki   (02.03.2017 в 12:24)
 

Да! Именно сегодня напоролся в документации по базам на BETWEEN. Всё прекрасно работает. Дата записана в обычном VARCHAR(25) и BETWEEN всё равно прекрасно справляется с выборкой между A и B датами.

  Ответить  
 
 автор: confirm   (02.03.2017 в 14:43)   письмо автору
 
   для: xopiledoci   (01.03.2017 в 17:42)
 

А где вы видели в базе своей чтобы дата в ней была в формате 2017.02.26T21:00:00+00:00?

  Ответить  
 
 автор: xopiledoci   (02.03.2017 в 16:40)   письмо автору
 
   для: confirm   (02.03.2017 в 14:43)
 

Так я записываю так...

  Ответить  
 
 автор: confirm   (03.03.2017 в 09:14)   письмо автору
 
   для: xopiledoci   (02.03.2017 в 16:40)
 

И куда записываете вы его пишите, в поле типа VARCHAR? Так ведь, а это ведь не тип дата/время, это строка, и поступая таким образом вы лишаетесь возможности работать в базе с датой/временем используя функции SQL.

Что вам мешает использовать тип DATETIME для поля start и вывод в ISO формате средствами SQL:

<?
$sql 
'SELECT CONCAT(
            DATE_FORMAT(
                `start`, "%Y-%m-%dT%H:%i:%s"), 
                IF(@@session.time_zone="SYSTEM", @@system_time_zone, @@session.time_zone
            )
       ) iso 
       FROM `timetable` WHERE `id`=1'
;

echo 
$row['iso'];


Или поле start, это тип TIMESTAMP, а вывод в ISO средствами РНР:

<?
echo date('c'$row['start']);


А поиск в базе, получение различных параметров даты/времени, сравнение даты/времени средствами SQL.

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования