SQL– tag –
-
Oracle
ORA-01861 : リテラルが書式文字列と一致しません の原因と対処法
Oracle Database を使っていると、日付や時刻を扱うSQLで頻繁に遭遇するのが ORA-01861 エラーです。本記事では、エラーの意味 → よくある原因 → 実践的な対処法 → 再発防止策 の順で、現場向けに分かりやすく解説します。 ORA-01861 とは? [crayon... -
SQL
SQL:前の行の値、次の行の値を取得したい時は
SQLで集計や分析をしていると、 「1つ前の行の値と比較したい」 「次の行の値を参照したい」 「前回との差分を出したい」 といったケースは非常によくあります。 このようなときに使うのが、ウィンドウ関数(分析関数)のLAG と LEAD です。 この記事では... -
SQL
SQL:切り捨て・切り上げをしたい時の TRUNC / CEIL
SQLで数値や日付を扱っていると、「小数点以下を切り捨てたい」「必ず切り上げたい」といった場面は頻繁にあります。そのような時に使う代表的な関数が TRUNC と CEIL です。 本記事では、それぞれの役割・違い・具体的な使用例を、数値と日付の両方でわか... -
SQL
SQL:構成比を出したい時に使う RATIO_TO_REPORT
SQLで売上構成比・割合・比率を求めたい場面はよくあります。そんなときに便利なのが RATIO_TO_REPORT 関数です。 この記事では、 RATIO_TO_REPORT とは何か 基本的な使い方 よくある使用例(売上構成比) 注意点・代替手段 をわかりやすく解説します。 RA... -
SQL
SQL 0除算エラー を防ぐ方法 | NULLIFで安全に割り算する書き方)
SQL で 割り算(除算) を行う際、分母が 0 になると 0除算エラー が発生します。 特に、 集計結果 売上 ÷ 件数 比率・平均値計算 などでは、実務で頻繁に遭遇するトラブルです。 この記事では、NULLIF を使って安全に0除算を回避する方法 を中心に解説し... -
SQL
SQL TO_CHAR で日時を文字列に変換する方法|フォーマット一覧付き
SQLで日付や日時を扱っていると、「YYYYMMDD形式で出したい」「時刻付きで表示したい」といった場面は頻繁にあります。 そんなときに使うのが TO_CHAR 関数 です。 この記事では、 TO_CHARの基本的な使い方 日時を文字列に変換する代表的なフォーマット よ... -
Oracle
ORA-08177 |can’t serialize access for this transaction:シリアライズエラーの原因と対処方法
Oracle でトランザクションを扱っていると、ORA-08177: can't serialize access for this transaction が突然発生することがあります。特に READ ONLY トランザクションモード(SERIALIZABLE) を使っていたり、UPDATE の競合が起きやすいバッチ処理では頻... -
SQL
SQL:複数行の値を1行にまとめたい時に使う関数(LISTAGG / STRING_AGG)
SQLを使っていると、次のように複数行の値をカンマ区切りで1つにまとめたい場面があります。 🔹例:従業員テーブル これを次のように集約したい👇 こういった「行→1セルまとめ」が必要な時に便利なのが、 👉 LISTAGG👉 STRING_AGG の2つです。データベース... -
Oracle
ORA-01422 | Expected single row/完全フェッチがリクエストより多くの行を戻しました の意味と解決方法
Oracle PL/SQLで SELECT INTO を実行した際に、想定より多くの行が返ってしまうと発生するエラーが ORA-01422 です。特に「必ず1件しか返らないはず」というロジック前提で処理を書いた場合に多く発生します。 この記事では、ORA-01422の意味、原因、発生... -
Oracle
ORA-01403 | データが1件も返らない時の典型原因と修正方法
Oracleデータベースでアプリケーション開発をしていると、時々遭遇するエラーが ORA-01403: no data found です。特にPL/SQLやSELECT INTO構文を使った処理でよく発生します。 この記事では、 ORA-01403が発生する状況 よくある原因 実務レベルでの修正方...


