1
0
mirror of https://github.com/php/doc-fr.git synced 2026-03-24 07:02:06 +01:00
Files
archived-doc-fr/reference/pgsql/functions/pg-select.xml

211 lines
7.3 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 18aa2012f6fa1e5b09733147e02911d16e06d4a1 Maintainer: yannick Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.pg-select" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>pg_select</refname>
<refpurpose>
Effectue une sélection PostgreSQL
</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type class="union"><type>array</type><type>string</type><type>false</type></type><methodname>pg_select</methodname>
<methodparam><type>PgSql\Connection</type><parameter>connection</parameter></methodparam>
<methodparam><type>string</type><parameter>table_name</parameter></methodparam>
<methodparam choice="opt"><type>array</type><parameter>conditions</parameter><initializer>[]</initializer></methodparam>
<methodparam choice="opt"><type>int</type><parameter>flags</parameter><initializer><constant>PGSQL_DML_EXEC</constant></initializer></methodparam>
<methodparam choice="opt"><type>int</type><parameter>mode</parameter><initializer><constant>PGSQL_ASSOC</constant></initializer></methodparam>
</methodsynopsis>
<para>
<function>pg_select</function> sélectionne les enregistrements par
<parameter>conditions</parameter> qui est au format
<literal>field=&gt;value</literal>. Lorsque la requête réussit,
elle retourne un tableau contenant tous les enregistrements et champs qui
vérifient la condition spécifiée par <parameter>conditions</parameter>.
</para>
<para>
Si <parameter>flags</parameter> est spécifié,
<function>pg_convert</function> est appliqué à
<parameter>values</parameter> avec les drapeaux fournis.
</para>
<para>
Si le paramètre <parameter>mode</parameter> est défini,
la valeur de retour sera sous la forme d'un tableau indexé
avec <constant>PGSQL_NUM</constant>,
un tableau associatif avec <constant>PGSQL_ASSOC</constant> (par défaut),
ou les deux avec <constant>PGSQL_BOTH</constant>.
</para>
<para>
Par défaut <function>pg_delete</function> passe des valeurs brutes. Les valeurs
doivent être échappées ou l'option PGSQL_DML_ESCAPE doit être fournie.
PGSQL_DML_ESCAPE met des guillemets et échappe les paramètres/identifiants.
Par conséquent, les noms de table/colonnes doivent être sensibles à la casse.
</para>
<para>
Il est à noter que ni l'échappement ni les requêtes préparées peuvent protéger des
requêtes LIKE, JSON, Tableaux, Regex, etc. Ces paramètres devraient être
traités en fonction de leur contexte. C'est-à-dire échapper/valider les valeurs.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>connection</parameter></term>
<listitem>
&pgsql.parameter.connection;
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>table_name</parameter></term>
<listitem>
<para>
Nom de la table à partir de laquelle sélectionner les lignes.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>conditions</parameter></term>
<listitem>
<para>
Un <type>array</type> dont les clés sont les noms des champs dans la table <parameter>table_name</parameter>,
et dont les valeurs sont les conditions qu'une ligne doit remplir pour être récupérée.
À partir de PHP 8.4.0, lorsqu'un tableau vide est fourni, aucune condition ne sera appliquée.
Auparavant, la fonction échouait avec un argument <parameter>conditions</parameter> vide.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>flags</parameter></term>
<listitem>
<para>
Un nombre quelconque de <constant>PGSQL_CONV_FORCE_NULL</constant>,
<constant>PGSQL_DML_NO_CONV</constant>,
<constant>PGSQL_DML_ESCAPE</constant>,
<constant>PGSQL_DML_EXEC</constant>,
<constant>PGSQL_DML_ASYNC</constant> ou
<constant>PGSQL_DML_STRING</constant> combinés. Si <constant>PGSQL_DML_STRING</constant> fait partie des
<parameter>flags</parameter>, alors la chaîne de requête est renvoyée. Lorsque <constant>PGSQL_DML_NO_CONV</constant>
ou <constant>PGSQL_DML_ESCAPE</constant> est activé, <function>pg_convert</function> n'est pas appelée en interne.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>mode</parameter></term>
<listitem>
<para>
Un nombre quelconque de <constant>PGSQL_ASSOC</constant>,
<constant>PGSQL_NUM</constant> ou
<constant>PGSQL_BOTH</constant>.
Si <constant>PGSQL_ASSOC</constant> est défini, la valeur de retour sera un <type>array</type> associatif,
avec <constant>PGSQL_NUM</constant>, la valeur de retour sera un <type>array</type> indexé numériquement, et
avec <constant>PGSQL_BOTH</constant>, la valeur de retour sera à la fois un <type>array</type> associatif et
numériquement indexé.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Retourne une <type>string</type> si <constant>PGSQL_DML_STRING</constant>
est fourni via <parameter>flags</parameter>, sinon ceci retourne un
<type>array</type> en cas de succès, &return.falseforfailure;.
</para>
</refsect1>
<refsect1 role="changelog">
&reftitle.changelog;
<para>
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>8.4.0</entry>
<entry>
<parameter>conditions</parameter> est désormais optionnel.
</entry>
</row>
&pgsql.changelog.connection-object;
<row>
<entry>7.1.0</entry>
<entry>
Le paramètre <parameter>mode</parameter> a été ajouté.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Exemple avec <function>pg_select</function></title>
<programlisting role="php">
<![CDATA[
<?php
$db = pg_connect ('dbname=foo');
// Ceci est sûr quelque peu, car toutes les valeurs sont échappées
// Cependant PostgreSQL supporte les JSON/Tableaux. Ceci ne sont pas
// sûr ni par échappement ni par les requêtes préparés.
$rec = pg_select($db, 'post_log', $_POST, PG_DML_ESCAPE);
if ($rec) {
echo "Lignes lues\n";
var_dump($rec);
} else {
echo "Problème dans les données utilisateur\n";
}
?>
]]>
</programlisting>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>pg_convert</function></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->