以下の Qiita の続きです。以前からお世話になっている共助学習コミニティのモブプロを通して、SQL の直書きの必要にせまられ(?もしかしたら使わない?)、全然分かってないな(or忘れてるな)と感じ、個人用に作っています。(Qiita なのに…(・∀・))
※コピペ後、カラム名など差し替えるときは(エラーになるので)前後などに全角スペースが入らないように気をつけてください。
〇主な学習参考資料・実験材料
①『スッキリわかるSQL入門 中山 清喬/飯田 理恵子 共著, 株式会社フレアリンク 監修』②転職活動時のポートフォリオに付けた意見投稿フォームのCRUDに紐付けた MySQLWorkbench
※なお以下、本題に移りますが、本 Qiita においては
「データ」は各レコード(横の行)においてカラム(縦の列(の項目名))を指定して、一部取り出したVALUE(値)を指すものとします
① ASを用いてカラム名を指定し直して、データを取得するSELECT文
SELECT column_name1 AS new_column_name1 column_name2 (, …) AS new_column_name2 (, …)
FROM table_name1 AS new_table_name1
WHERE column_name1 = '〇〇' /*カラム名が条件を満たすレコード(行のデータのみ調べる)*/
※WHERE句の条件式の左辺は元々のカラム名
※実際のコードに埋め込む場合も可読性のために、このように分けて書いてヒアドキュメントで一気に変数に代入することはよくあるようです。
② あるカラムの値が NULL 値である(でない)レコード(=その行すべてのデータ)をすべて取得するSELECT文
SELECT *
FROM table_name1
WHERE column_name1 IS NULL
SELECT *
FROM table_name1
WHERE column_name1 IS NOT NULL
③ LIKE演算子を用いて、あるカラムにおいて特定の文字列を含むレコードをすべて取得するSELECT文
SELECT *
FROM table_name1
WHERE column_name1 LIKE '%word%'
/*wordの前後に任意の0文字以上の文字列がついているものを取得する*/
※上記の「%」のように「(含まれていることを許容する)任意の文字(列)」を表す文字を「パターン文字」と呼び、他にも「_(半角英数アンダーバー):任意の1文字」等あるようです。
※パターンマッチング(上記のようにSQL等で文字列があるパターンに合致しているか確認すること)をしたい文字列が英語等の外国語または日本語の場合は、あまり意識しないですが、何度か試したところ「1月」のように数字を使う場合、「1」が半角か全角かもSQLでは識別されるようです。
④「~%」等、パターン文字を普通の文字として扱い、LIKEを使って特定の文字列を含むレコードをすべて取得するSELECT文
SELECT *
FROM table_name1
WHERE column_name1 LIKE '%〇〇~%'
ESCAPE ~
/*「~」をエスケープ処理(※下記参照)に用いる文字列とする*/
なお、Oracle やMySQL等以下にあるようにエスケープ処理(ある特定の意味をもつ文字列を意味をもたない文字列として扱われるようにすること)の記法は以下サイトで紹介されているようにDBで微妙に異なるようです。
⑤あるカラムの値を2つ指定したときに、カラムの値がその範囲内に収まるレコードをすべて取得するSELECT文
SELECT *
FROM table_name1
WHERE column_name1 BETWEEN number1 AND number2
※上記の「number1」「number2」は「データ型が同じであれば」、必ずしも例えばIntegerのような「数値」でなくともよいようです。※例えば以下の「データの投稿日時(created_at)」や日付のように順序をつけられるような数字の文字列であれば、以下のように適用される。
冒頭②のMySQLWorkBenchで実験してみた結果
※なお、冒頭②のポートフォリオはLaravel(たしかver10)で作ったものです。
※上記の.phpファイルはmigrationsというフォルダに入っていますが、これはLaravelの各プロジェクトに紐付けるDBのテーブルの型やプライマリーキーなどを指定・設定するファイルです。(作ったら php artisan migrate 等のartisan コマンドやsailコマンドをpowershellなどターミナルで打つとテーブルが設定されます)
※timestamp:ある出来事が発生した日時・日付・時刻などを示す文字列(SQLでデータを直接入れない場合、ここでは上記のポートフォリオのフォームに投稿した日時が文字列で入ります。)
上記の部分に対応するDBのテーブルをMySQLWorkBenchで見た結果
⑥ nullableなどで、NULL 値が値として許容されている場合に列を指定して追加するINSERT文(※3項目だけ挿入する場合)
INSERT INTO table_name1
(column_nameX, column_nameY, column_nameZ)
VALUES (value1, value2, value3)