@mofoletta

[22007] ERROR: invalid value «{dt.» for «YYYY» Подробности: Value must be an integer?

with
    input_vars as (
        select
            to_date(left('{dt.ToString("YYYY-MM-dd")}',10),'YYYY-MM-dd')::timestamp without time zone as m_date,
            (case when '{h}' = '8' then 8 else 10 end)  as morning_hours
    ),
    parsed_vars as (
        select
            (m_date + morning_hours * interval '1 hour') as date_start,
            (m_date + 1 * interval '1 day' + morning_hours * interval '1 hour') as date_end
        from input_vars
    )

select
(array['Понедельник','Вторник','Среда','Четверг','Пятница','Суббота','Воскресенье']) [date_part('dow',date_start)]
  || ', ' as dt,
  to_char(date_start,'DD.MM.YYYY,')  as date,


to_char(date_start, 'dd.mm.YYYY') as date_start,
to_char(date_end, 'dd.mm.YYYY') as date_end

from parsed_vars
  • Вопрос задан
  • 279 просмотров
Пригласить эксперта
Ответы на вопрос 1
trapwalker
@trapwalker
Программист, энтузиаст
Похоже, в ваш SQL попала строка шаблона в который забыли подставить значение:
{dt.ToString("YYYY-MM-dd")}
SQL эту строку интерпретирует как обычную строку, которую вы хотите привести к дате по формату YYYY-MM-dd. Само собой четыре символа {dt. не являются четырьмя цифрами года, которые ожидаются по шаблону. Об этом и ошибка.
Проблема не здесь, а уровнем выше, где вы готовите SQL-запрос.
Ответ написан
Комментировать
Ваш ответ на вопрос

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

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