「ブログ」カテゴリーアーカイブ

ブログ投稿用のカテゴリ

Oracle:事前構成済の表領域

Oracle データベースを新規に作成すると、何も設定していなくても
いくつかの 「事前構成済の表領域」 が自動的に作られます。

これらは Oracle 本体の管理情報や、一時的な処理用領域、
一般ユーザーが使うためのデフォルト領域など、
データベース運用の土台になる重要な領域 です。

この記事では、Oracle が作成時に自動で用意してくれる主な表領域と、
それぞれがどのような役割を持っているのかを整理して解説します。


表領域とは何か?

まず前提として、表領域(tablespace) のイメージを簡単におさらいしておきます。

  • データベース内の 論理的な「入れ物」

  • 実体は 1 つ以上の データファイル(*.dbf など)

  • テーブルやインデックスなどのセグメントは、どこかの表領域に属して保存される

つまり、表領域は

「どの種類のデータを、どの物理ファイル群に格納するか」

を切り分けるための単位、と考えると分かりやすいです。


事前構成済の表領域

Oracle データベースを作成すると、デフォルトで次のような表領域が自動作成されます。

 

表領域説明
SYSTEMOracleサーバーがデータベースを管理するために使用する表領域
SYSAUXSYSTEM表領域の補助表領域
TEMPデータベースのデフォルトの一時表領域
UNDOTBS1UNDO表領域
USERS永続表領域
SYSやSYSTEMユーザー以外のユーザー用のデフォルト表領域
EXAMPLEデータベース作成時に「サンプル・スキーマの作成」を指定すると作成される表領域
 


各表領域の役割をもう少し詳しく

上の表だけだと、ニュアンスがつかみにくい部分もあるので、
代表的な表領域について、もう少し踏み込んで解説します。

SYSTEM 表領域

  • Oracle データベースの 中枢となる管理情報 が格納される領域

  • データディクショナリ(オブジェクト定義情報など)が含まれる

  • 原則として、アプリケーションのユーザーデータを入れるべきではない

SYSTEM をいっぱいにしてしまうと、
データベース全体がまともに動作しなくなる 危険があるため、
運用設計時点で「SYSTEM には触らない」というルールを決めておくことが多いです。


SYSAUX 表領域

  • SYSTEM 表領域の 補助表領域

  • さまざまなコンポーネント(Enterprise Manager など)の管理情報が格納される

  • Oracle 10g 以降で導入された、比較的新しい位置づけの表領域

SYSAUX は SYSTEM の負荷分散のために存在しているので、
こちらもアプリケーション用のオブジェクトを作成する場所ではありません。


TEMP 表領域

  • ORDER BY、GROUP BY、ソート、ハッシュ結合などの際に使われる
    一時的な作業領域

  • メモリに収まらなかったデータの「一時退避先」になる

TEMP が足りないと、次のような影響が出ます。

  • 大量データを扱う SQL の性能劣化

  • 場合によってはエラー(ORA-01652 など)で処理失敗

大量データ処理を行うシステムでは、
TEMP のサイズと使用状況を定期的に監視する運用 がほぼ必須です。


UNDOTBS1(UNDO 表領域)

  • 更新系処理の ロールバック情報(UNDO) を保存する表領域

  • トランザクションの取り消しや、一貫性のある参照(CONSISTENT READ)で利用される

UNDO が足りなくなると、

  • ロングトランザクションで古い UNDO が上書きされてしまう

  • 一貫性の保証ができなくなり、エラーが発生する

といった問題に繋がります。

特にバッチ処理など、長時間走る大量更新 があるシステムでは、
UNDO 表領域のサイズ設計が重要です。


USERS 表領域

  • 一般ユーザーがオブジェクトを作成するための デフォルト表領域

  • SYS / SYSTEM 以外のユーザーに割り当てられることが多い

小規模環境や検証用データベースでは、
「とりあえず USERS に全部作る」という運用もよくありますが、
本番環境では業務ごとに表領域を分割したり、
表とインデックスで表領域を分けるなどの設計を行う場合もあります。


EXAMPLE 表領域

  • データベース作成時に「サンプル・スキーマを作成する」を選んだ場合のみ作成される

  • サンプルスキーマ(HR, OE など)のオブジェクトが格納される

学習・検証用途には便利ですが、
本番環境では不要なことが多く、
作成しない or 不要であれば削除する といった扱いにするケースが一般的です。


実運用で意識しておきたいポイント

事前構成済の表領域は、
「最初からあるからそのまま使う」だけだと、
後から運用で困ることもあります。

実務では、特に次の点を意識しておくとトラブルを避けやすくなります。

1. SYSTEM/SYSAUX にユーザーデータを入れない

  • 管理系の表領域に業務テーブルを作らない

  • 開発時点で デフォルト表領域を USERS などに変更 しておく

2. TEMP と UNDO のサイズを定期的に確認する

  • 大量データを扱うバッチ処理の前後で使用量をチェック

  • 苦しくなってきたら、表領域の追加・拡張 を検討

