SAS WHERE

【SAS】WHEREステートメントはIFステートメントと同様に処理条件を設定できる。(分岐)

投稿日:2021年12月3日 更新日:

今回はWHEREステートメントについて解説します。


/* where */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111, 2222, 3333);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。

/* where 条件1つ */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。(条件が1つでも使える)

/* where 条件文字列 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Char1 in ("AAAA", "BBBB", "CCCC");
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 文字列型でも設定できる。

/* where 数値型と文字列 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in ("AAAA", "BBBB", "CCCC");
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 文字列型でも設定できる。
  • 型が合っていないとエラーとなる。

/* 5555,6666,7777 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (5555, 6666, 7777);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 条件に合う値が無いと0レコードのデータセットが出力される。

/* where or */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1=1111 or Id1=2222 or Id1=3333;
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略せずに、通常通り記載することもできる。

data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1=1111 and Char1="AAAA";
run;

  • whereを用いて処理条件を設定できる。
  • if文と同様、andも使える。

/*where文が複数*/
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111, 2222, 3333);
  where Id1 in (1111, 4444);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • where文が複数あるとき、最後のwhere文が優先される。

-SAS, WHERE

執筆者:


comment

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

関連記事

【SAS】SQLプロシージャはSQLを実行できる。

今回はSQLプロシージャについて解説します。 /* sql_1 */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; Id2=2 …

【SAS】ARRAYステートメントは配列を設定することができる。

今回はarrayステートメントについて解説します。 /* array */ data data1; array hairetsu(3) Id1 Id2 Id3; hairetsu(1) = 1111; …

【SAS】”nは本来使用できない文字を使用可能にする。

今回は”nについて解説します。(参考:Solved: what the ”  ‘n ” means? – SAS Support Commu …

【SAS】SAS日時値からSAS時間値に変換する方法【TIMEPART】【DATETIME】【TIME】

今回はDATETIMEでSAS日時値を取得した後、SAS時間値に変換する方法について解説していきます。 (つまり、DATETIMEの値からTIMEの値に変換する) (DATETIME:【SAS】DAT …

【SAS】列名と列ラベルの表示を切り替える方法【LABEL】

今回はデータセットにおける列名と列ラベルの表示を切り替える方法を解説します。 /* label */ data data1; attrib Id1 length = 8 label = “Id1111 …