Как мы можем сделать такое простое соединение в Oracle? - PullRequest
0 голосов
/ 02 июля 2018

Как мы можем сделать такое простое соединение?

У меня есть три таблицы:

Таблица 1: Студент

UserID
11111111111
22222222222
33333333333
44444444444
55555555555
66666666666
77777777777
88888888888
99999999999

Таблица 2: Класс

ClassID | StartDate
0001    | Apr 2,2018, 9:00 AM
0002    | May 2,2018, 9:00 AM

Таблица 3: Регистрация

UserID      | ClassID
11111111111 | 0001
11111111111 | 0002
22222222222 | 0001
33333333333 | 0002

А мне нужно как результат таблица ниже:

Ожидаемая таблица

UserID      | ClassID | StartDate
11111111111 | 0001    | Apr 2,2018, 9:00 AM
11111111111 | 0002    | May 2,2018, 9:00 AM
22222222222 | 0001    | Apr 2,2018, 9:00 AM
33333333333 | 0002    | May 2,2018, 9:00 AM
44444444444 | null    | null
55555555555 | null    | null
66666666666 | null    | null
77777777777 | null    | null
88888888888 | null    | null
99999999999 | null    | null

Если это возможно, сделайте это без использования UNION.

ДОПОЛНИТЕЛЬНОЕ РЕДАКТИРОВАНИЕ

Таблица 3: Регистрация (с новым столбцом 'EnrollStatus')

UserID      | ClassID | EnrollStatus
11111111111 | 0001    | Enrolled
11111111111 | 0002    | Enrolled
22222222222 | 0001    | Enrolled
33333333333 | 0002    | Enrolled

Ожидаемая таблица (с новым столбцом 'EnrollStatus')

UserID      | ClassID | StartDate           | EnrollStatus
11111111111 | 0001    | Apr 2,2018, 9:00 AM | Enrolled
11111111111 | 0002    | May 2,2018, 9:00 AM | Enrolled
22222222222 | 0001    | Apr 2,2018, 9:00 AM | Enrolled
22222222222 | null    | null                | null
33333333333 | null    | null                | null
33333333333 | 0002    | May 2,2018, 9:00 AM | Enrolled
44444444444 | null    | null                | null
44444444444 | null    | null                | null
55555555555 | null    | null                | null
55555555555 | null    | null                | null
66666666666 | null    | null                | null
66666666666 | null    | null                | null
77777777777 | null    | null                | null
77777777777 | null    | null                | null
88888888888 | null    | null                | null
88888888888 | null    | null                | null
99999999999 | null    | null                | null
99999999999 | null    | null                | null

Я считаю, что это СОЕДИНЕНИЕ необходимо, потому что у меня есть другая таблица (далее) с датами года, и мне нужно подсчитать, сколько недель пользователи не зарегистрировались в определенный период (фильтр). Кроме того, необходимо указать, какие недели пользователи не зарегистрировали (по пользователям).

Таблица 4: Даты (с: Рабочая неделя SQL в Oracle )

WITH DATES AS
(
  SELECT DATE '2017-12-25' + LEVEL -1 dt FROM DUAL CONNECT BY LEVEL <= 500
)
SELECT dt,TO_CHAR(dt,'DY') DAY,TO_CHAR(dt,'WW') WW,TO_CHAR(dt,'IW') IW,
   CASE WHEN TO_CHAR(dt,'D')<TO_CHAR(TO_DATE(TO_CHAR(dt,'YYYY')||'0101','YYYYMMDD'),'D') THEN 
     LPAD(TO_CHAR(dt,'WW')+1,2,'0')
   ELSE 
     TO_CHAR(dt,'WW')
   END MY
FROM dates

Результат запроса

