db2_exec

(PECL)

db2_exec --  Executes an SQL statement directly

说明

resource db2_exec ( resource connection, string statement [, array options] )

Prepares and executes an SQL statement.

If you plan to interpolate PHP variables into the SQL statement, understand that this is one of the more common security exposures. Consider calling db2_prepare() to prepare an SQL statement with parameter markers for input values. Then you can call db2_execute() to pass in the input values and avoid SQL injection attacks.

If you plan to repeatedly issue the same SQL statement with different parameters, consider calling db2_prepare() and db2_execute() to enable the database server to reuse its access plan and increase the efficiency of your database access.

参数

connection

A valid database connection resource variable as returned from db2_connect() or db2_pconnect().

statement

An SQL statement. The statement cannot contain any parameter markers.

options

An associative array containing statement options. You can use this parameter to request a scrollable cursor on database servers that support this functionality.

cursor

Passing the DB2_FORWARD_ONLY value requests a forward-only cursor for this SQL statement. This is the default type of cursor, and it is supported by all database servers. It is also much faster than a scrollable cursor.

Passing the DB2_SCROLLABLE value requests a scrollable cursor for this SQL statement. This type of cursor enables you to fetch rows non-sequentially from the database server. However, it is only supported by DB2 servers, and is much slower than forward-only cursors.

返回值

Returns a statement resource if the SQL statement was issued successfully, or FALSE if the database failed to execute the SQL statement.

范例

例子 1. Creating a table with db2_exec()

The following example uses db2_exec() to issue a set of DDL statements in the process of creating a table.

<?php
$conn
= db2_connect($database, $user, $password);

// Create the test table
$create = 'CREATE TABLE animals (id INTEGER, breed VARCHAR(32),
    name CHAR(16), weight DECIMAL(7,2))'
;
$result = db2_exec($conn, $create);
if (
$result) {
    print
"Successfully created the table.\n";
}

// Populate the test table
$animals = array(
    array(
0, 'cat', 'Pook', 3.2),
    array(
1, 'dog', 'Peaches', 12.3),
    array(
2, 'horse', 'Smarty', 350.0),
    array(
3, 'gold fish', 'Bubbles', 0.1),
    array(
4, 'budgerigar', 'Gizmo', 0.2),
    array(
5, 'goat', 'Rickety Ride', 9.7),
    array(
6, 'llama', 'Sweater', 150)
);

foreach (
$animals as $animal) {
    
$rc = db2_exec($conn, "INSERT INTO animals (id, breed, name, weight)
      VALUES ('
{$animal[0]}', '{$animal[1]}', '{$animal[2]}', {$animal[3]})");
    if (
$rc) {
        print
"Insert... ";
    }
}
?>

上例将输出:

Successfully created the table.
Insert... Insert... Insert... Insert... Insert... Insert... Insert...

例子 2. Executing a SELECT statement with a scrollable cursor

The following example demonstrates how to request a scrollable cursor for an SQL statement issued by db2_exec().

<?php
$conn
= db2_connect($database, $user, $password);
$sql = "SELECT name FROM animals
    WHERE weight < 10.0
    ORDER BY name"
;
if (
$conn) {
    require_once(
'prepare.inc');
    
$stmt = db2_exec($conn, $sql, array('cursor' => DB2_SCROLLABLE));
    while (
$row = db2_fetch_array($stmt)) {
        print
"$row[0]\n";
    }
}
?>

上例将输出:

Bubbles
Gizmo
Pook
Rickety Ride


add a note add a note User Contributed Notes
duc
13-Aug-2006 09:38
if you have the error message : PHP Warning:  db2_exec() [<a href='function.db2-exec'>function.db2-exec</a>]: Statement Execute Failed in (....)
and cannot display the error message using db2_stmt_errormsg() , then check if your database connection handle is (still) valid
shawn at frozen-o dot com
20-May-2006 01:34
If you need to "emulate" offset/limit (as PEAR::DB puts it) for db2 queries, you will definitely need to add array('cursor' => DB2_SCROLLABLE) to your db2_exec() call. Otherwise, you will get nothing useful from db2_fetch_{whatever}() when you try to (see following hack for example):

$limit = 10;
$offset = 20;

for ($i = 0; $i < $limit && $row = db2_fetch_array($result, $offset + $i); $i++) {
   // stuff goes here
}

You can accomplish the same time of thing using sub-selects, "with" statements and other things new to me in the world of DB2, but the more dynamically generated the queries, the more difficult it gets to implement limit/offset behavior on the fly.