С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/48: Рейтинг темы: голосов - 48, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 08.07.2016
Сообщений: 10

Выборка данных из mysql за определенный промежуток времени

23.07.2016, 13:59. Показов 8943. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Обращусь с просьбой за подсказкой. Буду очень признателен.
Дело в том что я пишу программу по заполнению журнала с 8 утра текущего дня до 8 утра следующего дня.
Т.е. в запросах сначала выбираю SELECT * FROM ojd WHERE data='$today' ORDER BY data DESC LIMIT 1 где $today = date('Y-m-d'); если данных за сегодня нет то INSERT ON DUPLICATE KEY UPDATE. До 00:00 следующего дня все выводится отлично, но после 00:00 вывода нет так как выборка за текущую дату. Необходима выборка за промежуток с 8 утра текущего дня до 8 утра следующего дня. Мысли изменить формат даты или прибавить часы /* $new_date = date('Y.m.d', strtotime("+25 hours", strtotime($date))); */. Посоветуйте если кто сталкивался с данной проблемой. Заранее спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.07.2016, 13:59
Ответы с готовыми решениями:

Выборка файлов за определенный промежуток времени
нужно выбрать файлы в папке за последние 10 минут. не мойму как сделать. единственное что могу это за конкретно время ls -l...

Реализовать просмотр данных за определенный промежуток времени
Всем привет! Дорогие спецы подскажите пожалуйста. На форме помещены компоненты: DateTimePicker1,2 и DBGrig (соединен с БД MySQL Browser)...

Отчет за определенный промежуток времени
Добрый вечер! Подскажите, пожалуйста, как сделать что бы при выборе периода в DataTimeTicker (например, с 01.01.2013 по 01.02.2013)...

4
Фрилансер
Эксперт PythonЭксперт JSЭксперт PHP
 Аватар для Azdeman
1871 / 1362 / 604
Регистрация: 12.01.2011
Сообщений: 5,470
23.07.2016, 20:15
есть же интервал , если не ошибаюсь , то как то так.
SQL
1
SELECT * FROM `ojd` WHERE `data`> NOW() - INTERVAL 25 HOURS
0
0 / 0 / 0
Регистрация: 08.07.2016
Сообщений: 10
24.07.2016, 13:34  [ТС]
Добрый день. Azdeman спасибо большое, что ответил. Пробую, задать интервал - выводит ошибку. Ночью изменил отсчет даты, но не прибавил часы, а отнял 9 часов, чтобы в 8:00 следующего дня наступало 00:00. Тем самым у меня день начинается с 8:00 и заканчивается на следующий день в 8:00. После чего выборка if ($row ==false). Кому интересно, может пригодиться я скину скрипт.

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// забирает текущее время в массив 
$timestamp = time();
/* echo $timestamp; */
/* echo '<p>'; */
$date_time_array = getdate($timestamp);
 
// используйте mktime для обновления UNIX времени
$timestamp = mktime(
    $date_time_array['hours'],
    $date_time_array['minutes'],
    $date_time_array['seconds'],
    $date_time_array['mon'],
    $date_time_array['mday'],
    $date_time_array['year']
    );
/* echo $timestamp; */
 
$timestamp = time();
/* echo $timestamp; */
/* echo '<p>'; */
$date_time_array = getdate($timestamp);
 
$hours = $date_time_array['hours'];
$minutes = $date_time_array['minutes'];
$seconds = $date_time_array['seconds'];
$month = $date_time_array['mon'];
$day = $date_time_array['mday'];
$year = $date_time_array['year'];
 
// используйте mktime для обновления UNIX времени
$timestamp = mktime($hours,$minutes,$seconds,$month,$day,$year);
/* echo $timestamp; */
 
// забирает текущее время в массив
$timestamp = time();
/* echo strftime('%Hh%M %A %d %b',$timestamp); */
/* echo '<p>'; */
$date_time_array = getdate($timestamp);
 
$hours = $date_time_array['hours'];
$minutes = $date_time_array['minutes'];
$seconds = $date_time_array['seconds'];
$month = $date_time_array['mon'];
$day = $date_time_array['mday'];
$year = $date_time_array['year'];
 
// используйте mktime для обновления UNIX времени
// убавление на 9 часов от $hours
$timestamp = mktime($hours - 9,$minutes,$seconds,$month,$day,$year);
 
echo strftime(' %Y-%m-%d %Hh%M ',$timestamp); /* Вывод времени за минусом 9 часов (часовой пояс на час вперед)*/
 
$today = strftime('%Y-%m-%d',$timestamp); /* Задаем переменную в нужном нам формате*/
После чего делаем запрос выборки где дата в БД равна $today
 
$sql_select = "SELECT * FROM ojd WHERE data='$today' ORDER BY data DESC LIMIT 1";
$result = mysql_query($sql_select);
$row = mysql_fetch_array($result);
0
Фрилансер
Эксперт PythonЭксперт JSЭксперт PHP
 Аватар для Azdeman
1871 / 1362 / 604
Регистрация: 12.01.2011
Сообщений: 5,470
25.07.2016, 00:19
Цитата Сообщение от djonn Посмотреть сообщение
Пробую, задать интервал - выводит ошибку
А какая ошибка?
0
0 / 0 / 0
Регистрация: 08.07.2016
Сообщений: 10
25.07.2016, 13:14  [ТС]
Выдает Warning: mysql_fetch_array() expects parameter 1 to be resource.
А запрос
$sql_select = "SELECT * FROM `ojd` WHERE `data`> NOW() - INTERVAL 25 HOURS";
$result = mysql_query($sql_select);
$row = mysql_fetch_array($result);
Не могу понять в чем ошибка.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.07.2016, 13:14
Помогаю со студенческими работами здесь

Запрос за определенный промежуток времени
Вопрос такой: Delphi7 ругается на 5 строчку, т.е. когда хочу задать промежуток по дате. Не могу Query1 Active: true сделать! Еще...

Действие через определенный промежуток времени
Как сделать таймер по истечению действия которго выполнялось какое-то событие,при том между началом отщета и событием человек мог выполнять...

Выполнение скрипта в определенный промежуток времени
Доброго времени суток. Ребят возник такой вопрос, можно ли запускать скрипт в определенное время? допустим четверг 18:00 чтобы запустился...

Формирование отчета за определенный промежуток времени
Добрый день! Делаю отчет за определенный промежуток времени. Выдает ошибку &quot;Unterminated string&quot; в 4 строке. Пожалуйста,...

Количество записей в БД за определенный промежуток времени
Мне нужно подсчитать количество записей с ДАТА1 по ДАТА2. Не подскажете, как реализовать? var p1,p2:String; begin ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru