Сотрудники SQL ищут других в том же отделе - PullRequest
0 голосов
/ 01 мая 2018

У меня есть бизнес-правило, согласно которому сотрудники не могут покупать товары у сотрудников того же отдела. У меня есть две таблицы. один список сотрудников и их удостоверения личности:

   Emp_ID Emp_Name  Dept_ID
       1     John        1
       2      Bob        1
       3    Susie        2
       4     Jack        3
       5     Jill        3

И таблица идентификатора сотрудника и идентификатора сотрудника, у которого они приобрели:

   Emp_ID  Bought_From_Emp_ID
       1                   2
       2                   3
       4                   5
       5                   1

Мой ожидаемый результат будет иметь идентификатор (или имя) сотрудника обоих сотрудников, если один из них купил товар в том же отделе:

   Emp_ID  Bought_From_Emp_ID  Same_Dept_ID
       1                   2             1 --John and Bob are in Same Department (1)
       4                   5             3 --Jack and Jill are in Same Department (3)

Как бы я сделал это для миллионов записей? У меня такое ощущение, что в конечном итоге это очень просто, но мой разум еще не сместился в сторону решения.

Я использую Teradata, но могу использовать MSSQL, если есть какие-либо специфичные для SQL ответы

Ответы [ 2 ]

0 голосов
/ 01 мая 2018

Попробуйте этот запрос

SELECT purch.emp_id             AS EmpID, 
       purch.bought_from_emp_id AS BoughtFrom, 
       T1.dept_id               AS department 
FROM   purch 
       INNER JOIN emp T1 
               ON T1.emp_id = purch.emp_id 
       INNER JOIN emp T2 
               ON T2.emp_id = purch.bought_from_emp_id 
WHERE  t1.dept_id = t2.dept_id 

выход

+-------+------------+------------+
| EmpID | BoughtFrom | department |
+-------+------------+------------+
|     1 |          2 |          1 |
|     4 |          5 |          3 |
+-------+------------+------------+

Демо: http://www.sqlfiddle.com/#!18/22746/1/0

0 голосов
/ 01 мая 2018
DECLARE @emp TABLE
(
    emp_id INT,
    emp_name VARCHAR(20),
    dept_id INT
);
INSERT INTO @emp
(
    emp_id,
    emp_name,
    dept_id
)
VALUES
--Emp_ID Emp_Name  Dept_ID    
(1, 'John ', 1),
(2, 'Bob', 1),
(3, 'Susie', 2),
(4, 'Jack', 3),
(5, 'Jill', 3);

DECLARE @purch TABLE
(
    emp_id INT,
    Bought_From_Emp_ID INT
);
INSERT INTO @purch
(
    emp_id,
    Bought_From_Emp_ID
)
VALUES
(1, 2),
(2, 3),
(4, 5),
(5, 1);


SELECT e.emp_id,
       e1.emp_id AS Bought_From_Emp_ID,
       e.dept_id AS Same_Dept_ID
FROM @purch p
    JOIN @emp e
        ON p.emp_id = e.emp_id
    JOIN @emp e1
        ON p.Bought_From_Emp_ID = e1.emp_id
           AND e.dept_id = e1.dept_id
WHERE e1.emp_id <> e.emp_id;
...