Я видел это как часть кода Oracle SQL
где работодатель.eab_yr || работодатель.eab_no >= 20173 и работодатель.eab_yr || работодатель.eab_no <= 20202
Может ли кто-нибудь объяснить мне, что делает эта часть кода?
Похоже, он извлекает значения из таблицы работодателей, где eab_yr находится между 3-м месяцем 2017 года и вторым месяцем 2020 года. Это правильно?
С тех пор я понял, что часть eab.no на самом деле означает кварталы года (а не месяцы года) Q1, Q2, Q3 и Q4.
||
— оператор конкатенации строк, >=
— оператор больше или равно, а <=
— оператор меньше или равно.
Таким образом, он соответствует всем строкам, в которых конкатенация строк столбцов eab_yr
и eab_no
из employer
численно больше или равна 20173
и численно меньше или равна 20202
.
Это все, что есть. Что это означает семантически, нельзя ответить, не зная семантики отношения (отношений (их может быть более одного, мы не можем сказать, поскольку не было задано предложение FROM
)) и атрибутов. Вы их не раскрыли.
Спасибо. Вы помогли мне понять, что делает код. Кроме того, с тех пор я понял, что часть eab.no на самом деле означает кварталы года (а не месяцы года) Q1, Q2, Q3 и Q4.
Если предположить, что код объединяет год и месяц и пытается найти диапазон, код не работает так, как вы ожидаете.
Если вы поставите диапазон с сентября 2017 года по декабрь 2017 года, вы получите запрос:
where employer.eab_yr || employer.eab_no >= 20179
and employer.eab_yr || employer.eab_no <= 201712
Теперь 20201
больше числа 20179
и меньше числа 201712
, поэтому вы обнаружите, что возвращается январь 2020 года (и многие другие неожиданные месяцы).
Если вы хотите исправить это, используйте 2-значный месяц:
where employer.eab_yr || LPAD( employer.eab_no, 2, '0' ) BETWEEN 201709 AND 201712
или используйте литералы даты:
where TO_DATE( employer.eab_yr || '-' || employer.eab_no, 'YYYY-MM' )
BETWEEN DATE '2017-09-01' AND DATE '2017-12-01'
или, что еще лучше, исправьте свою таблицу, чтобы у вас был один столбец DATE
, а не отдельные столбцы year
и month
.
db<>рабочий пример здесь
Спасибо. С тех пор я выяснил, что часть eab.no на самом деле означает кварталы года (а не месяцы года) Q1, Q2, Q3 и Q4 Спасибо за ваши идеи.
как выглядят значения в столбце
eab_no
? Они похожи на номера месяцев? Мне не нравится код, если они такие, как 201712, например, численно больше, чем 20186.