「駑馬十駕」を信念に IT系情報を中心に調べた事をコツコツ綴っています。

SQL:MERGE文でINSERTとUPDATEを一度に行う効率的な方法

SQL:MERGE文でINSERTとUPDATEを一度に行う効率的な方法

MERGE文とは? SQLのMERGE文は、対象テーブルにデータが存在する場合はUPDATE、存在しない場合はINSERTを1回の処理でまとめて行える便利な構文です。従来は「UPDATE → 該当しなければINSERT」といった2回の処理が …

SQL:結合順序を意識してクエリ最適化を行う方法

SQL:結合順序を意識してクエリ最適化を行う方法

SQLでパフォーマンスを高めるうえで「結合順序(Join Order)」は非常に重要な要素です。同じ結果を返すクエリでも、テーブルの結合順序によって処理時間が大きく変わることがあります。 この記事では、結合順序を意識したSQLの最適化方法を …

SQL:NOT IN と NOT EXISTS の違いとパフォーマンス比較

SQL:NOT IN と NOT EXISTS の違いとパフォーマンス比較

SQLでサブクエリを使って除外条件を指定する際に利用される「NOT IN」と「NOT EXISTS」。両者の動作の違いやNULLの扱い、パフォーマンス差を実例付きで徹底解説します。 EXISTS は ANSI SQL(国際標準SQL)に含ま …

Oracle「ORA-01652: 一時セグメントを拡張できません」対処手順

Oracle「ORA-01652: 一時セグメントを拡張できません」対処手順

Oracleデータベースで大規模なソート処理や集計を行うと、次のようなエラーが発生することがあります。 ORA-01652: 一時セグメントを拡張できません このエラーは、一時表領域(TEMP)の空き容量不足によってSQL実行が中断されたこ …

Oracle「ORA-00054: リソースがビジー状態です」発生時の回避策

Oracle「ORA-00054: リソースがビジー状態です」発生時の回避策

Oracleで以下のようなエラーが出ることがあります: ORA-00054: リソースがビジー状態です。NOWAITを指定したためまたはタイムアウトが発生しました。 これは「対象のオブジェクトが別のセッションでロックされており、現在アクセス …

Oracle DBでORA-12170「接続タイムアウト」が出る場合の調査方法

Oracle DBでORA-12170「接続タイムアウト」が出る場合の調査方法

Oracleデータベースに接続しようとした際に、ORA-12170: TNS: 接続タイムアウトが発生しました というエラーが出ることがあります。このエラーは、クライアントからデータベースへの接続要求がタイムアウトした場合に発生します。ネッ …