Задать вопрос
@uroot

Как в ClickHouse выбрать данные с БД учитывая тайм зону?

У меня есть запрос:
spoiler
SELECT 
    country_id,
    toStartOfDay(max(ts), 'Europe/Kyiv') AS as_of_date,
    hangup_rate,
    all_answered
from 
	(select
	ts,
	country_id,
	round((100 * QUEUE_HANGUP/ all_answered), 2) as hangup_rate,
	all_answered
	from 
	(
	SELECT
		toDate(ts) AS ts,
		co.country_id,
		CASE
			WHEN count() > 0 THEN sum(CASE WHEN v.client_call_status = 'QUEUE_HANGUP' THEN 1 ELSE 0 END)
			ELSE NULL
		END as QUEUE_HANGUP,
		CASE
				WHEN count() > 0 THEN sum(CASE WHEN v.client_call_status = 'ANSWERED' THEN 1 ELSE 0 END)
				ELSE NULL
		END as ANSWERED,
		CASE
				WHEN count() > 0 THEN sum(CASE WHEN v.client_call_status in ('ANSWERED','QUEUE_HANGUP') THEN 1 ELSE 0 END)
				ELSE NULL
		END as all_answered
	FROM vt_tm_cdrs v
	join crm_orders co on v.order_id = co.id 
	where
	  co.created_at >= date(now(), 'Europe/Kyiv') - interval 2 day and co.created_at <= date(now(), 'Europe/Kyiv')
      and v.ts >= date(now(), 'Europe/Kyiv') - interval 2 day and v.ts <= date(now(), 'Europe/Kyiv')
	GROUP BY
		ts, country_id
	ORDER BY
		ts, country_id ASC
	) q
) q2
GROUP BY
    country_id, toStartOfDay(ts), hangup_rate, all_answered;

Данные в БД хранятся в GTM, а мне нужно выбрать их для UTC +3.

Мой запрос работает, но если я заменю:
where
  co.created_at >= date(now(), 'Europe/Kyiv') - interval 2 day and co.created_at <= date(now(), 'Europe/Kyiv')
  and v.ts >= date(now(), 'Europe/Kyiv') - interval 2 day and v.ts <= date(now(), 'Europe/Kyiv')


На:
where
  co.created_at >= '2024-04-14 21:00:00' AND created_at <= '2024-04-15 20:59:59'
  and v.ts  >= '2024-04-14 21:00:00' AND v.ts <= '2024-04-15 20:59:59'


То выборка уже будет отличаться. Я так полагаю, что это из-за неправильной работы с тайм зоной (или интервалом). Подскажите, что я делаю не так.
  • Вопрос задан
  • 156 просмотров
Подписаться 2 Простой Комментировать
Пригласить эксперта
Ответы на вопрос 1
2ord
@2ord
А зачем вообще учитывать часовой пояс при запросе к СУБД?
Работай с UTC ровно до того момента, где реально необходимо отобразить, будь то в отчете или на стороне клиента, в JS.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы