PDO::pgsqlLOBOpen

(PHP 5 >= 5.1.2, PHP 7, PHP 8, PECL pdo_pgsql >= 1.0.2)

PDO::pgsqlLOBOpen既存のラージオブジェクトのストリームをオープンする

説明

public PDO::pgsqlLOBOpen(string $oid, string $mode = "rb"): resource|false

PDO::pgsqlLOBOpen() は、oid が指すデータにアクセスするためのストリームをオープンします。 moder の場合、 ストリームは読み込み用にオープンされます。 modew の場合、 ストリームは書き込み用にオープンされます。 fread()fwrite() および fgets() のような通常のファイルシステム関数を使用して、 ストリームの内容を操作することができます。

注意: この関数およびラージオブジェクトに対するすべての操作は、 トランザクション内で処理される必要があります。

パラメータ

oid

ラージオブジェクトの ID。

mode

モードが r の場合、読み込み用のストリームをオープンします。 モードが w の場合、書き込み用のストリームをオープンします。

戻り値

成功した場合にストリームリソース、失敗した場合に false を返します。

例1 PDO::pgsqlLOBOpen() の例

PDO::pgsqlLOBCreate() の例に引き続き、 このコード片はデータベースからラージオブジェクトを取得して それをブラウザに出力します。

<?php
$db 
= new PDO('pgsql:dbname=test host=localhost'$user$pass);
$db->setAttribute(PDO::ATTR_ERRMODEPDO::ERRMODE_EXCEPTION);
$db->beginTransaction();
$stmt $db->prepare("select oid from BLOBS where ident = ?");
$stmt->execute(array($some_id));
$stmt->bindColumn('oid'$oidPDO::PARAM_STR);
$stmt->fetch(PDO::FETCH_BOUND);
$stream $db->pgsqlLOBOpen($oid'r');
header("Content-type: application/octet-stream");
fpassthru($stream);
?>

参考

関連キーワード:  ストリーム, オープン, ラージオブジェクト, PDO, 既存, pgsqlLOBOpen, mode, oid, pgsqlLOBCreate, 書き込み