Получить столбцы из объединенных таблиц в виде строк вместо соседних столбцов - PullRequest
1 голос
/ 26 июня 2019

У меня есть три таблицы A_PRODUCT, A_MODEL и A_AREA. Эти таблицы могут быть объединены с использованием PRODUCT_ID. Я хочу получить вывод такой, что за строкой из таблицы A_PRODUCT следуют строки из таблицы A_MODEL, за которыми следуют строки из таблицы A_AREA для продукта. Ниже приведен SQL для создания образца данных:

CREATE TABLE A_PRODUCT
(
PRODUCT_ID NVARCHAR(30),
PODUCT_NAME NVARCHAR(30),
);

INSERT INTO A_PRODUCT (PRODUCT_ID, PODUCT_NAME)
VALUES ('P-1', 'LONG-SLEEVE LOGO JERSEY');

INSERT INTO A_PRODUCT (PRODUCT_ID, PODUCT_NAME)
VALUES ('P-2', 'GLASSES');


CREATE TABLE A_MODEL
(
MODEL_ID NVARCHAR(30),
MODEL_NAME NVARCHAR(30),
PRODUCT_ID NVARCHAR(30)
);

INSERT INTO A_MODEL (MODEL_ID, MODEL_NAME, PRODUCT_ID)
VALUES ('M-1', 'OLD JERSEY', 'P-1');

INSERT INTO A_MODEL (MODEL_ID, MODEL_NAME, PRODUCT_ID)
VALUES ('M-2', 'RAY-BAN', 'P-2');

INSERT INTO A_MODEL (MODEL_ID, MODEL_NAME, PRODUCT_ID)
VALUES ('M-3', 'ARMANI', 'P-2');

CREATE TABLE A_AREA
(
AREA_ID NVARCHAR(30),
AREA_NAME NVARCHAR(30),
PRODUCT_ID NVARCHAR(30)
);

INSERT INTO A_AREA (AREA_ID, AREA_NAME, PRODUCT_ID)
VALUES ('A-1', 'SOUTH', 'P-1');

INSERT INTO A_AREA (AREA_ID, AREA_NAME, PRODUCT_ID)
VALUES ('A-2', 'NORTH', 'P-1');

INSERT INTO A_AREA (AREA_ID, AREA_NAME, PRODUCT_ID)
VALUES ('A-3', 'EAST', 'P-1');

INSERT INTO A_AREA (AREA_ID, AREA_NAME, PRODUCT_ID)
VALUES ('A-4', 'WEST', 'P-1');

INSERT INTO A_AREA (AREA_ID, AREA_NAME, PRODUCT_ID)
VALUES ('A-5', 'SOUTH-WEST', 'P-2');

Мой ожидаемый результат:

|PRODUCT|P-1|LONG-SLEEVE LOGO JERSEY|
|MODEL|M-1|OLD JERSEY|
|AREA|A-1|SOUTH|
|AREA|A-2|NORTH|
|AREA|A-3|EAST|
|AREA|A-4|WEST|
|PRODUCT|P-2|GLASSES|
|MODEL|M-2|RAY-BAN|
|MODEL|M-3|ARMANI|
|AREA|A-5|SOUTH-WEST|

Я пробовал следующий запрос, но он не дает желаемого результата:

;WITH CTE AS 
(
SELECT CONCAT('|PRODUCT|', P.PRODUCT_ID,'|',P.PODUCT_NAME,'|') AS Col1,
        CONCAT('|MODEL|', M.MODEL_ID,'|',M.MODEL_NAME,'|') AS COl2,
        CONCAT('|AREA|', A.AREA_ID,'|',A.AREA_NAME,'|') AS COl3      
    FROM A_PRODUCT P
    JOIN A_MODEL M
    ON P.PRODUCT_ID = M.PRODUCT_ID
    JOIN A_AREA A
    ON P.PRODUCT_ID = A.PRODUCT_ID
 )
 SELECT Result
 FROM CTE
 CROSS APPLY (VALUES (Col1,'Col1'),(Col2,'Col2'),(Col3,'Col3')
              )DT (Result,Names);

Ответы [ 2 ]

2 голосов
/ 26 июня 2019

Вы действительно не хотите JOIN здесь. Вам нужно использовать PRODUCT_ID для сортировки результатов UNION, и вам нужно принудительно выполнить дополнительную сортировку на основе таблицы, из которой поступает информация.

Используйте подзапрос, чтобы сгруппировать данные так, как вам нужно, с внешним SELECT, чтобы получить форматирование, необходимое для экспорта данных.

SELECT
  CONCAT('|',d.DetailCol1,'|',d.DetailCol2,'|', d.DetailCol3,'|') AS DelimitedList
FROM
  (
    SELECT
      PRODUCT_ID AS SortCol1,
      1 AS SortCol2,
      'PRODUCT' AS DetailCol1,
      PRODUCT_ID AS DetailCol2,
      PRODUCT_NAME AS DetailCol3
    FROM @A_PRODUCT
    UNION ALL
    SELECT
      PRODUCT_ID AS SortCol1,
      2 AS SortCol2,
      'MODEL' AS DetailCol1,
      MODEL_ID AS DetailCol2,
      MODEL_NAME AS DetailCol3
    FROM @A_MODEL
    UNION ALL
    SELECT
      PRODUCT_ID AS SortCol1,
      3 AS SortCol2,
      'AREA' AS DetailCol1,
      AREA_ID AS DetailCol2,
      AREA_NAME AS DetailCol3
    FROM @A_AREA
  ) AS d
ORDER BY 
  d.SortCol1,
  d.SortCol2;
+---------------------------------------+
|             DelimitedList             |
+---------------------------------------+
| |PRODUCT|P-1|LONG-SLEEVE LOGO JERSEY| |
| |MODEL|M-1|OLD JERSEY|                |
| |AREA|A-1|SOUTH|                      |
| |AREA|A-2|NORTH|                      |
| |AREA|A-3|EAST|                       |
| |AREA|A-4|WEST|                       |
| |PRODUCT|P-2|GLASSES|                 |
| |MODEL|M-2|RAY-BAN|                   |
| |MODEL|M-3|ARMANI|                    |
| |AREA|A-5|SOUTH-WEST|                 |
+---------------------------------------+
0 голосов
/ 26 июня 2019

Вы можете использовать следующий запрос, чтобы получить желаемый результат-

SELECT '| PRODUCT | '+PRODUCT_ID+' | '+PODUCT_NAME +' |' FROM A_PRODUCT
UNION ALL
SELECT '| AREA | '+AREA_ID+' | '+AREA_NAME +' |' FROM A_AREA
UNION ALL
SELECT '| MODEL | '+MODEL_ID+' | '+MODEL_NAME +' |' FROM A_MODEL

Вывод - (Вы можете удалить пробелы между значениями, если требуется)

| PRODUCT | P-1 | LONG-SLEEVE LOGO JERSEY |
| PRODUCT | P-2 | GLASSES |
| AREA | A-1 | SOUTH |
| AREA | A-2 | NORTH |
| AREA | A-3 | EAST |
| AREA | A-4 | WEST |
| AREA | A-5 | SOUTH-WEST |
| MODEL | M-1 | OLD JERSEY |
| MODEL | M-2 | RAY-BAN |
| MODEL | M-3 | ARMANI |
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...