DT                    | DAY | WW | IW | MY
Dec 25, 2017, 3:00 AM | MON | 52 | 52 | 52
Dec 26, 2017, 3:00 AM | TUE | 52 | 52 | 52
Dec 27, 2017, 3:00 AM | WED | 52 | 52 | 52
Dec 28, 2017, 3:00 AM | THU | 52 | 52 | 52
Dec 29, 2017, 3:00 AM | FRI | 52 | 52 | 52
Jan 1, 2018, 3:00 AM  | MON | 01 | 01 | 01
Jan 2, 2018, 3:00 AM  | TUE | 01 | 01 | 01
Jan 3, 2018, 3:00 AM  | WED | 01 | 01 | 01
Jan 4, 2018, 3:00 AM  | THU | 01 | 01 | 01
Jan 5, 2018, 3:00 AM  | FRI | 01 | 01 | 01
Jan 8, 2018, 3:00 AM  | MON | 02 | 02 | 02
Jan 9, 2018, 3:00 AM  | TUE | 02 | 02 | 02
Jan 10, 2018, 3:00 AM | WED | 02 | 02 | 02
Jan 11, 2018, 3:00 AM | THU | 02 | 02 | 02
Jan 12, 2018, 3:00 AM | FRI | 02 | 02 | 02
Jan 15, 2018, 3:00 AM | MON | 03 | 03 | 03
Jan 16, 2018, 3:00 AM | TUE | 03 | 03 | 03
Jan 17, 2018, 3:00 AM | WED | 03 | 03 | 03
Jan 18, 2018, 3:00 AM | THU | 03 | 03 | 03
Jan 19, 2018, 3:00 AM | FRI | 03 | 03 | 03

1 Ответ

0 голосов
/ 02 июля 2018

Вы можете попробовать использовать LEFT JOIN базу на Student столе

SELECT s.*,e.*,c.* 
  FROM Student s 
  LEFT JOIN Enroll e on s.UserID =e.UserID
  LEFT JOIN Class c on c.ClassID =e.ClassID 
 ORDER BY s.UserID

Sqlfiddle

EDIT

Я видел, как вы редактируете свой вопрос. Кажется, вы хотите получить декартово произведение.

Вам нужно CROSS JOIN на столе ученика и в классе, затем LEFT JOIN

SELECT s.userID,
       e.CLASSID,
       (CASE WHEN e.CLASSID IS NULL then NULL else c.STARTDATE END) STARTDATE,
       e.EnrollStatus
FROM 
Student s 
CROSS JOIN Class c 
LEFT JOIN Enroll e
    on s.UserID =e.UserID AND e.CLASSID = c.CLASSID
ORDER BY s.UserID

Результаты

|      USERID | CLASSID |           STARTDATE | ENROLLSTATUS |
|-------------|---------|---------------------|--------------|
| 11111111111 |    0001 | Apr 2,2018, 9:00 AM | EnrollStatus |
| 11111111111 |    0002 | May 2,2018, 9:00 AM | EnrollStatus |
| 22222222222 |    0001 | Apr 2,2018, 9:00 AM | EnrollStatus |
| 22222222222 |  (null) |              (null) |       (null) |
| 33333333333 |  (null) |              (null) |       (null) |
| 33333333333 |    0002 | May 2,2018, 9:00 AM | EnrollStatus |
| 44444444444 |  (null) |              (null) |       (null) |
| 44444444444 |  (null) |              (null) |       (null) |
| 55555555555 |  (null) |              (null) |       (null) |
| 55555555555 |  (null) |              (null) |       (null) |
| 66666666666 |  (null) |              (null) |       (null) |
| 66666666666 |  (null) |              (null) |       (null) |
| 77777777777 |  (null) |              (null) |       (null) |
| 77777777777 |  (null) |              (null) |       (null) |
| 88888888888 |  (null) |              (null) |       (null) |
| 88888888888 |  (null) |              (null) |       (null) |
| 99999999999 |  (null) |              (null) |       (null) |
| 99999999999 |  (null) |              (null) |       (null) |

CORSS JOIN

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...