Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
Страницы: (2) [1] 2  ( Перейти к первому непрочитанному сообщению )  
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Выборка данных по определенным датам, За месяц,за год и т.д.
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Здравствуйте,дорогие форумчане!Возникла задача-в таблицы есть следующие данные
id text datetime
1 ttt 1234567890
2 rrr 1455454775
n NNN unix_time

Данных много,и дата добавления данных хранится в Unixtime.Так вот задача-нужно выбирать данные по разным критериям-за месяц,за год,за час,за минуту,за 2 минуты,за две недели и много разных(они динамические-задаются пользователем)
Казалось бы,чего сложного,но...Дело в том,что пользователи с разными часовыми поясами,и например,если пользователь из Владивостока будет выбирать данные за последний день,то он получит одни данные,а для Москвы-уже другие,так как разница во времени-часовые пояса.Пример-Если выбирают данные для Москвы то допустим 2016 3 12 00 00 00 и 2016 4 12 00 00 00(данные за день),то если без смещения для Владивостока получим 2016 3 12 7 00 00 и 2016 3 13 7 00 00)
Так вот вопрос-как,зная смещение часового пояса(оно известно,ничего определять php,mysql'ом не нужно) для Москвы выбрать данные со своим смещением,а для Владивостока со своим?
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
depp  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 290
Пользователь №: 40589
На форуме: 2 года
Карма: 19




unixtime - плохой формат хранения даты в базе. мое мнение.
в вашей задаче надо приводить все к типу datetime (FROM_UNIXTIME) и работать с CONVERT_TZ.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


depp
не поняла,если честно sad.gif
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
walerus  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Чтобы все !
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1965
Пользователь №: 26852
На форуме: 5 лет, 8 месяцев, 18 дней
Карма: 111




Эли4ка
Цитата
datetime (FROM_UNIXTIME)

mysql> SELECT FROM_UNIXTIME(1255033470);
+---------------------------+
| FROM_UNIXTIME(1255033470) |
+---------------------------+
| 2009-10-08 13:24:30      |
+---------------------------+
1 row in set (0.01 sec)

convert_tz конвертирует одно и то же время в нужную тайм зону
Цитата
mysql> SELECT CONVERT_TZ('2004-01-01 12:00:00','GMT','MET');
        -> '2004-01-01 13:00:00'
mysql> SELECT CONVERT_TZ('2004-01-01 12:00:00','+00:00','+10:00');
        -> '2004-01-01 22:00:00'


Так же можно рассчитать выбранный период для отображения информации и работать с Unix Time, все зависит от конечной цели.
PMПисьмо на e-mail пользователюICQ
    1   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Все равно не понимаю sad.gif
Сейчас у меня абсолютное время.При выборке мне нужно пользователю из Моксвы показывать с поправкой на его время,а из Владивостока на его.
Вот как это реализовать? unsure.gif
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
depp  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 290
Пользователь №: 40589
На форуме: 2 года
Карма: 19




Эли4ка
вам дали решение для той задачи, которую вы описали выше.
решать должны вы сами. дайте свое решение, как сделали вы.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Игорь_Vasinsky  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Лысый и злой
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 25980
Пользователь №: 21350
На форуме: 6 лет, 8 месяцев, 20 дней
Карма: 725

Не курю:
1 год, 2 месяца, 6 дней


depp тише, тише, это свои, к тому же каратисты.

Свернутый текст
user posted image



Эли4ка
ну про формат хранения данных надеюсь тебе понятно - крайне не удачный.

вот же тебе пример дали - как с твоим форматом работать - используя часовые пояса.

SELECT CONVERT_TZ('2004-01-01 12:00:00','+00:00','+10:00');


--------------------
Халявные ответы кончились.
Если нужен готовый код - готовьтесь заплатить.
Райкин тоже был артист

Возле дома был сарай
А когда всё хорошо
Можно просто покурить

user posted image
http://ufa102.xyz/
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
depp  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 290
Пользователь №: 40589
На форуме: 2 года
Карма: 19




Цитата (Игорь_Vasinsky @ 22.11.2016 - 14:32)
depp тише, тише, это свои, к тому же каратисты.

я с целью выяснить исходную задачу. а то не совсем понятно по каким критериям выборка.
PMПисьмо на e-mail пользователю
    1   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Игорь_Vasinsky  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Лысый и злой
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 25980
Пользователь №: 21350
На форуме: 6 лет, 8 месяцев, 20 дней
Карма: 725

Не курю:
1 год, 2 месяца, 6 дней


depp
ну как я понял - средствами бд делать запросы за определённый период, учитывая часовой пояс.


--------------------
Халявные ответы кончились.
Если нужен готовый код - готовьтесь заплатить.
Райкин тоже был артист

Возле дома был сарай
А когда всё хорошо
Можно просто покурить

user posted image
http://ufa102.xyz/
PMПисьмо на e-mail пользователю
    1   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Цитата
ну как я понял - средствами бд делать запросы за определённый период, учитывая часовой пояс.

Игорь_Vasinsky,верно

PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Цитата
Эли4ка
ну про формат хранения данных надеюсь тебе понятно - крайне не удачный.

вот же тебе пример дали - как с твоим форматом работать - используя часовые пояса.

Игорь_Vasinsky,сейчас буду пробовать

PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Вот тогда вопрос-а как искать,если не известна дата
то есть если в базе есть такое '2004-01-01 12:00:00',но оно по Гринвичу,а в Москве тогда уже было 2004-01-01 15:00:00,а во Владивостоке 2004-01-01 20:00:00
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


врубилась)
SELECT CONVERT_TZ('2004-01-01 12:00:00','+00:00','+10:00') = 2004-01-01 22:00:00;
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


SELECT *
FROM `test`
WHERE CONVERT_TZ( '2016-11-09 00:00:00', '+00:00', '+10:00' ) = '2016-11-09 10:00:00'
LIMIT 0 , 30

Боже.какая я тупая...я два дня полоскала всем мозги такой простой фигней...нет.чтобы почитать мануал...
ребят,плюсики в репутацию чуть позже-сейчас закреплю,чтобы не забыть
Спасибо всем огромное :)
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Эли4ка  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Богиня-девственница
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 3189
Пользователь №: 27007
На форуме: 5 лет, 8 месяцев, 10 дней
Карма: 32

Не пью :
23 года, 11 месяцев, 15 дней


Цитата
depp тише, тише, это свои, к тому же каратисты.

Игорь_Vasinsky,Спасибо,Игорь rolleyes.gif
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темыСтраницы: (2) [1] 2  Ответ в темуСоздание новой темыСоздание опроса