WRITE ステートメントは、指定された数のデータを内部 LOB(LOB で始まる絶対オフセットから計算)に書き込むために使用されます。
データは buffer パラメータから書き込まれます。WRITE は、指定された長さで LOB オフセット内に既に存在するデータを上書きします。
機能の適用範囲
この内容はOceanBaseデータベースEnterprise Editionにのみ適用されます。OceanBaseデータベースCommunity EditionはMySQLモードのみを提供します。
構文
DBMS_LOB.WRITE (
lob_loc IN OUT NOCOPY BLOB,
amount IN INTEGER,
offset IN INTEGER,
buffer IN RAW);
DBMS_LOB.WRITE (
lob_loc IN OUT NOCOPY CLOB CHARACTER SET ANY_CS,
amount IN INTEGER,
offset IN INTEGER,
buffer IN VARCHAR2 CHARACTER SET ANY_CS);
パラメータの説明
パラメータ |
説明 |
|---|---|
| lob_loc | 書き込む内部 LOB のロケーターです。DBMS_LOB 使用说明を参照してください。 |
| amount | 書き込むバイト数(BLOBの場合)または文字数(CLOBの場合)。 |
| offset | LOB の読み取り開始位置のバイト数(BLOBの場合)または文字数(CLOBの場合)のオフセット(原点は1)。 |
| buffer | 書き込み用の入力バッファです。 |
例外状況
例外 |
説明 |
|---|---|
| VALUE_ERROR | lob_loc、mount、または offset パラメータのいずれかが NULL、範囲外、または無効です。 |
| INVALID_ARGVAL | 次のいずれかの場合が考えられます:
|
| QUERY_WRITE | クエリまたはPDML並列実行サーバー内で LOB 書き込みを実行できません。 |
| BUFFERING_ENABLED | LOB でバッファリングが有効になっている場合、その状態で操作を実行できません。 |
| SECUREFILE_OUTOFBOUNDS | 書き込み操作を実行しようとした際に、FRAGMENT_ * でマークされた LOB の末尾をスキップしました。 |
使用方法
入力量がバッファ内のデータより大きい場合、エラーが発生します。入力量がバッファ内のデータより小さい場合、バッファ内のバイトまたは文字数だけが
LOBに書き込まれます。指定されたオフセットがLOB内の現在のデータの終端を超える場合、BLOBまたはCLOBにゼロバイトフィラーまたはスペースが挿入されます。VARCHAR2バッファの形式はCLOBパラメータの形式と一致している必要があります。つまり、LOBパラメータの型をCLOBとして指定した場合、バッファにはCHARデータを含める必要があります。クライアントから
DBMS_LOB_WRITEを呼び出す際、バッファにはクライアントの文字セットのデータを含める必要があります。バッファデータをLOBに書き込む前に、データベースはクライアントのバッファをサーバーの文字セットに変換します。LOB操作を Open/Close インターフェースで囲むことは必須ではありません。操作を実行する前にLOBを開いていない場合、呼び出し中にLOB列上の機能インデックスとドメインインデックスが更新されます。操作を実行する前にLOBを開いている場合、トランザクションをコミットする前にそれを閉じる必要があります。内部LOBを閉じると、LOB列上の機能インデックスとドメインインデックスが更新されます。LOB操作を Open/Close インターフェースで囲まない場合、LOBに書き込むたびに機能インデックスとドメインインデックスが更新されます。パフォーマンスへの悪影響を避けるため、LOBへの書き込み操作はOPENまたはCLOSEステートメント内に含めることを推奨します。必要に応じて、
WRITEはLOBを書き込む前にLOBを取得します。ただし、書き込み操作がLOB全体を上書きすることを指定している場合はこの限りではありません。