Sql 更新 PDO 中的 clob 字段 (PHP) 不更新不抛出更新异常
Sql update for clob field in PDO (PHP) doesn't update nor throw update execption
我在网上搜索了有关对 clob 字段执行 sql 更新的示例;我相信我使用的示例是最简单的示例,但到目前为止 none 已经有效。我正在尝试将 base64 编码的图像插入到 oracle 的 clob 字段中。下面是函数和 clob 条目数组。我检查了 table 并确认 clob 字段没有发生更新。
// update row with new clob values
private function clobUpdate($clobArray){
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = EMPTY_BLOB() WHERE ID = :ID RETURNING ". $item["clobField"] . " INTO :blob";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':id', $item["id"]);
$stmt->bindParam(':blob', $item["clobValue"], PDO::PARAM_LOB);
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(Exception $e){
throw new Exception($e);
}
}
Array
(
[0] => Array
(
[clobField] => 0
[clobValue] => 
[id] => 25
)
)
***** 更新
根据 Fred 的错误处理 link 和 this 2007 补丁,我现在可以更新我的 clob。更新了以下功能:
// update row with new clob values
private function clobUpdate($clobArray){
$this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = :CLOB WHERE ID = :ID";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':ID', $item["id"]);
$stmt->bindParam(':CLOB', $item["clobValue"], PDO::PARAM_STR, strlen($item["clobValue"]));
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(PDOException $e){
echo "Exception ". $e->getMessage();
throw new Exception($e);
}
}
注意:作为社区 Wiki 发布以将问题标记为已解决。
您正在使用 :ID
和 :id
。区分大小写。
WHERE ID = :ID
... bindParam(':id',
=> bindParam(':ID',
- 使用 PDO 的错误处理http://php.net/manual/en/pdo.error-handling.php
然而,从 link 你发现的一个补丁,似乎也有助于成功更新你的数据库。
根据您的评论:
"Per Fred's error handling link and this 2007 patch I'm now able to update my clob. Updated function below:"
// update row with new clob values
private function clobUpdate($clobArray){
$this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = :CLOB WHERE ID = :ID";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':ID', $item["id"]);
$stmt->bindParam(':CLOB', $item["clobValue"], PDO::PARAM_STR, strlen($item["clobValue"]));
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(PDOException $e){
echo "Exception ". $e->getMessage();
throw new Exception($e);
}
}
我在网上搜索了有关对 clob 字段执行 sql 更新的示例;我相信我使用的示例是最简单的示例,但到目前为止 none 已经有效。我正在尝试将 base64 编码的图像插入到 oracle 的 clob 字段中。下面是函数和 clob 条目数组。我检查了 table 并确认 clob 字段没有发生更新。
// update row with new clob values
private function clobUpdate($clobArray){
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = EMPTY_BLOB() WHERE ID = :ID RETURNING ". $item["clobField"] . " INTO :blob";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':id', $item["id"]);
$stmt->bindParam(':blob', $item["clobValue"], PDO::PARAM_LOB);
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(Exception $e){
throw new Exception($e);
}
}
Array
(
[0] => Array
(
[clobField] => 0
[clobValue] => 
[id] => 25
)
)
***** 更新
根据 Fred 的错误处理 link 和 this 2007 补丁,我现在可以更新我的 clob。更新了以下功能:
// update row with new clob values
private function clobUpdate($clobArray){
$this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = :CLOB WHERE ID = :ID";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':ID', $item["id"]);
$stmt->bindParam(':CLOB', $item["clobValue"], PDO::PARAM_STR, strlen($item["clobValue"]));
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(PDOException $e){
echo "Exception ". $e->getMessage();
throw new Exception($e);
}
}
注意:作为社区 Wiki 发布以将问题标记为已解决。
您正在使用 :ID
和 :id
。区分大小写。
WHERE ID = :ID
... bindParam(':id',
=> bindParam(':ID',
- 使用 PDO 的错误处理http://php.net/manual/en/pdo.error-handling.php
然而,从 link 你发现的一个补丁,似乎也有助于成功更新你的数据库。
根据您的评论:
"Per Fred's error handling link and this 2007 patch I'm now able to update my clob. Updated function below:"
// update row with new clob values
private function clobUpdate($clobArray){
$this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
foreach ($clobArray as $item) {
$query = "UPDATE ". static::$table ." SET ". $item["clobField"] ." = :CLOB WHERE ID = :ID";
$stmt = $this->db->prepare($query);
$stmt->bindParam(':ID', $item["id"]);
$stmt->bindParam(':CLOB', $item["clobValue"], PDO::PARAM_STR, strlen($item["clobValue"]));
$blob = NULL;
$this->db->beginTransaction();
$stmt->execute();
$this->db->commit();
print_r($blob);
die();
}
} catch(PDOException $e){
echo "Exception ". $e->getMessage();
throw new Exception($e);
}
}