Понимание конкретного предложения WHERE в Oracle

Я видел это как часть кода Oracle SQL

где работодатель.eab_yr || работодатель.eab_no >= 20173 и работодатель.eab_yr || работодатель.eab_no <= 20202

Может ли кто-нибудь объяснить мне, что делает эта часть кода?

Похоже, он извлекает значения из таблицы работодателей, где eab_yr находится между 3-м месяцем 2017 года и вторым месяцем 2020 года. Это правильно?

как выглядят значения в столбце eab_no? Они похожи на номера месяцев? Мне не нравится код, если они такие, как 201712, например, численно больше, чем 20186.

Martin Smith 24.12.2020 22:56

С тех пор я понял, что часть eab.no на самом деле означает кварталы года (а не месяцы года) Q1, Q2, Q3 и Q4.

cmomah 26.12.2020 08:34
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
2
53
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

|| — оператор конкатенации строк, >= — оператор больше или равно, а <= — оператор меньше или равно.

Таким образом, он соответствует всем строкам, в которых конкатенация строк столбцов eab_yr и eab_no из employer численно больше или равна 20173 и численно меньше или равна 20202.

Это все, что есть. Что это означает семантически, нельзя ответить, не зная семантики отношения (отношений (их может быть более одного, мы не можем сказать, поскольку не было задано предложение FROM)) и атрибутов. Вы их не раскрыли.

Спасибо. Вы помогли мне понять, что делает код. Кроме того, с тех пор я понял, что часть eab.no на самом деле означает кварталы года (а не месяцы года) Q1, Q2, Q3 и Q4.

cmomah 26.12.2020 03:35

Если предположить, что код объединяет год и месяц и пытается найти диапазон, код не работает так, как вы ожидаете.

Если вы поставите диапазон с сентября 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 Спасибо за ваши идеи.

cmomah 26.12.2020 03:38

Другие вопросы по теме