SAS Snowflake SQL UNION ALL

【SAS】【SQL】SQLにおける複数テーブルの結合 その1【UNION ALL】【Snowflake】

投稿日:

今回は複数テーブルの結合について解説します。


/* 複数テーブルの結合_1 */
data data1;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

data data2;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

proc sql;
  create table data3 AS
  select * from data1
  UNION ALL
  select * from data2;
quit;

  • UNION ALLによって抽出結果を縦に結合することができる。
  • 重複が有っても全て出力される。

/* 複数テーブルの結合_2 */
data data1;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

data data2;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

proc sql;
  create table data3 AS
  select * from data1,data2;
quit;

  • from句に複数テーブルあるときは、結合されてデカルト積になる。
  • 名前が全く同じ列は表示されない。

[メモ:デカルト積の図解を追記]


/* 複数テーブルの結合_3 */
data data1;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

data data2;
  Id1=1111; Id2=1111; Id3=1111;
    output;
  Id1=2222; Id2=2222; Id3=2222;
    output;
  Id1=3333; Id2=3333; Id3=3333;
    output;
run;

proc sql;
  create table data3 AS
  select t1.Id1,
         t1.Id2,
         t1.Id3,
         t2.Id1,
         t2.Id2,
         t2.Id3
  from data1 t1,data2 t2;
quit;

  • from句に複数テーブルあるときは、結合されてデカルト積になる。
  • 名前が全く同じ列は表示されない。

[メモ:デカルト積の図解を追記]

UNION ALLの項目差異について


-- create or replace table1-
create or replace table DB1.PUBLIC.DATA1
(
  "id1" VARCHAR(10),
  "id2" VARCHAR(10)
);

-- create or replace table2-
create or replace table DB1.PUBLIC.DATA2
(
  "id1" VARCHAR(10),
  "id2" VARCHAR(10),
  "id3" VARCHAR(10)
);



-- プロシージャ定義
CREATE OR REPLACE PROCEDURE DB1.PUBLIC.INSERT_PROC1()

RETURNS VARCHAR
LANGUAGE SQL
AS
BEGIN

INSERT INTO DB1.PUBLIC.DATA1 VALUES ('1111', '1111');
INSERT INTO DB1.PUBLIC.DATA1 VALUES ('2222', '2222');
INSERT INTO DB1.PUBLIC.DATA1 VALUES ('3333', '3333');

INSERT INTO DB1.PUBLIC.DATA2 VALUES ('1111', '1111','1111');
INSERT INTO DB1.PUBLIC.DATA2 VALUES ('2222', '2222','2222');
INSERT INTO DB1.PUBLIC.DATA2 VALUES ('3333', '3333','3333');

END;

-- プロシージャ呼び出し
CALL DB1.PUBLIC.INSERT_PROC1();


-- UNION ALL
select * from DB1.PUBLIC.DATA1
UNION ALL
select * from DB1.PUBLIC.DATA2;
  • UNION ALLによって抽出結果を縦に結合することができる。
  • 結合するテーブルの項目に差分があると、エラーとなる。

-SAS, Snowflake, SQL, UNION ALL

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

no image

【SQL】【Snowflake】LAG関数で他レコードを参照する【LAG】【OVER】

今回は、SQLのLAG関数で他レコードを参照する方法について解説します。 — create or replace table1- create or replace table DB1.PUBLIC …

【SAS】SAS日時値をyyyymmddhhmmss形式にする。【PUT】【DATETIME】【DATEPART】【TOD】

今回はdatetime関数を使って、SAS日時値を取得した後、yyyymmddhhmmss形式に加工する方法を解説していきます。 (参考PUT:【SAS】PUTはSAS日付値をフォーマットを変換して表 …

【SAS】SUMは足し算をする。その1【SQL】

今回はSQLのSUMについて解説します。 /* SUM_1 */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; Id2=222 …

【SAS】INTNX関数は指定期間の条件を満たす日付けを返す。その2

今回はINTNX関数について追加で解説します。 過去記事では INTNX関数 の使い方(引数3つ)について解説しました。⇒【SAS】INTNX関数は指定期間の条件を満たす日付けを返す。 | ビジネスイ …

【SAS】TRANSTRN関数は指定した文字を別の文字に変換する。その2 再帰的使用

今回はTRANSTRN関数の再帰的使用について解説していきます。 (参考:【SAS】TRANSTRN関数は指定した文字を別の文字に変換する。 | ビジネスイッチ (how-to-business.co …