|  | 
 oci_bind_by_name    (PHP 5) oci_bind_by_name -- 
     Binds the PHP variable to the Oracle placeholder
    Descriptionbool oci_bind_by_name  ( resource stmt, string ph_name, mixed &variable [, int maxlength [, int type]]) 
     oci_bind_by_name() binds the PHP variable
     variable to the Oracle placeholder
     ph_name.  Whether it will be used for
     input or output will be determined at run-time and the necessary
     storage space will be allocated. The length 
     parameter sets the maximum length for the bind. If you set 
     length to -1
     oci_bind_by_name() will use the current length of
     variable to set the maximum length.
     
     If you need to bind an abstract datatype (LOB/ROWID/BFILE) you
     need to allocate it first using the
     oci_new_descriptor() function. The
     length is not used for abstract datatypes
     and should be set to -1. The type parameter
     tells Oracle which descriptor is used. Possible
     values are: 
      
        OCI_B_FILE - for BFILEs;
       
        OCI_B_CFILE - for CFILEs;
       
        OCI_B_CLOB - for CLOBs;
       
        OCI_B_BLOB - for BLOBs;
       
        OCI_B_ROWID - for ROWIDs;
       
        OCI_B_NTY - for named datatypes;
       
        OCI_B_CURSOR - for cursors, that were created
        before with oci_new_cursor().
       
 
      | 例子 1. oci_bind_by_name()example | 
<?php/* oci_bind_by_name example thies at thieso dot net (980221)
 inserts 3 records into emp, and uses the ROWID for updating the
 records just after the insert.
 */
 
 $conn = oci_connect("scott", "tiger");
 
 $stmt = oci_parse($conn, "
 INSERT INTO
 emp (empno, ename)
 VALUES
 (:empno,:ename)
 RETURNING
 ROWID
 INTO
 :rid
 ");
 
 $data = array(
 1111 => "Larry",
 2222 => "Bill",
 3333 => "Jim"
 );
 
 $rowid = oci_new_descriptor($conn, OCI_D_ROWID);
 
 oci_bind_by_name($stmt, ":empno", $empno, 32);
 oci_bind_by_name($stmt, ":ename", $ename, 32);
 oci_bind_by_name($stmt, ":rid",   $rowid, -1, OCI_B_ROWID);
 
 $update = oci_parse($conn, "
 UPDATE
 emp
 SET
 sal = :sal
 WHERE
 ROWID = :rid
 ");
 oci_bind_by_name($update, ":rid", $rowid, -1, OCI_B_ROWID);
 oci_bind_by_name($update, ":sal", $sal,   32);
 
 $sal = 10000;
 
 while (list($empno, $ename) = each($data)) {
 oci_execute($stmt);
 oci_execute($update);
 }
 
 $rowid->free();
 
 oci_free_statement($update);
 oci_free_statement($stmt);
 
 $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);
 ?>
 | 
 | 
 
     Remember, that this function strips trailing whitespace. See the following
     example:
     
      | 例子 2. oci_bind_by_name() example | 
<?php$connection = oci_connect('apelsin','kanistra');
 $query = "INSERT INTO test_table VALUES(:id, :text)";
 
 $statement = oci_parse($query);
 oci_bind_by_name($statement, ":id", 1);
 oci_bind_by_name($statement, ":text", "trailing spaces follow     ");
 oci_execute($statement);
 /*
 This code will insert into DB string 'trailing spaces follow', without
 trailing spaces
 */
 ?>
 | 
 | 
 
      | 例子 3. oci_bind_by_name() example | 
<?php$connection = oci_connect('apelsin','kanistra');
 $query = "INSERT INTO test_table VALUES(:id, 'trailing spaces follow      ')";
 
 $statement = oci_parse($query);
 oci_bind_by_name($statement, ":id", 1);
 oci_execute($statement);
 /*
 And this code will add 'trailing spaces follow      ', preserving
 trailing whitespaces
 */
 ?>
 | 
 | 
 | 警告 |  | 
      Do not use magic_quotes_gpc or 
      addslashes() and oci_bind_by_name() 
      simultaneously as no quoting is needed and any magically applied quotes 
      will be written into your database as oci_bind_by_name() 
      is not able to distinguish magically added quotings from those added
      intentionally.
      | 
     如果成功则返回 TRUE,失败则返回 FALSE。
     注: 
      In PHP versions before 5.0.0 you must use ocibindbyname() instead. 
      This name still can be used, it was left as alias of
      oci_bind_by_name() for downwards compatability. 
      This, however, is deprecated and not recommended.
     
 |  |