A simple select example.
$pr_stmt = db2_prepare ($this->conn,"select count(*) from note where city=? and year= ?");
db2_execute($pr_stmt,array('test',2016));
$count_res = db2_fetch_array($pr_stmt);
echo "Count =".$count_res[0](PECL ibm_db2 >= 1.0.0)
db2_prepare — Prepara una consulta SQL para ser ejecutada
db2_prepare() crea una consulta SQL preparada que puede
incluir ningún o varios marcadores (caracteres ?)
representando los argumentos de entrada, salida o entrada/salida. Se
pueden pasar argumentos a la consulta preparada utilizando la
función db2_bind_param(), si solo hay entradas,
se puede utilizar db2_execute().
Existen tres ventajas principales de utilizar consultas preparadas en la aplicación :
connectionstatementoptions
Devuelve una variable recurso si la consulta SQL fue enviada
correctamente o false si el servidor de base de datos ha
devuelto un error. Se puede determinar qué error fue devuelto
llamando a la función
db2_stmt_error() o db2_stmt_errormsg().
Ejemplo #1 Preparación y ejecución de una consulta SQL con marcadores
El siguiente ejemplo prepara una consulta INSERT que acepta cuatro marcadores, luego itera sobre el array que contiene los valores de entrada que serán pasados a la función db2_execute().
<?php
$animales = array(
array(0, 'gato', 'Pook', 3.2),
array(1, 'perro', 'Peaches', 12.3),
array(2, 'caballo', 'Smarty', 350.0),
);
$insert = 'INSERT INTO animales (id, raza, nombre, peso)
VALUES (?, ?, ?, ?)';
$stmt = db2_prepare($conn, $insert);
if ($stmt) {
foreach ($animales as $animal) {
$result = db2_execute($stmt, $animal);
}
}
?>A simple select example.
$pr_stmt = db2_prepare ($this->conn,"select count(*) from note where city=? and year= ?");
db2_execute($pr_stmt,array('test',2016));
$count_res = db2_fetch_array($pr_stmt);
echo "Count =".$count_res[0]If you are having problems with scrollable cursors and the prepare statement, I've found that you cant set the scrollable option on the connection. The following code (which tries to get the 2nd record):
<?php
$sql = "SELECT * FROM SCHEMA.TABLENAME";
$options = array('cursor' => DB2_SCROLLABLE);
$conn = db2_connect($database, $user, $password,$options);
$stmt = db2_prepare($conn, $sql);
$result = db2_execute($stmt);
$row = db2_fetch_both($stmt, 2);
$conn = db2_connect($database, $user, $password);
$stmt = db2_prepare($conn, $sql, $options);
$result = db2_execute($stmt);
$row = db2_fetch_both($stmt, 2);
?>
Will result in the following error:
Warning: db2_fetch_both() [function.db2-fetch-both]: Fetch Failure in dbtest.php on line 7
In fact, even if you set the options on both the connection and the prepare your fetch will not work. You must only set that option on the prepare.if you have the error message : PHP Warning: db2_prepare() [<a href='function.db2-prepare'>function.db2-prepare</a>]: Statement Prepare Failed in (....)
and cannot display the error message using db2_stmt_errormsg() , then check if your database connection handle is (still) valid