34.3 マイニング・モデルのエクスポートおよびインポート
データ・マイニング・モデルをフラット・ファイルにエクスポートして作業途中の操作をバックアップしたり、Oracle Database Enterprise Editionの別のインスタンスに(たとえば、開発データベースからテスト・データベースに)モデルを移動したりできます。
関連トピック
34.3.1 Oracle Data Pumpについて
Oracle Data Pumpは、2つのコマンドライン・クライアントと2つのPL/SQLパッケージで構成されています。コマンドライン・クライアント(expdp
およびimpdp
)により、データ・ポンプ・エクスポートおよびインポート・ユーティリティに対する使いやすいインタフェースが提供されます。expdp
とimpdp
を使用して、スキーマ全体またはデータベース全体のエクスポートとインポートを行うことができます。
データ・ポンプ・エクスポート・ユーティリティは、マイニング・モデルを構成する表およびメタデータを含むスキーマ・オブジェクトを、ダンプ・ファイル・セットに書き出します。データ・ポンプ・インポート・ユーティリティは、ダンプ・ファイル・セットからモデル表およびメタデータを含むスキーマ・オブジェクトを取得し、それらをターゲット・データベースにリストアします。
expdp
およびimpdp
は、個々のマイニング・モデルのエクスポートおよびインポートには使用できません。
関連項目:
Oracle Data Pumpと、expdp
およびimpdp
ユーティリティの詳細は、『Oracle Databaseユーティリティ』を参照してください
34.3.2 マイニング・モデルのエクスポートおよびインポート用オプション
マイニング・モデルのエクスポートおよびインポート用のオプションをリストします。
マイニング・モデルのエクスポートおよびインポート用オプションについて、次の表で説明します。
表34-1 Oracle Data Miningのエクスポートおよびインポート・オプション
34.3.3 EXPORT_MODELおよびIMPORT_MODELのディレクトリ・オブジェクト
ディレクトリ・オブジェクトを使用して、ダンプ・ファイル・セットの場所を識別する方法を学習します。
EXPORT_MODEL
およびIMPORT_MODEL
は、ディレクトリ・オブジェクトを使用してダンプ・ファイル・セットの場所を特定します。ディレクトリ・オブジェクトとは、ホスト・コンピュータ上の物理ディレクトリのデータベース内での論理名です。
データ・マイニング・モデルをエクスポートするには、ディレクトリ・オブジェクトおよびそれが表すファイル・システム・ディレクトリに対する書込みアクセス権を持っている必要があります。データ・マイニング・モデルをインポートするには、ディレクトリ・オブジェクトおよびファイル・システム・ディレクトリに対する読取りアクセス権を持っている必要があります。また、データベース自体にはファイル・システムのディレクトリに対するアクセス権が必要です。ディレクトリ・オブジェクトを作成するにはCREATE ANY DIRECTORY
権限が必要です。
次のSQLコマンドを実行すると、dmuser_dir
という名前のディレクトリ・オブジェクトが作成されます。このディレクトリ・オブジェクトが表すファイル・システム・ディレクトリは、すでに存在している必要があり、さらにオペレーティング・システムによって付与される共有の読取りおよび書込みアクセス権を所有している必要があります。
CREATE OR REPLACE DIRECTORY dmuser_dir AS '/dm_path/dm_mining';
次のSQLコマンドを実行すると、dmuser_dir
への読取りおよび書込みアクセス権の両方がユーザーdmuser
に付与されます。
GRANT READ,WRITE ON DIRECTORY dmuser_dir TO dmuser;
関連トピック
34.3.4 EXPORT_MODELおよびIMPORT_MODELの使用
この例は、EXPORT_MODEL
とIMPORT_MODEL
を使用した様々なエクスポートおよびインポート・シナリオを示しています。
各例では、例34-1に示すディレクトリ・オブジェクトdmdir
と、2つのスキーマdm1
およびdm2
を使用します。どちらのスキーマもデータ・マイニング権限を持っています。dm1
には2つのモデルがあります。dm2
には1つのモデルがあります。
SELECT owner, model_name, mining_function, algorithm FROM all_mining_models; OWNER MODEL_NAME MINING_FUNCTION ALGORITHM ---------- -------------------- -------------------- -------------------------- DM1 EM_SH_CLUS_SAMPLE CLUSTERING EXPECTATION_MAXIMIZATION DM1 DT_SH_CLAS_SAMPLE CLASSIFICATION DECISION_TREE DM2 SVD_SH_SAMPLE FEATURE_EXTRACTION SINGULAR_VALUE_DECOMP
例34-1 ディレクトリ・オブジェクトの作成
-- connect as system user CREATE OR REPLACE DIRECTORY dmdir AS '/scratch/dmuser/expimp'; GRANT READ,WRITE ON DIRECTORY dmdir TO dm1; GRANT READ,WRITE ON DIRECTORY dmdir TO dm2; SELECT * FROM all_directories WHERE directory_name IN 'DMDIR'; OWNER DIRECTORY_NAME DIRECTORY_PATH ---------- -------------------------- ---------------------------------------- SYS DMDIR /scratch/dmuser/expimp
例34-2 DM1からのすべてのモデルのエクスポート
-- connect as dm1 BEGIN dbms_data_mining.export_model ( filename => 'all_dm1', directory => 'dmdir'); END; /
ログ・ファイルとダンプ・ファイルは、dmdir
に関連付けられている物理ディレクトリ/scratch/dmuser/expimp
で作成されます。ログ・ファイルの名前はdm1_exp_11.log
です。ダンプ・ファイルの名前はall_dm101.dmp
です。
例34-3 元のDM1へのモデルのインポート
例34-2でエクスポートされたモデルが、まだdm1
に存在しています。インポートにより同じ名前のモデルが上書きされることはないため、モデルを同じスキーマに戻す前に、同じ名前のモデルを削除する必要があります。
BEGIN dbms_data_mining.drop_model('EM_SH_CLUS_SAMPLE'); dbms_data_mining.drop_model('DT_SH_CLAS_SAMPLE'); dbms_data_mining.import_model( filename => 'all_dm101.dmp', directory => 'DMDIR'); END; / SELECT model_name FROM user_mining_models; MODEL_NAME ------------------------------ DT_SH_CLAS_SAMPLE EM_SH_CLUS_SAMPLE
例34-4 別のスキーマへのモデルのインポート
この例では、例34-2でdm1
からエクスポートされたモデルが、dm2
にインポートされます。dm1
スキーマではexample
表領域を使用し、dm2
スキーマではsysaux
表領域を使用します。
-- CONNECT as sysdba BEGIN dbms_data_mining.import_model ( filename => 'all_d101.dmp', directory => 'DMDIR', schema_remap => 'DM1:DM2', tablespace_remap => 'EXAMPLE:SYSAUX'); END; / -- CONNECT as dm2 SELECT model_name from user_mining_models; MODEL_NAME -------------------------------------------------------------------------------- SVD_SH_SAMPLE EM_SH_CLUS_SAMPLE DT_SH_CLAS_SAMPLE
例34-5 特定のモデルのエクスポート
単一のモデル、モデルのリストまたは特定の特性を共有するモデルのグループをエクスポートできます。
-- Export the model named dt_sh_clas_sample EXECUTE dbms_data_mining.export_model ( filename => 'one_model', directory =>'DMDIR', model_filter => 'name in (''DT_SH_CLAS_SAMPLE'')'); -- one_model01.dmp and dm1_exp_37.log are created in /scratch/dmuser/expimp -- Export Decision Tree models EXECUTE dbms_data_mining.export_model( filename => 'algo_models', directory => 'DMDIR', model_filter => 'ALGORITHM_NAME IN (''DECISION_TREE'')'); -- algo_model01.dmp and dm1_exp_410.log are created in /scratch/dmuser/expimp -- Export clustering models EXECUTE dbms_data_mining.export_model( filename =>'func_models', directory => 'DMDIR', model_filter => 'FUNCTION_NAME = ''CLUSTERING'''); -- func_model01.dmp and dm1_exp_513.log are created in /scratch/dmuser/expimp
34.3.5 シリアライズされたモデルのEXPORTおよびIMPORT
Oracle Databaseリリース18c以降、EXPORT_SERMODEL
プロシージャとIMPORT_SERMODEL
プロシージャは、シリアライズされたモデルのエクスポートとインポートに使用できます。
シリアライズされた形式を使用すると、スコアリングのために別のプラットフォーム(データベースの外部)にモデルを移動できます。モデルはBFILE
に保存可能なBLOB
でエクスポートされます。インポート・ルーチンは、BLOB
でシリアライズされたコンテンツと、そのコンテンツで作成するモデルの名前を受け取ります。
34.3.6 PMMLからのインポート
Predictive Model Markup Language (PMML)で表現された回帰モデルをインポートできます。
PMMLは、Data Mining Group(http://www.dmg.org
)によって策定されたXMLベースの規格です。PMMLに準拠しているアプリケーションは、任意のベンダーによって作成されたPMML準拠のモデルを配置できます。Oracle Data Miningでは、回帰モデルに対応するPMML 3.1のコア機能をサポートしています。
PMMLで表現された回帰モデルをインポートできます。モデルのタイプは、RegressionModel
(線形回帰またはバイナリ・ロジスティック回帰)である必要があります。