3. USERS を「なんでも置き場」にしない

  • システムが大きくなる前に、業務単位で表領域を分ける設計を検討

  • バックアップ/リストア単位としても表領域分割は有効


まとめ

Oracle データベースを作成すると、
SYSTEM / SYSAUX / TEMP / UNDOTBS1 / USERS / EXAMPLE などの
事前構成済の表領域 が自動的に作成されます。

これらはそれぞれ、

  • データベース管理情報の領域

  • 各種コンポーネントの補助領域

  • ソートや一時処理用の領域

  • ロールバック情報(UNDO)用の領域

  • 一般ユーザー用のデフォルト領域

  • サンプルスキーマ用の領域

といった役割を持っており、
闇雲に使ってよい領域と、そうでない領域がはっきり分かれている のがポイントです。

開発や運用の現場では、

  • SYSTEM / SYSAUX にアプリのテーブルを作らない

  • TEMP / UNDO の使用状況を監視する

  • USERS を一時しのぎではなく、きちんと設計する

といった点を意識しておくと、
後からの障害対応やパフォーマンス劣化に悩まされにくくなります。

SQL:単語の先頭1文字目のみ大文字へ変更する方法

SQLで単語の先頭1文字目のみ小文字から大文字へ変更したい場合は、INITCAP関数を使用することで可能となります。引数に変換したい文字を指定すればOKです。単語の区切りはスペースかアルファベット以外の文字(ハイフン「-」、カンマ「,」、アンダースコア「-」など)を区切り文字として見做して変換されます。

DBMS毎の使用可否

  • 一般的な以下のDBMSではINITCAP関数は使用可能です。

サンプルテーブル

  • 「GOODS」テーブル

INITCAP関数の使用例

SQL(クエリー)

実行結果

  • 以下のように区切り文字の単語別に先頭文字が大文字に変換されているのが確認出来ます。

 

Eclipse:スネークケース ⇔ キャメルケース変換方法

Eclipseでコーディングしている際、スネークケースとキャメルケースの切り替えはショートカットキーを利用することで簡単に実施出来ます。ローカル変数などを定義する際に結構便利な機能となります。

Eclipseのバージョンによっては使用出来ない可能性もあるのでご注意下さい。

環境

  • Eclipse:ver 4.7.3

スネークケースとキャメルケースの切り替え方法

  1. 変換したい変数名やメソッド名を選択し「Ctrl + Alt + k」押下でスネークケース⇔キャメルケースの変更を実施
    ※右クリック⇒「変換」⇒「キャメル <-> アンダースコアー」を選択でも変換可能です
  2. スネークケースに変換する場合は「Ctrl + Shift + x」or「Ctrl + Alt + u」で大文字に変更すれば定数名を指定する際に便利です。
    ※右クリック⇒「変換」⇒「大文字に変更」を選択でも変換可能です

Oracle:データベースの起動段階と状態について

Oracleデータベースを起動すると内部的に以下の段階でデータベースが使用可能な状態となります。

データベースの起動段階と状態

 

段階ステータス状態
1SHUTDOWNデータベースが停止している状態
2NOMOUNTインスタンスが起動している状態
※制御ファイル、データファイル、REDOログファイルはクローズ
3MOUNTインスタンスが起動し、制御ファイルがオープンしている状態
※データファイル、REDOログファイルはクローズ
4OPENインスタンスが起動し、制御ファイル、データファイル、REDOログ・ファイルもオープンしている状態
※一般ユーザーが使用可能な状態
 

SQL:指定した日付(該当月)の月末日を取得する方法

SQLで指定した日付項目(該当年月)の月末日を取得するには「LAST_DAY」関数を使用します。うるう年でも正確な月の最終日を取得出来ます。

DBMS毎の使用可否

  • SQL Serverでは「EOMONTH」関数で最終日付を取得出来ます。
    関数\DBMSMySQLPostgreSQLSQL ServerOracle
    LAST_DAY
    EOMONTH

日付(該当月)の最終日を取得する例

サンプルテーブル「BIRTHDAY」

SQL(クエリー)

  • BIRTHDAYテーブルの項目「BIRTHDAY」の最終日を取得する例となります。

実行結果

Oracle:制約の種類

Oracleデータベースでは以下の制約を設定することが出来ます。

Oracle DB:制約の種類

制約説明
NOT NULL制約NULL値の設定を許可しない
UNIQE制約
(一意キー制約)
一意の値のみ許可します。複数レコード登録時、重複する値を許可しません。NULL値は許可します。
CHECK制約指定した条件の値のみ許可します。
PRIMARY KEY制約
(主キー制約)
一意の値のみ許可し、重複する値は許可しません。NULL値も許可しません。
FOREIGN KEY制約
(外部キー制約)
指定した親テーブルに存在する値のみ許可します。
 

制約のポイント

  • 制約はCREATE TABLE または ALTER TABLEで設定出来ます。
  • 制約設定の構文には列制約構文と表制約構文の2種類あります。
  • NOT NULL制約は列制約構文でのみ設定出来ます。

