maxdb_stmt_bind_param
maxdb_stmt::bind_param
(PECL maxdb >= 1.0)
maxdb_stmt_bind_param -- maxdb_stmt::bind_param — Binds variables to a prepared statement as parameters
Description
Procedural style
Object oriented style
Procedural style (extended syntax):
$stmt
, string $types
, array &$var
)Object oriented style (extended syntax):
$types
, array &$var
)
maxdb_stmt_bind_param() is used to bind variables for the
parameter markers in the SQL statement that was passed to
maxdb_prepare().
The string types
contains one or more characters which specify
the types for the corresponding bind variables.
The extended syntax of maxdb_stmt_bind_param() allows to give the parameters as an array instead of a variable list of PHP variables to the function. If the array variable has not been used before calling maxdb_stmt_bind_param(), it has to be initialized as an emtpy array. See the examples how to use maxdb_stmt_bind_param() with extended syntax.
Variables for SELECT INTO SQL statements can also be bound using maxdb_stmt_bind_param(). Parameters for database procedures can be bound using maxdb_stmt_bind_param(). See the examples how to use maxdb_stmt_bind_param() in this cases.
If a variable bound as INTO variable to an SQL statement was used before, the content of this variable is overwritten by the data of the SELECT INTO statement. A reference to this variable will be invalid after a call to maxdb_stmt_bind_param().
For INOUT parameters of database procedures the content of the bound INOUT variable is overwritten by the output value of the database procedure. A reference to this variable will be invalid after a call to maxdb_stmt_bind_param().
Character | Description |
---|---|
i | corresponding variable has type integer |
d | corresponding variable has type double |
s | corresponding variable has type string |
b | corresponding variable is a blob and will be sent in packages |
Return Values
Returns TRUE
on success or FALSE
on failure.
Examples
Example #1 Object oriented style
<?php
$maxdb = new maxdb('localhost', 'MONA', 'RED', 'DEMODB');
/* check connection */
if (maxdb_connect_errno()) {
printf("Connect failed: %s\n", maxdb_connect_error());
exit();
}
$maxdb->query ("CREATE TABLE temp.mycity LIKE hotel.city");
$maxdb->query ("INSERT INTO temp.mycity SELECT * FROM hotel.city");
$stmt = $maxdb->prepare("INSERT INTO temp.mycity VALUES (?, ?, ?)");
$stmt->bind_param('sss', $zip, $name, $state);
$zip = '11111';
$name = 'Georgetown';
$state = 'NY';
/* execute prepared statement */
$stmt->execute();
printf("%d Row inserted.\n", $stmt->affected_rows);
/* close statement and connection */
$stmt->close();
/* Clean up table CountryLanguage */
$maxdb->query("DELETE FROM temp.mycity WHERE name='Georgetown'");
printf("%d Row deleted.\n", $maxdb->affected_rows);
/* close connection */
$maxdb->close();
?>
Example #2 Procedural style
<?php
$link = maxdb_connect("localhost", "MONA", "RED", "DEMODB");
/* check connection */
if (!$link) {
printf("Connect failed: %s\n", maxdb_connect_error());
exit();
}
maxdb_query ($link, "CREATE TABLE temp.mycity LIKE hotel.city");
maxdb_query ($link, "INSERT INTO temp.mycity SELECT * FROM hotel.city");
$stmt = maxdb_prepare($link, "INSERT INTO temp.mycity VALUES (?, ?, ?)");
maxdb_stmt_bind_param($stmt, 'sss', $zip, $name, $state);
$zip = '11111';
$name = 'Georgetown';
$state = 'NY';
/* execute prepared statement */
maxdb_stmt_execute($stmt);
printf("%d Row inserted.\n", maxdb_stmt_affected_rows($stmt));
/* close statement and connection */
maxdb_stmt_close($stmt);
/* Clean up table CountryLanguage */
maxdb_query($link, "DELETE FROM temp.mycity WHERE name='Georgetown'");
printf("%d Row deleted.\n", maxdb_affected_rows($link));
/* close connection */
maxdb_close($link);
?>
The above example will output something similar to:
1 Row inserted. 1 Row deleted.
Example #3 Procedural style (SELECT INTO)
<?php
$link = maxdb_connect("localhost", "MONA", "RED", "DEMODB");
/* check connection */
if (!$link) {
printf("Connect failed: %s\n", maxdb_connect_error());
exit();
}
/* Performing SQL query */
$stmt = maxdb_prepare ($link, "SELECT price INTO ? FROM hotel.room where hno = ? and type = ?");
if (!$stmt) {
printf ("Prepare failed: %s\n", maxdb_error($link));
}
$hno = "50";
$rtype = "suite";
maxdb_stmt_bind_param($stmt, 'dss', $price, $hno, $rtype);
maxdb_stmt_execute($stmt);
printf ("%f\n", $price);
maxdb_stmt_close ($stmt);
?>
The above example will output something similar to:
21.600000
Example #4 Procedural style (DB procedure)
<?php
$link = maxdb_connect("localhost", "MONA", "RED", "DEMODB");
/* check connection */
if (!$link) {
printf("Connect failed: %s\n", maxdb_connect_error());
exit();
}
maxdb_report (MAXDB_REPORT_OFF);
maxdb_query($link,"DROP DBPROC test_proc");
maxdb_report (MAXDB_REPORT_ERROR);
$query = "create dbproc test_proc (INOUT e_text char(72)) AS select * from SYSDBA.DUAL; fetch into :e_text;";
maxdb_query($link, $query);
/* Performing SQL query */
$stmt = maxdb_prepare ($link, "CALL test_proc (?)");
if (!$stmt) {
printf ("Prepare failed: %s\n", maxdb_error($link));
}
maxdb_stmt_bind_param($stmt, 's', $result);
maxdb_stmt_execute($stmt);
printf ("%s\n", $result);
maxdb_stmt_close ($stmt);
?>
The above example will output something similar to:
a
Example #5 Object oriented style (extended syntax)
<?php
$maxdb = new maxdb('localhost', 'MONA', 'RED', 'DEMODB');
/* check connection */
if (maxdb_connect_errno()) {
printf("Connect failed: %s\n", maxdb_connect_error());
exit();
}
$maxdb->query ("CREATE TABLE temp.mycity LIKE hotel.city");
$maxdb->query ("INSERT INTO temp.mycity SELECT * FROM hotel.city");
$stmt = $maxdb->prepare("INSERT INTO temp.mycity VALUES (?, ?, ?)");
$arr = array();
$stmt->bind_param('iss', $arr);
$arr[0] = 11111;
$arr[1] = 'Georgetown';
$arr[2] = 'NY';
/* execute prepared statement */
$stmt->execute();
printf("%d Row inserted.\n", maxdb_stmt_affected_rows($stmt));
$arr[0] = 22222;
$arr[1] = 'New Orleans';
$arr[2] = 'LA';
/* execute prepared statement */
$stmt->execute();
printf("%d Row inserted.\n", $stmt->affected_rows);
/* close statement and connection */
$stmt->close();
$result = $maxdb->query("SELECT * from temp.mycity WHERE zip = '11111' OR zip = '22222'");
if ($result) {
while ($row = $result->fetch_row()) {
printf ("%s %s %s\n", $row[0], $row[1], $row[2]);
}
}
/* Clean up table CountryLanguage */
$maxdb->query("DELETE FROM temp.mycity WHERE name='Georgetown'");
$maxdb->query("DELETE FROM temp.mycity WHERE name='New Orleans'");
printf("%d Rows deleted.\n", $maxdb->affected_rows);
/* close connection */
$maxdb->close();
?>
The above example will output something similar to:
1 Row inserted. 1 Row inserted. 11111 Georgetown NY 22222 New Orleans LA 2 Rows deleted.
See Also
- maxdb_stmt_bind_result() - Binds variables to a prepared statement for result storage
- maxdb_stmt_execute() - Executes a prepared Query
- maxdb_stmt_fetch() - Fetch results from a prepared statement into the bound variables
- maxdb_prepare() - Prepare an SQL statement for execution
- maxdb_stmt_send_long_data() - Send data in blocks
- maxdb_stmt_errno() - Returns the error code for the most recent statement call
- maxdb_stmt_error() - Returns a string description for last statement error
- PHP Руководство
- Функции по категориям
- Индекс функций
- Справочник функций
- Расширения для работы с базами данных
- Расширения для работы с базами данных отдельных производителей
- MaxDB
- maxdb_affected_rows
- maxdb_autocommit
- maxdb_bind_param
- maxdb_bind_result
- maxdb_change_user
- maxdb_character_set_name
- maxdb_client_encoding
- maxdb_close_long_data
- maxdb_close
- maxdb_commit
- maxdb_connect_errno
- maxdb_connect_error
- maxdb_connect
- maxdb_data_seek
- maxdb_debug
- maxdb_disable_reads_from_master
- maxdb_disable_rpl_parse
- maxdb_dump_debug_info
- maxdb_embedded_connect
- maxdb_enable_reads_from_master
- maxdb_enable_rpl_parse
- maxdb_errno
- maxdb_error
- maxdb_escape_string
- maxdb_execute
- maxdb_fetch_array
- maxdb_fetch_assoc
- maxdb_fetch_field_direct
- maxdb_fetch_field
- maxdb_fetch_fields
- maxdb_fetch_lengths
- maxdb_fetch_object
- maxdb_fetch_row
- maxdb_fetch
- maxdb_field_count
- maxdb_field_seek
- maxdb_field_tell
- maxdb_free_result
- maxdb_get_client_info
- maxdb_get_client_version
- maxdb_get_host_info
- maxdb_get_metadata
- maxdb_get_proto_info
- maxdb_get_server_info
- maxdb_get_server_version
- maxdb_info
- maxdb_init
- maxdb_insert_id
- maxdb_kill
- maxdb_master_query
- maxdb_more_results
- maxdb_multi_query
- maxdb_next_result
- maxdb_num_fields
- maxdb_num_rows
- maxdb_options
- maxdb_param_count
- maxdb_ping
- maxdb_prepare
- maxdb_query
- maxdb_real_connect
- maxdb_real_escape_string
- maxdb_real_query
- maxdb_report
- maxdb_rollback
- maxdb_rpl_parse_enabled
- maxdb_rpl_probe
- maxdb_rpl_query_type
- maxdb_select_db
- maxdb_send_long_data
- maxdb_send_query
- maxdb_server_end
- maxdb_server_init
- maxdb_set_opt
- maxdb_sqlstate
- maxdb_ssl_set
- maxdb_stat
- maxdb_stmt_affected_rows
- maxdb_stmt_bind_param
- maxdb_stmt_bind_result
- maxdb_stmt_close_long_data
- maxdb_stmt_close
- maxdb_stmt_data_seek
- maxdb_stmt_errno
- maxdb_stmt_error
- maxdb_stmt_execute
- maxdb_stmt_fetch
- maxdb_stmt_free_result
- maxdb_stmt_init
- maxdb_stmt_num_rows
- maxdb_stmt_param_count
- maxdb_stmt_prepare
- maxdb_stmt_reset
- maxdb_stmt_result_metadata
- maxdb_stmt_send_long_data
- maxdb_stmt_sqlstate
- maxdb_stmt_store_result
- maxdb_store_result
- maxdb_thread_id
- maxdb_thread_safe
- maxdb_use_result
- maxdb_warning_count
Коментарии
404 Not Found