Linux and UNIX Man Pages

Linux & Unix Commands - Search Man Pages

pg_query_params(3) [php man page]

PG_QUERY_PARAMS(3)														PG_QUERY_PARAMS(3)

pg_query_params  -  Submits  a command to the server and waits for the result, with the ability to pass parameters separately from the SQL command
text.

SYNOPSIS
resource pg_query_params ([resource $connection], string $query, array $params) DESCRIPTION
Submits a command to the server and waits for the result, with the ability to pass parameters separately from the SQL command text. pg_query_params(3) is like pg_query(3), but offers additional functionality: parameter values can be specified separately from the command string proper. pg_query_params(3) is supported only against PostgreSQL 7.4 or higher connections; it will fail when using earlier versions. If parameters are used, they are referred to in the $query string as $1, $2, etc. The same parameter may appear more than once in the $query; the same value will be used in that case. $params specifies the actual values of the parameters. A NULL value in this array means the corresponding parameter is SQL NULL. The primary advantage of pg_query_params(3) over pg_query(3) is that parameter values may be separated from the $query string, thus avoid- ing the need for tedious and error-prone quoting and escaping. Unlike pg_query(3), pg_query_params(3) allows at most one SQL command in the given string. (There can be semicolons in it, but not more than one nonempty command.) PARAMETERS
o $connection - PostgreSQL database connection resource. When $connection is not present, the default connection is used. The default connection is the last connection made by pg_connect(3) or pg_pconnect(3). o $query - The parameterized SQL statement. Must contain only a single statement. (multiple statements separated by semi-colons are not allowed.) If any parameters are used, they are referred to as $1, $2, etc. User-supplied values should always be passed as param- eters, not interpolated into the query string, where they form possible SQL injection attack vectors and introduce bugs when han- dling data containing quotes. If for some reason you cannot use a parameter, ensure that interpolated values are properly escaped. o $params - An array of parameter values to substitute for the $1, $2, etc. placeholders in the original prepared query string. The number of elements in the array must match the number of placeholders. Values intended for bytea fields are not supported as parameters. Use pg_escape_bytea(3) instead, or use the large object functions. RETURN VALUES
A query result resource on success or FALSE on failure. EXAMPLES
Example #1 Using pg_query_params(3) <?php // Connect to a database named "mary" $dbconn = pg_connect("dbname=mary"); // Find all shops named Joe's Widgets. Note that it is not necessary to // escape "Joe's Widgets" $result = pg_query_params($dbconn, 'SELECT * FROM shops WHERE name = $1', array("Joe's Widgets")); // Compare against just using pg_query $str = pg_escape_string("Joe's Widgets"); $result = pg_query($dbconn, "SELECT * FROM shops WHERE name = '{$str}'"); ?> SEE ALSO
pg_query(3). PHP Documentation Group PG_QUERY_PARAMS(3)

Check Out this Related Man Page

PG_ESCAPE_STRING(3)													       PG_ESCAPE_STRING(3)

pg_escape_string - Escape a string for query

SYNOPSIS
string pg_escape_string ([resource $connection], string $data) DESCRIPTION
pg_escape_string(3) escapes a string for querying the database. It returns an escaped string in the PostgreSQL format without quotes. pg_escape_literal(3) is more preferred way to escape SQL parameters for PostgreSQL. addslashes(3) must not be used with PostgreSQL. If the type of the column is bytea, pg_escape_bytea(3) must be used instead. pg_escape_identifier(3) must be used to escape identifiers (e.g. ta- ble names, field names) Note This function requires PostgreSQL 7.2 or later. PARAMETERS
o $connection - PostgreSQL database connection resource. When $connection is not present, the default connection is used. The default connection is the last connection made by pg_connect(3) or pg_pconnect(3). o $data - A string containing text to be escaped. RETURN VALUES
A string containing the escaped data. CHANGELOG
+--------+-------------------+ |Version | | | | | | | Description | | | | +--------+-------------------+ | 5.2.0 | | | | | | | $connection added | | | | +--------+-------------------+ EXAMPLES
Example #1 pg_escape_string(3) example <?php // Connect to the database $dbconn = pg_connect('dbname=foo'); // Read in a text file (containing apostrophes and backslashes) $data = file_get_contents('letter.txt'); // Escape the text data $escaped = pg_escape_string($data); // Insert it into the database pg_query("INSERT INTO correspondence (name, data) VALUES ('My letter', '{$escaped}')"); ?> SEE ALSO
pg_escape_bytea(3). PHP Documentation Group PG_ESCAPE_STRING(3)
Man Page