SQL– category –
-
SQL
SQL:DELETEが異常に遅い原因と対処法まとめ|大量データで固まる時のチェックポイント
大量データを扱うシステムでは、「DELETE文が異常に遅い」「1000件削除するだけで何分もかかる」という現象は珍しくありません。 実際、筆者の環境でも 1500万件のテーブル DELETE 1件 = 約1.2秒 DELETE 100件 = 約2分 DELETE 1000件 = 約20分 という、明... -
SQL
SQL:半角 全角 変換 SQLだけで行う方法(Oracle / SQL Server / PostgreSQL)
SQLで半角 全角 変換 SQL を実行したい場面は、顧客データの正規化・文字種統一・基幹システム間のデータ連携などで非常に多く発生します。カタカナ・英数字・記号などは半角/全角の表記ゆれが多く、SQLだけで統一できるとバッチ処理やETLの品質が向上し... -
SQL
SQL:VIEWの仕組みを理解する – 仮想テーブルはどう評価される?
SQLのVIEW(ビュー)は、データベースの中に“仮想テーブル”を作る仕組みです。名前は知っていても、 VIEWは物理的にデータを持つのか? SELECTすると実際にはどう評価されるのか? VIEWをネストしたらパフォーマンスはどうなる? といった点まで正しく理解... -
SQL
Oracleで文字列操作を極める:SUBSTR・INSTR・REPLACEの活用術
Oracle SQLで文字列を自在に扱えるようになると、データ抽出や整形が格段に効率化します。本記事では、文字列操作の3大関数「SUBSTR」「INSTR」「REPLACE」の使い方をわかりやすく解説します。 1️⃣ SUBSTR:文字列の一部を取り出す SUBSTRは指定した位置か... -
SQL
サブクエリを使ったUPDATE文:別テーブルの値で更新する方法
■ 概要 SQLでデータを更新する際、別のテーブルの値を参照してUPDATEしたい場面は多くあります。たとえば、マスタテーブルの最新情報でトランザクションテーブルを更新するケースなどです。 この記事では、Oracleデータベースを例に、サブクエリを使ったUP... -
SQL
SQL:実行計画(EXPLAIN PLAN)の読み方とボトルネックの見つけ方
データベースチューニングにおいて「どのSQLが遅いのか」だけでなく、「どの処理がボトルネックなのか」を正しく把握することは非常に重要です。そのための基本ツールが実行計画(EXPLAIN PLAN)です。 本記事では、Oracleを例に実行計画の見方とボトルネ... -
SQL
インデックスの仕組みを理解してSQLを劇的に高速化する方法
SQLの処理が遅いと感じたとき、多くの人が「サーバが遅いのでは?」と思いがちです。しかし、実際の原因の多くは「インデックス(索引)」の使い方にあります。この記事では、インデックスの基本構造から、実際のチューニング手法までを体系的に解説します... -
SQL
JOINの種類を解説!INNER/LEFT/RIGHT/FULLの違いとは?
SQLで複数のテーブルを結合してデータを取得したい場合、欠かせないのが「JOIN」構文です。しかし、INNER・LEFT・RIGHT・FULLと種類が多く、「どれを選べば良いかわからない…」という悩みをよく聞きます。 本記事では、各JOINの違いを図解付きでわかりやす... -
SQL
SQL:MERGE文でINSERTとUPDATEを一度に行う効率的な方法
MERGE文とは? SQLのMERGE文は、対象テーブルにデータが存在する場合はUPDATE、存在しない場合はINSERTを1回の処理でまとめて行える便利な構文です。従来は「UPDATE → 該当しなければINSERT」といった2回の処理が必要でしたが、MERGEを使うことで1回のSQL... -
SQL
SQL:結合順序を意識してクエリ最適化を行う方法
SQLでパフォーマンスを高めるうえで「結合順序(Join Order)」は非常に重要な要素です。同じ結果を返すクエリでも、テーブルの結合順序によって処理時間が大きく変わることがあります。 この記事では、結合順序を意識したSQLの最適化方法を、実例とともに...