制約の設定例

  • 下記例のNOT NULL制約の設定箇所が列制約構文、UNIQUE制約の設定箇所が表制約構文となります。

 

Excel:図形(オブジェクト・オートシェイブ)内の文字列を検索する方法

Excelで図形(オブジェクト・オートシェイブ)内の文字列を検索すると通常は以下の様に検索結果にヒットせず「検索対象が見つかりません。…」と表示されます。

今回は「Relax Tools AddIn」というアドインを導入して図形内の文字列を検索可能とする手順を説明します。

アドイン「Relax Tools AddIn」のダウンロード

Excelで図形内の文字列を検索する手順

  1. 「オプション」を選択します。
  2. 「アドイン」⇒「設定」ボタンを選択します。
  3. 「参照」ボタンを選択します。
  4. ダウンロードしたファイル内にある「RelaxTools.xlam」を選択します。
  5. 以下の様に「RelaxTools AddIn」が追加されていることを確認します。
  6. 追加された「RelaxTools」タブの「検索/置換/装飾」⇒「セル・シェイブの正規表現検索」を選択します。
  7. 検索ボックスで検索を実施すると以下の様に図形内の文字列も検索結果として表示されているのが確認出来ます。

📝補足:実際に使ってみて気づいたこと

Excelで図形内の文字を検索できるのは意外と知られていませんが、実務ではかなり便利です。
特に「フローチャート」や「構成図」「業務手順書」など、図形の中にテキストを入れて管理しているファイルでは効果絶大です。

導入時のポイントとしては以下の通りです。

  • アドインの互換性確認:Excelのバージョン(32bit/64bit)に合ったRelax Tools AddInを導入する。

  • マクロのセキュリティ設定:信頼できる発行元であることを確認し、必要に応じて「信頼できる場所」に登録。

  • 大量の図形がある場合:シート全体を対象にすると処理時間がかかるため、範囲を限定して使うと快適。

  • 他の用途への応用:コメントやテキストボックス内の文字もVBAで検索できるので、似た仕組みを応用すればさらに便利。

ちょっとした工夫で作業効率がぐっと上がるので、「図形の中だけ検索できない…」というときに試してみる価値はあります。
今後もExcelアドインやVBA活用の小ネタを紹介していくので、ぜひブックマークしておいてください。

Eclipse:同じ処理内容を一つのメソッドへ抽出(統合)する方法

EclipseではJavaなどで一つのクラス内で同じ処理内容が複数存在している場合、一つのメソッドとして抽出(統合)することが出来ます。この機能は同じ処理内容ではなくても選択したソースコードは別のメソッドとして抽出することも可能となります。

サンプルコード

Javaソース:メソッド抽出前

  • 以下の様に3~7行目と9~13行目は同じ内容なのでこちらを一つのメソッドに抽出します。

メソッド抽出手順

  1. 抽出したいソースコードを範囲選択して右クリック後、「リファクタリング」⇒「メソッドの抽出」を選択します。ショートカットキー「Alt + Shift + M」でもOKです。
  2. メソッドの抽出画面でメソッド名を指定して必要に応じて各チェックボックスを選択して「OK」ボタンを選択します。

Javaソース:メソッド抽出後

  • 以下の様に同じ処理内容が一つのメソッドとして抽出(統合)されているのが確認出来ます。

     

SQL:特定の日付時点で有効な住所情報を取得する方法

顧客の有効住所などを管理しているテーブルからある特定の日付時点で有効な住所を取得する方法をメモしておきます。

特定の日付時点で有効な住所情報を取得するサンプル

サンプルテーブル

  • 「CLIENT_ADDRESS」テーブル
    以下の様に顧客ID(CLIENT_ID)毎に有効な住所を管理するテーブルです。最新の住所のEND_DATEはnullとして管理してます。

クエリー(SQL)

  • ‘2022-03-31’時点で有効な住所情報を取得する例です。

実行結果

Excelの表をWordへ貼り付ける方法

Excelで作成した表やテーブルなどをWordへ貼り付ける場合、単純にコピペでも可能ですが、計算式などの書式は数値としてそのままコピーされるので今ひとつ使い勝手が良くない表になってしまいます。

そういう場合は「形式を選択した貼り付け」でExcel形式のオブジェクトとして貼り付けすることでExcelの計算式などもコピペ出来るので便利です。

Excelの表をWordへ貼り付ける手順

  1. Excelで貼り付けたい表を選択してコピーします。
  2. Wordで「ホーム」タブ ⇒ 「貼り付け」 ⇒ 「形式を選択して貼り付け」 を選択します。
  3. 「Microsoft Excel ワークシート オブジェクト」を選択して「OK」ボタンを選択します。
  4. 以下のようにExcelの表のまま貼り付けられているのが確認できます。
  5. 貼り付けた表をダブルクリックするとExcelベースでのフィルタやグループ化なども操作する事が可能となります。