Home >Backend Development >PHP Problem >What is the usage of php prepare
In PHP, "PDO::prepare" means preparing a statement to be executed and returning a statement object. Its usage syntax is such as "public PDO::prepare(string $statement, array $driver_options = array()) ".
The operating environment of this article: Windows7 system, PHP8 version, DELL G3 computer
What is the usage of php prepare?
PDO::prepare
(PHP 5 >= 5.1.0, PHP 7, PHP 8, PHP 8,PECL pdo >= 0.1 .0)
PDO::prepare — Prepare the statement to be executed and return the statement object
Description
public PDO::prepare(string $statement, array $driver_options = array()): PDOStatement
Prepare the statement to be executed for the PDOStatement::execute() method SQL statement. A statement template can contain zero or more parameter placeholder markers, in the form of names (:name) or question marks (?), which will be replaced with real data when it is executed. In the same statement template, the named form and question mark form cannot be used at the same time; only one of the parameter forms can be selected. Please use parameter form to bind the data entered by the user, and do not directly splice string strings into the query.
When calling PDOStatement::execute(), the parameter placeholder mark of each value must have a unique name. Unless simulation mode is enabled, parameters with the same name cannot be used in the same statement.
Note:
Parameter placeholders can only display complete data literally. It cannot be part of a literal, a keyword, an identifier, or any other arbitrary scope. For example: You cannot bind multiple values to a single parameter and then use IN() query in the SQL statement.
If you use different parameters and call the same SQL statement multiple times through PDO::prepare() and PDOStatement::execute(), the performance of the application will be improved - the driver can allow the client/server to cache the query and Meta information. At the same time, calling PDO::prepare() and PDOStatement::execute() can also prevent SQL injection attacks without manually quoting and escaping parameters.
If the built-in driver does not support parameters, PDO will simulate the function of parameters; if the driver only supports one of the styles (named parameters and question mark parameters), it will automatically rewrite to the other style.
注意: The parser used for emulated prepared statements and for rewriting named or question mark style parameters supports the non standard backslash escapes for single- and double quotes. That means that terminating quotes immediately preceeded by a backslash are not recognized as such, which may result in wrong detection of parameters causing the prepared statement to fail when it is executed. A work-around is to not use emulated prepares for such SQL queries, and to avoid rewriting of parameters by using a parameter style which is natively supported by the driver.
Parameters
statement
must be a valid SQL statement template for the target database server.
driver_options
The array contains one or more key=>value key-value pairs that set properties for the returned PDOStatement object. Common usage is: setting PDO::ATTR_CURSOR to PDO::CURSOR_SCROLL will get a scrollable cursor. Some drivers have driver-level options that are set during prepare.
Return value
If the database server completes preparing the statement, PDO::prepare() returns the PDOStatement object. If the database server cannot prepare the statement, PDO::prepare() returns false or throws PDOException (depending on the error handler).
Note:
The prepare statement in simulation mode does not interact with the database server, so PDO::prepare() will not check the statement.
Example
Example#1 SQL statement template in the form of named parameters
<?php /* 传入数组的值,并执行准备好的语句 */ $sql = 'SELECT name, colour, calories FROM fruit WHERE calories < :calories AND colour = :colour'; $sth = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY)); $sth->execute(array(':calories' => 150, ':colour' => 'red')); $red = $sth->fetchAll(); $sth->execute(array(':calories' => 175, ':colour' => 'yellow')); $yellow = $sth->fetchAll(); ?>
Example#2 SQL statement template in the form of question mark
<?php /* 传入数组的值,并执行准备好的语句 */ $sth = $dbh->prepare('SELECT name, colour, calories FROM fruit WHERE calories < ? AND colour = ?'); $sth->execute(array(150, 'red')); $red = $sth->fetchAll(); $sth->execute(array(175, 'yellow')); $yellow = $sth->fetchAll(); ?>
Recommended study: " PHP video tutorial》
The above is the detailed content of What is the usage of php prepare. For more information, please follow other related articles on the PHP Chinese website!