oracle — обновление Sql для поля clob в PDO (PHP) не обновляет и не выдает выполнение обновления

Я искал по всей сети примеры выполнения обновления sql для полей clob; Я считаю, что пример, который я использую, является самым простым, который должен работать, но до сих пор ни один не работал. Я пытаюсь вставить закодированное в base64 изображение в поле clob в oracle. Ниже приведены функция и массив записей clob. Я проверил таблицу и убедился, что в поле 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
)

)

***** Обновить

За ссылку обработки ошибок Фреда и этот Патч 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);
}
}

2

Решение

ПРИМЕЧАНИЕ: размещение в вики сообщества, чтобы пометить вопрос как решенный.

Ты используешь :ID а также :id, Они чувствительны к регистру.

WHERE ID = :IDbindParam(':id', => bindParam(':ID',

Тем не менее, судя по ссылке, которую вы нашли о патче, она также внесла свой вклад в успешное обновление вашей базы данных.

Согласно вашему комментарию:

«Ссылка на обработку ошибок Фреда и этот патч 2007 года Теперь я могу обновить мой саб. Обновленная функция ниже:

// 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);
}
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]