pg_select
(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)
pg_select — Wählt Datensätze aus
Beschreibung
Falls flags gesetzt ist, wird
pg_convert() mit den angegebenen Flags auf
conditions angewendet.
Wenn mode gesetzt ist, ist der Rückgabewert bei
PGSQL_NUM ein Array, bei
PGSQL_ASSOC (Standard) ein assoziatives Array und bei
PGSQL_BOTH beides.
Standardmäßig übergibt pg_select() Rohwerte. Die Werte
müssen entweder maskiert werden oder es muss die Option PGSQL_DML_ESCAPE
angegeben werden. PGSQL_DML_ESCAPE maskiert Parameter und Bezeichner und
setzt sie in Anführungszeichen. Daher muss bei Tabellen- und Spaltennamen
zwischen Groß- und Kleinschreibung unterschieden werden.
Es ist zu beachten, dass weder die Maskierung noch eine vorbereitete
Abfrage LIKE-Abfragen, JSON, Array, Regex usw. schützen können. Diese
Parameter sollten im Kontext behandelt werden, d. h. Werte maskieren und
validieren.
Parameter-Liste
connection
-
Eine PgSql\Connection-Instanz.
table_name
-
Der Name der Tabelle, aus der die Datensätze ausgewählt werden.
conditions
-
Ein Array, dessen Schlüssel Feldnamen von
table_name sind und dessen Werte mit den
entsprechenden Werten in table_name
übereinstimmen müssen, damit der Datensatz zurückgegeben werden kann.
Seit PHP 8.4.0 gelten keine Bedingungen mehr, wenn ein leeres Array
angegeben wird.
Zuvor schlug die Funktion fehl, wenn das Argument für
conditions leer war.
flags
-
Eine beliebige Kombination aus
PGSQL_CONV_FORCE_NULL,
PGSQL_DML_NO_CONV,
PGSQL_DML_ESCAPE,
PGSQL_DML_EXEC,
PGSQL_DML_ASYNC und
PGSQL_DML_STRING. Falls
PGSQL_DML_STRING in den
options enthalten ist, wird der Abfragestring
zurückgegeben. Werden PGSQL_DML_NO_CONV oder
PGSQL_DML_ESCAPE angegeben, wird
pg_convert() intern nicht aufgerufen.
mode
-
Eine beliebige Kombination aus PGSQL_ASSOC,
PGSQL_NUM und PGSQL_BOTH.
Wenn PGSQL_ASSOC gesetzt ist, ist der Rückgabewert
ein assoziatives Array, bei PGSQL_NUM
ist es ein Array, und bei PGSQL_BOTH
ist es ein sowohl assoziativ als auch numerisch indiziertes
Array.
Rückgabewerte
Gibt einen String zurück, falls
PGSQL_DML_STRING im Parameter
flags übergeben wurde, andernfalls wird bei Erfolg
ein Array zurückgegeben. Bei einem Fehler wird false zurückgegeben.
Beispiele
Beispiel #1 pg_select()-Beispiel
<?php
$db = pg_connect('dbname=foo');
// Das ist einigermaßen sicher, da alle Werte maskiert werden.
// Allerdings unterstützt PostgreSQL JSON/Array. Diese sind nicht
// sicher, da sie Abfragen weder maskieren noch vorbereiten.
$rec = pg_select($db, 'post_log', $_POST, PG_DML_ESCAPE);
if ($rec) {
echo "Datensätze ausgewählt\n";
var_dump($rec);
} else {
echo "Falsche Eingabe\n";
}
?>
Siehe auch
- pg_convert() - Konvertiert die Werte eines assoziativen Arrays in die für SQL-Anweisungen
passende Form