Конкретный выбор на сервере sql

У меня есть таблица vbap: для всех отдельных POSNR, PARVW мне нужно проверить, является ли POSNR=POSNR2, если это так, я выбираю KUNNR. если POSNR<>POSNR2 и POSNR2 = ‘00000’, я выбираю KUNNR

enter image description here

Результат:

enter image description here

Я не понял, как это сделать?

3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
1
0
51
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Это кажется просто where причиной:

select t.*
from t
where POSNR2 in (POSNR, '00000')

Возможно, вы пытаетесь расставить приоритеты для строк, чтобы выбрать одну строку для каждого kunnr. Если так:

select t.*
from (select t.*,
             row_number() over (partition by parvw order by psnr2 desc) as seqnum
      from t
      where POSNR2 in (POSNR, '00000')
     ) t
where seqnum = 1;

Для того же [PARVW] мне нужно выбрать POSNR2 = POSNR иначе POSNR2 = '00000'.. первый запрос возвращает два результата для POSNR = 000025: 0000515408 и 0000502356.. Мне нужно расставить приоритеты в случае POSNR2 = POSNR

user138957 22.05.2019 16:27

Сделай это over (partition by vbeln, posnr, parvw order by posnr2 desc). (Или, если вы должны уметь работать и с отрицательными числами: over (partition by vbeln, posnr, parvw order by case when posnr2 = posnr then 1 else 2 end).)

Thorsten Kettner 22.05.2019 16:37

@ThorstenKettner точно !!

user138957 22.05.2019 16:42

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