oci_bind_by_name --
Associe une variable PHP Ã une variable SQL Oracle
Description
bool oci_bind_by_name ( resource stmt, string ph_name, mixed &variable [, int maxlength [, int type]] )
oci_bind_by_name() relie la variable PHP
variable à l'emplacement Oracle
ph_name, dans la commande préparée
stmt. Son utilisation (comme entrée
ou comme sortie) sera définie à l'exécution,
et l'espace nécessaire sera alloué. Le paramètre de
longueur length fixe la taille maximum pour
la liaison. Si vous affectez une longueur length de -1,
oci_bind_by_name() utilisera la longueur de variable
comme maximum maxlength.
Si vous devez lier des types abstraits de données (LOB/ROWID/BFILE),
vous devrez l'allouer dans un premier temps, avec
ocinewdescriptor(). La longueur
length ne sert pas pour ces types et
devrait être fixée à -1. La variable
type indique au serveur Oracle, quel type de
pointeur va être utilisé. Les valeurs possibles sont :
SQLT_FILE - Pour BFILEs;
SQLT_CFILE - Pour CFILEs;
SQLT_CLOB - Pour CLOBs;
SQLT_BLOB - Pour BLOBs;
SQLT_RDD - Pour ROWIDs;
SQLT_NTY - Pour les types de données nommés.
SQLT_INT - pour les entiers.
SQLT_CHR - pour les VARCHARs.
SQLT_BIN - pour les colonnes RAW.
SQLT_LNG - pour les colonnes LONG.
SQLT_LBI - pour les colonnes LONG RAW.
SQLT_RSET - pour les curseurs, qui ont été créés
auparavant avec la fonction oci_new_cursor().
Exemple 1. Exemple avec oci_bind_by_name()
<?php /* Exemple ociBindByPos par thies@thieso.net (980221) Insère 3 lignes dans emp, et utilise ROWID pour mettre à jour les lignes, juste après l'insertion. */
$conn = oci_connect("scott", "tiger");
$stmt = oci_parse($conn, " INSERT INTO emp (empno, ename) VALUES (:empno,:ename) RETURNING ROWID INTO :rid ");
$stmt = oci_parse($conn, " SELECT * FROM emp WHERE empno IN (1111,2222,3333) "); oci_execute($stmt);
while ($row = oci_fetch_assoc($stmt)) { var_dump($row); }
oci_free_statement($stmt);
/* delete our "junk" from the emp table.... */ $stmt = oci_parse($conn, " DELETE FROM emp WHERE empno IN (1111,2222,3333) "); oci_execute($stmt); oci_free_statement($stmt);
oci_close($conn); ?>
N'oubliez pas que cette fonction supprime les caractères d'espace
terminaux. Par exemple :
Exemple 2. oci_bind_by_name() et les caractères d'espace terminaux
$statement = oci_parse($query); oci_bind_by_name($statement, ":id", 1); oci_execute($statement); /* Ce code va insérer la chaîne 'trailing spaces follow ', avec les espaces terminaux. */ ?>
Avertissement
C'est une mauvaise idée que d'utiliser les
magic_quotes_gpc et la fonction
oci_bind_by_name() simultanément, car aucun ajout de
guillemets n'est nécessaire sur les variables citées, et tout
guillemet magique sera inscrit dans votre base de données car
oci_bind_by_name() n'est pas capable de faire la
différence entre les guillemets et ceux qui ont été ajoutés
dynamiquement.
Cette fonction retourne TRUE en cas de
succès, FALSE en cas d'échec.
Note :
Dans les versions de PHP antérieures à la version 5.0.0,
vous devez utiliser la fonction ocibindbyname().
Cet ancien nom est toujours utilisable : un alias a été fait vers
la fonction oci_bind_by_name(), pour assurer
la compatibilité ascendante. Toutefois, il est recommandé de ne
plus l'utiliser.