
中山テック 代表の中山です。
先日、システム開発の現場にてDataPump(データポンプ)でのダンプに
どれぐらいの時間が掛かるのか調査をして欲しいという問い合わせを受けました。
というか、Oracleは11g以降は通常のダンプではなく、DataPumpが推奨されています。
※通常のダンプは11g以降サポートしなくなったため
今まで話題にすら上がらなかった?と思うと情報収集の甘さが露呈していますね。
そんこんなで、DataPumpは何をするものなのか、使い方や
メリット・デメリットをお話したいと思います。
高速のデータエクスポートと思っていただいて差し支えありません。
今まではexpでエクスポートを行っていた(行っている)方が殆どでしたが
サポート切れの憂き目にあってしまいました。
読み方は先ほど記載しましたが、「データポンプ」です。
※私は初め「データパンプ」と読んでました。いやー、お恥ずかしい(笑)
- リモート会議がかんたんに出来る!Google Meetの使い方を伝授
- Lenovo ThinkPad E14 Gen2 を購入しました
- JavaScriptでデバッグ~プログラムエラー発生した時の解決に繋がる~
- JavaScriptで画像をランダム表示~様々な種類の広告や記事の見出しを見せたい等~
- VMWare Workstation Player×CentOSで自PCに仮想環境を構築する方法
- VMWare × CentOSの環境にSSH通信する方法~TeraTermを例にログイン~
- VMWareを使っていて「プロセスはファイルにアクセスできません。別のプロセスが使用中です」と出た
- VBAの基礎についてのブログはnoteに移動しました【リンクあり】
- Javascriptでアニメーションを作る方法~anime.jsで簡単に~
- UNION ALLの使い方(構文)は非常にシンプル
DataPumpの使い方
ディレクトリを作成
エクスポート専用のディレクトリぐらい作ってるわ!とお思いかもしれませんが
これはオラクルが認識可能な環境変数定義の意味であると覚えておいてください。
ちなみに、DataPumpは直接のパス指定はできません。
DDLの様式は下記の通りです。
create [OR REPLACE] directory オブジェクト名 as '対象ディレクトリのフルパス';
※OR REPLACEは同名のディレクトリがあっても無視するオプションです
これだけではオブジェクト指定してもエラーが発生します。
対象ユーザに権限を付与します。
GRANT READ ON DIRECTORY ディレクトリ名 TO ユーザ(スキーマ)名;
GRANT WRITE ON DIRECTORY ディレクトリ名 TO ユーザ(スキーマ)名;
エクスポートコマンド
expdpコマンドを使用します。
構文は下記の通りになります。
expdp <ユーザ>/<パスワード>@<接続文字列> <オプション>
一見簡単そうですが、データエクスポートする際はディレクトリやエクスポートファイル、
パスを指定するケースが殆どなのでオプションが多くなります。
インポートコマンド
impdpコマンドを使用します。
構文はエクスポートとほぼ同じになります。
impdp <ユーザ>/<パスワード>@<接続文字列> <オプション>
オプションについてはOracleのDataPumpの使い方(応用編)をご参照ください。