SQL関連まとめ
好きじゃないがめんどくさいのでここにいろいろまとめる
-- sqlite3 だけ?っぽい
PRAGMA table_info('テーブル名')
ODBC(Open Database Connectivity)とは?
ODBCは、アプリケーションソフトがデータベース管理システム(DBMS)などに接続し、データの取得や書き込み、操作などを行う方法の標準を定めたもの。 ODBCを介してアプリからDBMSの基本的な機能を利用するための手順を定めています。データベースの作成や削除、SQLクエリによるデータの検索や取得、書き込みなど、データベースに対する基本的な操作を行うことができます。ODBCはDBMS毎の違いを吸収し、同一のコードでデータベースにアクセスできるようにします。
SQL クエリ関連について
Select/Insert/Update/delete構文
- select
言わずもがななので、省略
- insert構文
INSERT INTO テーブル名 (列名1, 列名2,...) VALUES (値1, 値2,...);
-- 🚨非推奨(並び変わったり、列名が変更された際に悲惨なことに)
INSERT INTO テーブル名 VALUES (値1, 値2,...);
- update構文
-- シンプルパターン
UPDATE (表名) SET (カラム名1) = (値1), (カラム名2) = (値2) WHERE (条件);
UPDATE employees SET title = 'Ms.'
WHERE emp_no IN (10006, 10007, 10009)
-- 🌟From を使うパターン
UPDATE T
SET [カラム1] = [値1],
[カラム2] = [値1], ...
FROM [テーブル1] AS T
WHERE [条件];
-- Joinしてupdateするパターン
UPDATE table_A
SET table_A.medical_checkup = 'DONE'
FROM table_A
INNER JOIN table_B
ON table_A.stuff_id = table_B.stuff_id
AND table_B.checkup_date IS NOT NULL
Where table_B.scheup_data = ~~
;
- Delete構文
Delete from テーブル名 where 条件
-- トランケート(全件削除)
trancate table <tableName>
-- テーブル削除
DROP TABLE <tablename>
Joinについて
left joinの場合select * from [左テーブル] LEFT JOIN [右テーブル] ON ...
といった形でSQL文を作成できる

Union/Union Allについて
-- union(重複したレコードは削除される)
select test_pk, test_val from test1
union
select test_pk, test_val from test2
-- union all(重複の削除は行わない)
select test_pk, test_val from test1
union all
select test_pk, test_val from test2
Merge(upsert)文について
近年追加された構文で1ステートメントでinsert/update/deleteを同時に実行できるSQL
ユースケースとしてupsert,複数のテーブルデータをマージするといった場合が考えられる
insert on conflictとの違いとしては、insert on conflictはinsertを主目的として競合時の処理を実行できるのに対し、
いるのに対しupdate/delete処理を選ぶことができる点がある。
/* 🌟例1----------------------------- */
MERGE INTO /* 操作対象テーブル */user1 a
USING ( /* 参照テーブル(🌟セレクトじゃなくてテーブル指定でもOK) */
SELECT id, name, age
FROM user2
) b
ON (a.id = b.id) /* 🌟結合条件 */
WHEN MATCHED THEN /* 🌟マッチする場合 */
UPDATE SET
a.name = b.name,
a.age = b.age
WHEN NOT MATCHED THEN /* 🌟マッチしない場合 */
INSERT (id, name, age)
VALUES (b.id, b.name, b.age)
/* 🌟例2----------------------------- */
MERGE INTO /*🌟更新先テーブル*/ user1 a
USING (
SELECT id, name, age
FROM user2
) b /* 利用元テーブル */
ON (a.id = b.id)
/* 🌟マッチする場合 */
WHEN MATCHED THEN
UPDATE SET
a.name = b.name,
a.age = b.age
-- 🌟マッチしない場合
-- BY TARGETをつけることで更新先テーブルに条件と一致するデータが存在しない場合
WHEN NOT MATCHED BY TARGET THEN
INSERT (id, name, age)
VALUES (b.id, b.name, b.age)
-- 🌟マッチしない場合
-- 🌟BY SOURCE をつけることで利用元テーブルに条件と一致するデータが存在しない場合
WHEN NOT MATCHED BY SOURCE THEN
DELETE;
CASE句(条件分岐)について
-- 🌟こう書くことでCASE文が使える。
SELECT
CASE
WHEN [条件] THEN [条件を満たしたら表示する内容]
ELSE [条件を満たしていなかったら表示する内容]
END
FROM [テーブル名];
-- updateはこう
-- 🌟 [パターン1]80点以上の場合、2倍にして更新,80以下はそのまま
UPDATE USER
SET
CASE WHEN 80 <= POINT THEN POINT =POINT*2 ELSE 0 END;
-- 🌟 [パターン2]80点以上の場合、2倍にして更新,80以下は0
UPDATE USER
SET
POINT = CASE WHEN 80 <= POINT THEN POINT*2 ELSE 0 END;
曖昧検索
LIKE句は、主に曖昧検索を行う場合に使用するクエリです。SQLでLIKE句を使用すると、対象のカラムに対して文字列検索をかけることが出来ます。
-
覚えるべきワイルドカード
「%」と「_」 %- 0文字以上の任意の文字列
_- 任意の1文字
-- 前方一致
SELECT user FROM users WHERE user LIKE "山%";
-- 後方一致
SELECT user FROM users WHERE user LIKE "%山";
-- 部分一致
SELECT user FROM users WHERE user LIKE "%山%";
-- 部分一致の否定
SELECT user FROM users WHERE user NOT LIKE "%山%";
-- 完全一致
SELECT user FROM users WHERE user LIKE "山";
正規表現
- 曖昧検索だけでなく
正規表現も使える。しかし、SQLサーバごとに使い方が違うらしい。
-- MYSQL
SELECT col_name1 [, col_name2 ...] FROM table_name
WHERE col_name REGEXP '<正規表現パターン>'
-- PostgreSQL
SELECT col_name1 [, col_name2 ...] FROM table_name
WHERE col_name ~ '<正規表現パターン>'
-- 🌟Oracel(REGEXP_REPLACE,REGEXP_SUBSTR,REGEXP_COUNT
-- とか便利関数があるので適宜調べること)
WHERE REGEXP_LIKE(<Column>, '正規表現パターン')
-- 🚨SQL Server(正規表現ないらしい、、、)
-- 一応 `[]`で一文字毎のはできるとか、、、(使えねー)
SELECT name FROM sys.databases
WHERE name LIKE 'm[n-z]%';/* 2文字目が n~z で引っかかる、、*/
With句の使い方
- こんな感じで副問い合わせができる
WITH
regional_sales AS (
SELECT region, SUM(amount) AS total_sales
FROM orders
GROUP BY region),
top_regions AS (
SELECT region
FROM regional_sales
WHERE
/* 🌟ここで上のregional_salesを使う。 */
total_sales > (SELECT SUM(total_sales)/10 FROM regional_sales)
)
SELECT region,
product,
SUM(quantity) AS product_units,
SUM(amount) AS product_sales
FROM orders
/* 🌟ここでwith句の2つ目のクエリを実行してる */
WHERE region IN (SELECT region FROM top_regions )
GROUP BY region, product;