oci_new_cursor
<<<
oci_new_descriptor oci_num_fields
>>>

6.27 Fonctions Oracle
6 Référence des fonctions
 Manuel PHP

Introduction
Pré-requis
Configuration à l'exécution
Constantes pré-définies
Exemples
Gestion de la connexion
Types de données supportées par le driver
oci_bind_by_name
oci_cancel
oci_close
OCI-Collection->append
OCI-Collection->assign
OCI-Collection->assignElem
OCI-Collection->free
OCI-Collection->getElem
OCI-Collection->max
OCI-Collection->size
OCI-Collection->trim
oci_commit
oci_connect
oci_define_by_name
oci_error
oci_execute
oci_fetch_all
oci_fetch_array
oci_fetch_assoc
oci_fetch_object
oci_fetch_row
oci_fetch
oci_field_is_null
oci_field_name
oci_field_precision
oci_field_scale
oci_field_size
oci_field_type_raw
oci_field_type
oci_free_statement
oci_internal_debug
OCI-Lob->append
OCI-Lob->close
oci_lob_copy
OCI-Lob->eof
OCI-Lob->erase
OCI-Lob->export
OCI-Lob->flush
OCI-Lob->free
OCI-Lob->getBuffering
OCI-Lob->import
oci_lob_is_equal
OCI-Lob->load
OCI-Lob->read
OCI-Lob->rewind
OCI-Lob->save
OCI-Lob->saveFile
OCI-Lob->seek
OCI-Lob->setBuffering
OCI-Lob->size
OCI-Lob->tell
OCI-Lob->truncate
OCI-Lob->write
OCI-Lob->writeTemporary
OCI-Lob->writeToFile
oci_new_collection
oci_new_connect
oci_new_cursor
->oci_new_descriptor
oci_num_fields
oci_num_rows
oci_parse
oci_password_change
oci_pconnect
oci_result
oci_rollback
oci_server_version
oci_set_prefetch
oci_statement_type
ocibindbyname
ocicancel
ocicloselob
ocicollappend
ocicollassign
ocicollassignelem
ocicollgetelem
ocicollmax
ocicollsize
ocicolltrim
ocicolumnisnull
ocicolumnname
ocicolumnprecision
ocicolumnscale
ocicolumnsize
ocicolumntype
ocicolumntyperaw
ocicommit
ocidefinebyname
ocierror
ociexecute
ocifetch
ocifetchinto
ocifetchistatement
ocifreecollection
ocifreecursor
ocifreedesc
ocifreestatement
ociinternaldebug
ociloadlob
ocilogoff
ocilogon
ocinewcollection
ocinewcursor
ocinewscriptor
ocinlogon
ocinumcols
ociparse
ociplogon
ociresult
ocirollback
ocirowcount
ocisavelob
ocisavelobfile
ociserverversion
ocisetprefetch
ocistatementtype
ociwritelobtofile
ociwritetemporarylob

6.27.66 oci_new_descriptor()Initialise un nouveau pointeur vide de LOB/FILE Oracle

[ Exemples avec oci_new_descriptor ]   PHP 5

OCI-Lob  oci_new_descriptor ( resource   connection , int   type )

oci_new_descriptor alloue l'espace nécessaire pour stocker un descripteur, ou un pointeur de LOB, pour la connexion connection . Les valeurs acceptées pour type sont : OCI_D_FILE , OCI_D_LOB et OCI_D_ROWID

Exemple avec oci_new_descriptor

<?php   
/* Ce script est fait pour être appelé dans un formulaire HTML
* Il attends les variables $user, $password, $table, $where, et $commitsize
* Le script efface alors les lignes sélectionnées avec ROWID et valide
* l'effacement après chaque groupe de $commitsize lignes.
* (Utilisez avec prudence, car il n'y a pas d'annulation possible).
*/
$conn = oci_connect($user, $password);
$stmt = oci_parse($conn, "select rowid from $table $where");
$rowid = oci_new_descriptor($conn, OCI_D_ROWID);
oci_define_by_name($stmt, "ROWID", $rowid);   
oci_execute($stmt);
while (
oci_fetch($stmt)) {
  
$nrows = oci_num_rows($stmt);
  
$delete = oci_parse($conn, "delete from $table where ROWID = :rid");
  
oci_bind_by_name($delete, ":rid", $rowid, -1, OCI_B_ROWID);
  
oci_execute($delete);      
  echo
"$nrows\n";
  if ((
$nrows % $commitsize) == 0) {
    
oci_commit($conn);      
  }   
}
$nrows = oci_num_rows($stmt);   
echo
"$nrows deleted...\n";
oci_free_statement($stmt);  
oci_close($conn);
?>
Exemple avec oci_new_descriptor

<?php   
/* Appel d'une procédure PL/SQL stockée qui prend un clobs
* en entrée (PHP 4 >= 4.0.6).
* Exemple de signateure de procédure stockée PL/SQL :
*
* PROCEDURE save_data
*   Argument Name                  Type                    In/Out Default?
*   ------------------------------ ----------------------- ------ --------
*   KEY                            NUMBER(38)              IN
*   DATA                           CLOB                    IN
*
*/

$conn = oci_connect($user, $password);
$stmt = oci_parse($conn, "begin save_data(:key, :data); end;");
$clob = oci_new_descriptor($conn, OCI_D_LOB);
oci_bind_by_name($stmt, ':key', $key);
oci_bind_by_name($stmt, ':data', $clob, -1, OCI_B_CLOB);
$clob->write($data);
oci_execute($stmt, OCI_DEFAULT);
oci_commit($conn);
$clob->free();
oci_free_statement($stmt);
?>

oci_new_descriptor retourne FALSE en cas d'erreur.

Note

Dans les versions de PHP antérieures à la version 5.0.0, vous devez utiliser la fonction ocinewdescriptor . Cet ancien nom est toujours utilisable : un alias a été fait vers la fonction oci_new_descriptor , pour assurer la compatibilité ascendante. Toutefois, il est recommandé de ne plus l'utiliser.

<< oci_new_descriptor >>
oci_new_cursor Fonctions Oracle oci_num_fields