Search code examples
phporacle-databasepdoclob

Sql update for clob field in PDO (PHP) doesn't update nor throw update execption


I've searched all over the net for examples on performing a sql update on clob fields; I believe the example I'm using is the simplest one that should work but so far none have worked. I'm trying to insert a base64 encoded image into the clob field in oracle. Below are the function and the array of clob entries. I've checked the table and verified that no update has occurred on the clob field.

// 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
    )

)

***** update

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

Solution

  • NOTA: Posting as a community wiki to mark the question as solved.

    You are using :ID and :id. Those are case-sensitive.

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

    Yet, from the link you found about a patch, seems to also have contributed to successfully updating your database.

    As per your comment:

    "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);
        }
    }