Sobes.tech
Назад к вопросам
Middle+
6

table employee id bigint PK not null employee_name varvhar(100) not null employee_number int4 not null id; employee_name; employee_number 1000; Ivanov; 123 WITH ordered AS ( SELECT employee_number, LAG(employee_number) OVER (ORDER BY employee_number) as prev_number FROM employee ) SELECT prev_number + 1 as missing_number FROM ordered WHERE employee_number - prev_number > 1; 1000; name1; 1 1001; name2; 2 1002; name3; 4 1003; name4; 5 with ordered as () select * from ordered

Компании, где спрашивали
ИннотехИннотех

Ответ от нейросети

sobes.tech AI

В вашем примере вы хотите найти пропущенные номера сотрудников в последовательности employee_number.

Запрос с использованием оконной функции LAG позволяет получить предыдущий номер сотрудника для каждой строки, упорядоченной по employee_number. Затем вы выбираете те случаи, где разница между текущим и предыдущим номером больше 1, что указывает на пропуск.

Пример запроса:

WITH ordered AS (
    SELECT employee_number,
           LAG(employee_number) OVER (ORDER BY employee_number) AS prev_number
    FROM employee
)
SELECT prev_number + 1 AS missing_number
FROM ordered
WHERE employee_number - prev_number > 1;

Если у вас есть данные:

id employee_name employee_number
1000 name1 1
1001 name2 2
1002 name3 4
1003 name4 5

Этот запрос вернёт 3, так как между 2 и 4 пропущен номер 3.

Если нужно найти все пропущенные номера (например, если пропущено несколько подряд), можно расширить запрос, например, с использованием generate_series, но это зависит от СУБД.

Пример для PostgreSQL с generate_series:

SELECT missing_number
FROM (
  SELECT generate_series(
    MIN(employee_number),
    MAX(employee_number)
  ) AS missing_number
  FROM employee
) AS all_numbers
LEFT JOIN employee e ON e.employee_number = all_numbers.missing_number
WHERE e.employee_number IS NULL;

Этот запрос вернёт все отсутствующие номера в диапазоне.