Zend_Db_Select.xml 55 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 13846 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.select">
  5. <title>Zend_Db_Select</title>
  6. <sect2 id="zend.db.select.introduction">
  7. <title>Introduction</title>
  8. <para>L'objet <classname>Zend_Db_Select</classname> représente une instruction de requête SQL de type <code>SELECT</code>.
  9. La classe a des méthodes pour ajouter différentes parties à la requête. Vous pouvez indiquer quelques parties de
  10. la requête en utilisant des structures de données et des méthodes de PHP, et la classe forme la syntaxe correcte
  11. de SQL pour vous. Après avoir construit une requête, vous pouvez l'exécuter comme si vous l'aviez écrite comme
  12. une chaîne de caractères.</para>
  13. <para>Les possibilités offertes par <classname>Zend_Db_Select</classname> inclut :</para>
  14. <itemizedlist>
  15. <listitem>
  16. <para>des méthodes orientées objet pour spécifier des requêtes SQL morceau par morceau ;</para>
  17. </listitem>
  18. <listitem>
  19. <para>l'abstraction de certaines parties de la requête SQL indépendamment de la base de données ;</para>
  20. </listitem>
  21. <listitem>
  22. <para>l'échappement automatique des identificateurs de méta-données dans la plupart des cas, pour
  23. supporter les identificateurs contenant les mots réservés SQL et les caractères spéciaux ;</para>
  24. </listitem>
  25. <listitem>
  26. <para>l'échappement des identificateurs et des valeurs, afin de réduire les risques d'attaques par
  27. injection SQL.</para>
  28. </listitem>
  29. </itemizedlist>
  30. <para>L'utilisation de <classname>Zend_Db_Select</classname> n'est pas obligatoire. Pour de très simple requêtes SELECT ,
  31. il est d'habitude plus simple de spécifier la requête SQL entière comme une chaîne et l'exécuter en utilisant
  32. des méthodes de l'adaptateur comme <code>query()</code> ou <code>fetchAll()</code>. L'utilisation de
  33. <classname>Zend_Db_Select</classname> est utile si vous devez assembler une requête SELECT par procédure, ou basé sur une
  34. logique conditionnelle dans votre application.</para>
  35. </sect2>
  36. <sect2 id="zend.db.select.creating">
  37. <title>Créer un objet Select</title>
  38. <para>Vous pouvez créer une instance d'un objet <classname>Zend_Db_Select</classname> en utilisant la méthode
  39. <code>select()</code> de l'objet <classname>Zend_Db_Adapter_Abstract</classname>.</para>
  40. <example id="zend.db.select.creating.example-db">
  41. <title>Exemple d'utilisation de la méthode select()</title>
  42. <programlisting role="php"><![CDATA[
  43. $db = Zend_Db::factory( ...options... );
  44. $select = $db->select();
  45. ]]></programlisting>
  46. </example>
  47. <para>Une autre manière de créer un objet <classname>Zend_Db_Select</classname> est avec son constructeur, en indiquant
  48. l'adaptateur de base de données comme argument.</para>
  49. <example id="zend.db.select.creating.example-new">
  50. <title>Exemple de création d'un nouvel objet Select</title>
  51. <programlisting role="php"><![CDATA[
  52. $db = Zend_Db::factory( ...options... );
  53. $select = new Zend_Db_Select($db);
  54. ]]></programlisting>
  55. </example>
  56. </sect2>
  57. <sect2 id="zend.db.select.building">
  58. <title>Construction de requêtes Select</title>
  59. <para>En construisant la requête, vous pouvez ajouter des clauses à la requête une par une. Il y a une méthode
  60. séparée pour ajouter chaque clause à l'objet <classname>Zend_Db_Select</classname>.</para>
  61. <example id="zend.db.select.building.example">
  62. <title>Exemple d'utilisation des méthodes d'ajout de clauses</title>
  63. <programlisting role="php"><![CDATA[
  64. // Créer un objet Zend_Db_Select
  65. $select = $db->select();
  66. // Ajouter une clause FROM
  67. $select->from( ...spécifiez une table et des colonnes... )
  68. // Ajouter une clause WHERE
  69. $select->where( ...spécifiez des critères de recherche... )
  70. // Ajouter une clause ORDER BY
  71. $select->order( ...spécifiez des critères de tri... );
  72. ]]></programlisting>
  73. </example>
  74. <para>Vous pouvez également employer la plupart des méthodes de l'objet Zend_Db_Select avec une interface fluide
  75. et simple. Une <ulink url="http://en.wikipedia.org/wiki/Fluent_interface">interface fluide</ulink> signifie que
  76. chaque méthode renvoie une référence à l'objet qui a été appelé, ainsi vous pouvez immédiatement appeler une
  77. autre méthode.</para>
  78. <example id="zend.db.select.building.example-fluent">
  79. <title>Exemple d'utilisation de l'interface fluide</title>
  80. <programlisting role="php"><![CDATA[
  81. $select = $db->select()
  82. ->from( ...spécifiez une table et des colonnes... )
  83. ->where( ...spécifiez des critères de recherche... )
  84. ->order( ...spécifiez des critères de tri... );
  85. ]]></programlisting>
  86. </example>
  87. <para>Les exemples de cette section montrent l'utilisation de l'interface fluide, mais vous pouvez employer une
  88. interface non-fluide dans tous les cas. Il est souvent nécessaire d'employer l'interface non-fluide, par
  89. exemple, si votre application doit exécuter de la logique avant d'ajouter une clause à une requête.</para>
  90. <sect3 id="zend.db.select.building.from">
  91. <title>Ajouter une clause FROM</title>
  92. <para>Indiquez la table pour la requête en utilisant la méthode <code>from()</code>. Vous pouvez indiquer le
  93. nom de table comme une chaîne de caractères. <classname>Zend_Db_Select</classname> applique l'échappement des
  94. identificateurs autour du nom de table, ainsi vous pouvez employer les caractères spéciaux.</para>
  95. <example id="zend.db.select.building.from.example">
  96. <title>Exemple d'utilisation de la méthode <code>from()</code></title>
  97. <programlisting role="php"><![CDATA[
  98. // Construire cette requête :
  99. // SELECT *
  100. // FROM "produits"
  101. $select = $db->select()
  102. ->from( 'produits' );
  103. ]]></programlisting>
  104. </example>
  105. <para>Vous pouvez également indiquer le nom de corrélation (parfois appelé "l'alias de table") pour une
  106. table. Au lieu d'une chaîne de caractère simple, employez un tableau associatif faisant correspondre le nom
  107. de corrélation au nom de table. Dans d'autres clauses de la requête SQL, employez ce nom de corrélation. Si
  108. votre requête réalise des jointures sur plus d'une table, <classname>Zend_Db_Select</classname> produit des noms
  109. uniques de corrélation basés sur les noms de table, pour chaque table pour lesquelles vous n'indiquez pas le
  110. nom de corrélation.</para>
  111. <example id="zend.db.select.building.from.example-cname">
  112. <title>Exemple d'utilisation d'un alias de nom de table</title>
  113. <programlisting role="php"><![CDATA[
  114. // Construire cette requête :
  115. // SELECT p.*
  116. // FROM "produits" AS p
  117. $select = $db->select()
  118. ->from( array('p' => 'produits') );
  119. ]]></programlisting>
  120. </example>
  121. <para>Certaines marques de SGBDR supportent un spécificateur de schéma principal pour une table. Vous pouvez
  122. spécifiez un nom de table comme "<code>nomDuSchema.nomDeTable</code>", où <classname>Zend_Db_Select</classname>
  123. échappera chaque partie individuellement, ou vous pouvez spécifier le nom du schéma séparément. Un nom de
  124. schéma spécifié dans le nom de table sera prioritaire sur un schéma fourni séparément dans les cas où les
  125. deux seraient fournis.</para>
  126. <example id="zend.db.select.building.from.example-schema">
  127. <title>Exemple d'utilisation d'un nom de schéma</title>
  128. <programlisting role="php"><![CDATA[
  129. // Construire cette requête :
  130. // SELECT *
  131. // FROM "monschema"."produits"
  132. $select = $db->select()
  133. ->from( 'monschema.produits' );
  134. // ou
  135. $select = $db->select()
  136. ->from('produits', '*', 'monschema');
  137. ]]></programlisting>
  138. </example>
  139. </sect3>
  140. <sect3 id="zend.db.select.building.columns">
  141. <title>Ajouter des colonnes</title>
  142. <para>Dans le deuxième argument de la méthode <code>from()</code>, vous pouvez indiquer les colonnes à
  143. choisir parmi les tables respectives. Si vous n'indiquez aucune colonne, la valeur par défaut est
  144. "<code>*</code>", la caractère de remplacement SQL pour "toutes les colonnes".</para>
  145. <para>Vous pouvez énumérer les colonnes dans un tableau simple de chaîne de caractère, ou en tant que
  146. tableau associatif faisant correspondre l'alias de la colonne au nom de la colonne. Si vous avez seulement
  147. une colonne à requêter, et vous n'avez pas besoin d'indiquer un alias de colonne, vous pouvez l'énumérer
  148. comme une chaîne simple au lieu d'un tableau.</para>
  149. <para>Si vous passez un tableau comme argument pour les colonnes, aucune colonne pour la table
  150. correspondante ne sera inclus dans le jeu de résultat. Voir un <link
  151. linkend="zend.db.select.building.join.example-no-columns">exemple de code</link> sous la section concernant
  152. la méthode <code>join()</code>.</para>
  153. <para>Vous pouvez indiquer le nom de colonne en tant que "<code>aliasDeTable.nomDeColonne</code>".
  154. <classname>Zend_Db_Select</classname> échappera chaque partie individuellement. Si vous n'indiquez pas un nom d'alias
  155. pour une colonne, elle emploie le nom de corrélation de la table nommée dans la méthode courante
  156. <code>from()</code>.</para>
  157. <example id="zend.db.select.building.columns.example">
  158. <title>Exemples de spécification de colonnes</title>
  159. <programlisting role="php"><![CDATA[
  160. // Construire cette requête :
  161. // SELECT p."produit_id", p."produit_nom"
  162. // FROM "produits" AS p
  163. $select = $db->select()
  164. ->from(array('p' => 'produits'),
  165. array('produit_id', 'produit_nom'));
  166. // Construire la même requête, en spécifiant l'alias de table :
  167. // SELECT p."produit_id", p."produit_nom"
  168. // FROM "produits" AS p
  169. $select = $db->select()
  170. ->from(array('p' => 'produits'),
  171. array('p.produit_id', 'p.produit_nom'));
  172. // Construire cette requête avec un alias pour une colonne :
  173. // SELECT p."produit_id" AS prodno, p."produit_nom"
  174. // FROM "produits" AS p
  175. $select = $db->select()
  176. ->from(array('p' => 'produits'),
  177. array('prodno' => 'produit_id', 'produit_nom'));
  178. ]]></programlisting>
  179. </example>
  180. </sect3>
  181. <sect3 id="zend.db.select.building.columns-expr">
  182. <title>Ajouter une expression de colonne</title>
  183. <para>Les colonnes dans les requêtes SQL sont parfois des expressions, pas simplement des noms de colonnes
  184. d'une table. Les expressions peuvent avoir des noms d'alias ou peuvent nécessiter d'être échappées. Si la
  185. chaîne de caractère désignant votre colonne contient des parenthèses, <classname>Zend_Db_Select</classname> la
  186. reconnaît comme une expression.</para>
  187. <para>Vous pouvez aussi créer un objet de type <classname>Zend_Db_Expr</classname> explicitement, pour éviter qu'une
  188. chaîne soit traitée comme un nom de colonne. <classname>Zend_Db_Expr</classname> est une classe minimale qui contient
  189. une unique chaîne de caractère. <classname>Zend_Db_Select</classname> reconnaît les objets de type
  190. <classname>Zend_Db_Expr</classname> et les convertit en chaînes de caractères, mais n'applique aucun changement, tel
  191. qu'un échappement ou un alias.</para>
  192. <note>
  193. <para>Utiliser <classname>Zend_Db_Expr</classname> pour les noms de colonnes n'est pas nécessaire si votre
  194. expression de colonne contient des parenthèses ; <classname>Zend_Db_Select</classname> reconnaît les parenthèses
  195. et traite la chaîne comme une expression en omettant l'échappement et les alias.</para>
  196. </note>
  197. <example id="zend.db.select.building.columns-expr.example">
  198. <title>Exemples d'utilisation de colonnes contenant des expressions</title>
  199. <programlisting role="php"><![CDATA[
  200. // Construire cette requête :
  201. // SELECT p."produit_id", LOWER(produit_nom)
  202. // FROM "produits" AS p
  203. // Une expression avec parenthèses devient implicitement
  204. // un objet Zend_Db_Expr.
  205. $select = $db->select()
  206. ->from(array('p' => 'produits'),
  207. array('produit_id', 'LOWER(produit_nom)'));
  208. // Construire cette requête :
  209. // SELECT p."produit_id", (p.prix * 1.08) AS prix_avec_taxe
  210. // FROM "produits" AS p
  211. $select = $db->select()
  212. ->from(array('p' => 'produits'),
  213. array('produit_id',
  214. 'prix_avec_taxe' => '(p.prix * 1.08)'));
  215. // Construire cette requête en utilisant explicitement Zend_Db_Expr :
  216. // SELECT p."produit_id", p.prix * 1.08 AS prix_avec_taxe
  217. // FROM "produits" AS p
  218. $select = $db->select()
  219. ->from(array('p' => 'produits'),
  220. array('produit_id',
  221. 'prix_avec_taxe' =>
  222. new Zend_Db_Expr('p.prix * 1.08')));
  223. ]]></programlisting>
  224. </example>
  225. <para>Dans les cas ci-dessus, <classname>Zend_Db_Select</classname> ne change pas la chaîne pour appliquer des alias
  226. ou échapper les identificateurs. Si ces changements sont nécessaires pour résoudre l'ambiguïté, vous devez
  227. faire manuellement les changements dans la chaîne de caractères.</para>
  228. <para>Si vos noms de colonne sont des mots-clés de SQL ou contiennent les caractères spéciaux, vous devriez
  229. employer la méthode <code>quoteIdentifier()</code> de l'adaptateur et interpoler le résultat dans la chaîne
  230. de caractères. La méthode <code>quoteIdentifier()</code> utilise l'échappement SQL pour délimiter les
  231. identificateurs, qui indique clairement que c'est un identificateur pour une table ou une colonne, et non
  232. n'importe quelle autre partie de la syntaxe de SQL.</para>
  233. <para>Votre code est plus indépendant du SGBDR si vous utilisez la méthode <code>quoteIdentifier()</code> au
  234. lieu d'échapper littéralement dans votre chaîne, car quelques marques de SGBDR utilisent des symboles non
  235. standards pour échapper les identificateurs. La méthode <code>quoteIdentifier()</code> est conçue pour
  236. utiliser le symbole d'échappement approprié basé sur le type d'adaptateur. La méthode
  237. <code>quoteIdentifier()</code> échappe aussi tout caractère d'échappement qui apparaissent dans
  238. l'identificateur lui-même.</para>
  239. <example id="zend.db.select.building.columns-quoteid.example">
  240. <title>Exemples d'échappement de colonnes dans une expression</title>
  241. <programlisting role="php"><![CDATA[
  242. // Construire cette requête, en échappant une colonne spéciale
  243. // nommée "from" dans une expression :
  244. // SELECT p."from" + 10 AS origine
  245. // FROM "produits" AS p
  246. $select = $db->select()
  247. ->from(array('p' => 'produits'),
  248. array('origine' => '(p.'
  249. . $db->quoteIdentifier('from')
  250. . ' + 10)'));
  251. ]]></programlisting>
  252. </example>
  253. </sect3>
  254. <sect3 id="zend.db.select.building.columns-atomic">
  255. <title>Ajouter des colonnes à une table FROM ou JOIN existante</title>
  256. <para>Il peut y avoir des cas où vous souhaitez ajouter des colonnes à une table FROM ou JOIN existante
  257. après que ces méthodes aient été appelées. La méthode <code>columns()</code> vous permet d'ajouter des
  258. colonnes spécifiques à n'importe quel moment avant que la requête ne soit exécutée. Vous pouvez fournir les
  259. colonnes en tant qu'une chaîne de caractères, une <classname>Zend_Db_Expr</classname> ou un tableau de ces derniers.
  260. Le second argument de cette méthode peut être omis, impliquant que les colonnes sont ajoutées à la table
  261. FROM, sinon un alias déjà défini doit être utilisé.</para>
  262. <example id="zend.db.select.building.columns-atomic.example">
  263. <title>Exemples d'ajout de colonnes avec la méthode <code>columns()</code></title>
  264. <programlisting role="php"><![CDATA[
  265. // Construire cette requête :
  266. // SELECT p."produit_id", p."produit_nom"
  267. // FROM "produits" AS p
  268. $select = $db->select()
  269. ->from(array('p' => 'produits'), 'produit_id')
  270. ->columns('produit_nom');
  271. // Construire la même requête, en spécifiant l'alias :
  272. // SELECT p."produit_id", p."produit_nom"
  273. // FROM "produits" AS p
  274. $select = $db->select()
  275. ->from(array('p' => 'produits'), 'p.produit_id')
  276. ->columns('produit_nom', 'p');
  277. // Ou alternativement columns('p.produit_nom')
  278. ]]></programlisting>
  279. </example>
  280. </sect3>
  281. <sect3 id="zend.db.select.building.join">
  282. <title>Ajouter une autre table à la requête avec JOIN</title>
  283. <para>Beaucoup de requêtes utiles impliquent l'utilisation de <code>JOIN</code> pour combiner les lignes
  284. issues de tables multiples. Vous pouvez ajouter des tables à une requête en utilisant la méthode
  285. <code>join()</code>. L'utilisation de cette méthode est similaire à la méthode <code>from()</code>, excepté
  286. que vous pouvez aussi spécifier une condition join dans la plupart des cas.</para>
  287. <example id="zend.db.select.building.join.example">
  288. <title>Exemple d'utilisation de la méthode join()</title>
  289. <programlisting role="php"><![CDATA[
  290. // Construire cette requête :
  291. // SELECT p."produit_id", p."produit_nom", l.*
  292. // FROM "produits" AS p JOIN "ligne_items" AS l
  293. // ON p.produit_id = l.produit_id
  294. $select = $db->select()
  295. ->from(array('p' => 'produits'),
  296. array('produit_id', 'produit_nom'))
  297. ->join(array('l' => 'ligne_items'),
  298. 'p.produit_id = l.produit_id');
  299. ]]></programlisting>
  300. </example>
  301. <para>Le deuxième argument de <code>join()</code> est une chaîne qui représente la condition join. C'est une
  302. expression qui déclare les critères par lesquels les lignes d'une table correspondent aux lignes dans une
  303. autre table. Vous pouvez utiliser un nom d'alias dans cette expression.</para>
  304. <note>
  305. <para>Aucun échappement n'est appliqué à une expression que vous spécifiez pour une condition join ; si
  306. vous avez des noms de colonnes qui nécessitent d'être échappées, vous devez utiliser
  307. <code>quoteIdentifier()</code> quand vous préparez la chaîne pour une condition join.</para>
  308. </note>
  309. <para>Le troisième argument de <code>join()</code> est un tableau des noms de colonnes, comme c'est utilisé
  310. dans la méthode <code>from()</code>. La valeur par défaut est "<code>*</code>", la méthode supporte les
  311. alias, les expressions, et les objets <classname>Zend_Db_Expr</classname> de la même manière que le tableau de noms de
  312. colonnes de la méthode <code>from()</code>.</para>
  313. <para>Pour ne choisir aucune colonne à partir d'une table, utilisez un tableau vide pour la liste de
  314. colonnes. Cette utilisation fonctionnerait aussi avec la méthode <code>from()</code>, mais typiquement vous
  315. pouvez avoir besoin de colonnes issues de la table primaire dans vos requêtes, tandis que vous pourriez ne
  316. vouloir aucune colonne de la table jointe.</para>
  317. <example id="zend.db.select.building.join.example-no-columns">
  318. <title>Exemple avec aucune colonne spécifiée</title>
  319. <programlisting role="php"><![CDATA[
  320. // Construire cette requête :
  321. // SELECT p."produit_id", p."produit_nom"
  322. // FROM "produits" AS p JOIN "ligne_items" AS l
  323. // ON p.produit_id = l.produit_id
  324. $select = $db->select()
  325. ->from(array('p' => 'produits'),
  326. array('produit_id', 'produit_name'))
  327. ->join(array('l' => 'ligne_items'),
  328. 'p.produit_id = l.produit_id',
  329. array() ); // liste de colonnes vide
  330. ]]></programlisting>
  331. <para>Notez le tableau vide (<code>array()</code>) dans l'exemple ci-dessus à la place de la liste de
  332. colonnes de la table jointe.</para>
  333. </example>
  334. <para>Le SQL a plusieurs types de jointures. Voyez la liste ci-dessous des méthodes supportant les
  335. différents types de jointures dans <classname>Zend_Db_Select</classname>.</para>
  336. <itemizedlist>
  337. <listitem>
  338. <para><command>INNER JOIN</command> avec les méthodes <code>join(table, jointure, [colonnes])</code>
  339. ou <code>joinInner(table, jointure, [colonnes])</code>.</para>
  340. <para>Ceci est le type de jointure le plus commun. Les lignes de chaque table sont comparées en
  341. utilisant la condition join spécifiée. Le résultat inclut seulement les lignes qui vérifient la
  342. condition join. Le résultat peut être vide si aucune ligne ne satisfait la condition.</para>
  343. <para>Tous les marques de SGBDR supportent ce type de jointure.</para>
  344. </listitem>
  345. <listitem>
  346. <para><command>LEFT JOIN</command> avec la méthode <code>joinLeft(table, condition,
  347. [colonnes])</code>.</para>
  348. <para>Toutes les lignes issues de la table opérande de gauche sont inclues, les lignes
  349. correspondantes de la table de droite sont inclues, et les colonnes de la table opérande de droite
  350. sont remplies de NULL si aucune ligne existante ne correspond à la table de gauche.</para>
  351. <para>Tous les marques de SGBDR supportent ce type de jointure.</para>
  352. </listitem>
  353. <listitem>
  354. <para><command>RIGHT JOIN</command> avec la méthode <code>joinRight(table, condition,
  355. [colonnes])</code>.</para>
  356. <para>La jointure étrangère droite est le complément de la jointure étrangère gauche. Toutes les
  357. lignes issues de la table opérande de droite sont inclues, les lignes correspondantes de la table de
  358. gauche sont inclues, et les colonnes de la table opérande de gauche sont remplies de NULL si aucune
  359. ligne existante ne correspond à la table de droite.</para>
  360. <para>Certaines marques de SGBDR ne supportent pas ce type de jointure, mais en général toute
  361. jointure droite peut être représentée comme une jointure gauche en inversant l'ordre des
  362. tables.</para>
  363. </listitem>
  364. <listitem>
  365. <para><command>FULL JOIN</command> avec la méthode <code>joinFull(table, condition,
  366. [colonnes])</code>.</para>
  367. <para>Une jointure étrangère complète est comme la combinaison d'une jointure étrangère gauche et
  368. d'une jointure étrangère droite. Toutes les lignes des deux tables sont inclues, appairées ensemble
  369. dans la même ligne de résultat si elles satisfont la condition de jointure, et sinon appairées avec
  370. des valeurs NULL à la place des colonnes de l'autre table.</para>
  371. <para>Certaines marques de SGBDR ne supportent pas ce type de jointure.</para>
  372. </listitem>
  373. <listitem>
  374. <para><command>CROSS JOIN</command> avec la méthode <code>joinCross(table,
  375. [colonnes])</code>.</para>
  376. <para>Une jointure croisée est un produit cartésien. Chaque ligne de la première table est assortie
  377. avec chaque ligne de la seconde. Ainsi le nombre de lignes du résultat est équivalent au produit du
  378. nombre de lignes de chacune des tables. Vous pouvez filtrer le résultat en utilisant une clause
  379. WHERE ; dans ce cas une jointure croisée est semblable à l'ancienne syntaxe de jointure
  380. SQL-89.</para>
  381. <para>La méthode <code>joinCross()</code> n'a pas de paramètres pour spécifier la condition de
  382. jointure. Certaines marques de SGBDR ne supportent pas ce type de jointure.</para>
  383. </listitem>
  384. <listitem>
  385. <para><command>NATURAL JOIN</command> avec la méthode <code>joinNatural(table,
  386. [colonnes])</code>.</para>
  387. <para>Une jointure naturelle compare chaque(s) colonne(s) qui apparaissent avec le même nom dans les
  388. deux tables. La comparaison est l'égalité pour toute(s) la(es) colonne(s) ; la comparaison des
  389. colonnes utilisant l'inégalité n'est pas une jointure naturelle. Seules les jointures internes (NdT
  390. : INNER) naturelles sont supportées par cette API, même si la syntaxe SQL permet aussi bien des
  391. jointures naturelles étrangères (NdT : OUTER).</para>
  392. <para>La méthode <code>joinNatural()</code> n'a pas de paramètres pour spécifier la condition de
  393. jointure.</para>
  394. </listitem>
  395. </itemizedlist>
  396. <para>En plus de ces méthodes join, vous pouvez simplifier vos requêtes en utilisant les méthodes de type
  397. <code>join*Using</code>. Au lieu de fournir une condition complète à votre jointure, vous fournissez
  398. simplement le nom de la colonne sur laquelle réaliser la jointure et l'objet <classname>Zend_Db_Select</classname>
  399. complète la condition pour vous.</para>
  400. <example id="zend.db.select.building.joinusing.example">
  401. <title>Exemple avec la méthode <code>joinUsing()</code></title>
  402. <programlisting role="php"><![CDATA[
  403. // Construire cette requête :
  404. // SELECT *
  405. // FROM "table1"
  406. // JOIN "table2"
  407. // ON "table1".colonne1 = "table2".colonne1
  408. // WHERE colonne2 = 'foo'
  409. $select = $db->select()
  410. ->from('table1')
  411. ->joinUsing('table2', 'colonne1')
  412. ->where('column2 = ?', 'foo');
  413. ]]></programlisting>
  414. </example>
  415. <para>Chacune des méthodes join applicables du composant <classname>Zend_Db_Select</classname> possède une méthode
  416. correspondante "using".</para>
  417. <itemizedlist>
  418. <listitem>
  419. <para><code>joinUsing(table, join, [columns])</code> et <code>joinInnerUsing(table, join,
  420. [columns])</code></para>
  421. </listitem>
  422. <listitem>
  423. <para><code>joinLeftUsing(table, join, [columns])</code></para>
  424. </listitem>
  425. <listitem>
  426. <para><code>joinRightUsing(table, join, [columns])</code></para>
  427. </listitem>
  428. <listitem>
  429. <para><code>joinFullUsing(table, join, [columns])</code></para>
  430. </listitem>
  431. </itemizedlist>
  432. </sect3>
  433. <sect3 id="zend.db.select.building.where">
  434. <title>Ajouter une clause WHERE</title>
  435. <para>Vous pouvez spécifier des critères pour restreindre le nombre de lignes du résultat en utilisant la
  436. méthode <code>where()</code>. Le premier argument de cette méthode est une expression SQL, et cette
  437. expression est utilisée dans une clause <code>WHERE</code> dans la requête.</para>
  438. <example id="zend.db.select.building.where.example">
  439. <title>Exemple d'utilisation de la méthode <code>where()</code></title>
  440. <programlisting role="php"><![CDATA[
  441. // Construire cette requête :
  442. // SELECT produit_id, produit_nom, prix
  443. // FROM "produits"
  444. // WHERE prix > 100.00
  445. $select = $db->select()
  446. ->from('produits',
  447. array('produit_id', 'produit_nom', 'prix'))
  448. ->where('prix > 100.00');
  449. ]]></programlisting>
  450. </example>
  451. <note>
  452. <para>Aucun échappement n'est appliqué aux expressions passées aux méthodes <code>where()</code> ou
  453. <code>orWhere()</code>. Si vous avez des noms de colonnes qui nécessitent d'être échappés, vous devez
  454. utiliser <code>quoteIdentifier()</code> quand vous générez la chaîne pour la condition.</para>
  455. </note>
  456. <para>Le second argument de la méthode <code>where()</code> est optionnel. C'est une valeur à substituer
  457. dans l'expression. <classname>Zend_Db_Select</classname> échappe cette valeur et la substitue au caractère point
  458. ("<code>?</code>") d'interrogation dans l'expression.</para>
  459. <para>Cette méthode accepte un seul paramètre. Si vous avez une expression dans laquelle vous devez
  460. substituer plusieurs variables, vous devez formater la chaîne manuellement, en interpolant les variables et
  461. en les échappant vous-même.</para>
  462. <example id="zend.db.select.building.where.example-param">
  463. <title>Exemple d'un paramètre dans la méthode <code>where()</code></title>
  464. <programlisting role="php"><![CDATA[
  465. // Construire cette requête :
  466. // SELECT produit_id, produit_nom, prix
  467. // FROM "produits"
  468. // WHERE (prix > 100.00)
  469. $prixminimum = 100;
  470. $select = $db->select()
  471. ->from('produits',
  472. array('produit_id', 'produit_nom', 'prix'))
  473. ->where('prix > ?', $prixminimum);
  474. ]]></programlisting>
  475. </example>
  476. <para>Vous pouvez appeler la méthode <code>where()</code> plusieurs fois sur la même objet
  477. <classname>Zend_Db_Select</classname>. La requête résultante combine les différents termes ensemble en utilisant
  478. <code>AND</code> entre eux.</para>
  479. <example id="zend.db.select.building.where.example-and">
  480. <title>Exemple avec plusieurs appels de <code>where()</code></title>
  481. <programlisting role="php"><![CDATA[
  482. // Construire cette requête :
  483. // SELECT produit_id, produit_nom, prix
  484. // FROM "produits"
  485. // WHERE (prix > 100.00)
  486. // AND (prix < 500.00)
  487. $prixminimum = 100;
  488. $prixmaximum = 500;
  489. $select = $db->select()
  490. ->from('produits',
  491. array('produit_id', 'produit_nom', 'prix'))
  492. ->where('prix > ?', $prixminimum)
  493. ->where('prix < ?', $prixmaximum);
  494. ]]></programlisting>
  495. </example>
  496. <para>Si vous devez combiner ensemble des termes en utilisant <code>OR</code>, utilisez la méthode
  497. <code>orWhere()</code>. Cette méthode est utilisée de la même manière que la méthode <code>where()</code>,
  498. excepté que le terme spécifié est précédé par <code>OR</code>, au lieu de <code>AND</code>.</para>
  499. <example id="zend.db.select.building.where.example-or">
  500. <title>Exemple d'utilisation de la méthode <code>orWhere()</code></title>
  501. <programlisting role="php"><![CDATA[
  502. // Construire cette requête :
  503. // SELECT produit_id, produit_nom, prix
  504. // FROM "produits"
  505. // WHERE (prix < 100.00)
  506. // OR (prix > 500.00)
  507. $prixminimum = 100;
  508. $prixmaximum = 500;
  509. $select = $db->select()
  510. ->from('produits',
  511. array('produit_id', 'produit_nom', 'prix'))
  512. ->where('prix < ?', $prixminimum)
  513. ->orWhere('prix > ?', $prixmaximum);
  514. ]]></programlisting>
  515. </example>
  516. <para><classname>Zend_Db_Select</classname> met automatiquement des parenthèses autour de chaque expression spécifiée
  517. en utilisant les méthodes <code>where()</code> ou <code>orWhere()</code>. Ceci permet de s'assurer que la
  518. priorité de l'opérateur booléen n'entraîne pas de résultats inattendus.</para>
  519. <example id="zend.db.select.building.where.example-parens">
  520. <title>Exemple de mise en parenthèse d'expressions booléennes</title>
  521. <programlisting role="php"><![CDATA[
  522. // Construire cette requête :
  523. // SELECT produit_id, produit_nom, prix
  524. // FROM "produits"
  525. // WHERE (prix < 100.00 OR prix > 500.00)
  526. // AND (produit_nom = 'Pomme')
  527. $prixminimum = 100;
  528. $prixmaximum = 500;
  529. $prod = 'Pomme';
  530. $select = $db->select()
  531. ->from('produits',
  532. array('produit_id', 'produit_nom', 'prix'))
  533. ->where("prix < $prixminimum OR prix > $prixmaximum")
  534. ->where('produit_nom = ?', $prod);
  535. ]]></programlisting>
  536. </example>
  537. <para>Dans l'exemple ci-dessus, le résultat serait tout à fait différent sans parenthèses, car
  538. <code>AND</code> a une plus grande priorité que <code>OR</code>. <classname>Zend_Db_Select</classname> applique les
  539. parenthèses avec pour effet de relier de manière plus étroite chaque expression dans les appels successifs
  540. de <code>where()</code> qu'avec <code>AND</code> qui combine les expressions.</para>
  541. </sect3>
  542. <sect3 id="zend.db.select.building.group">
  543. <title>Ajouter une clause GROUP BY</title>
  544. <para>Dans la syntaxe SQL, la clause <code>GROUP BY</code> vous permet de réduire le nombre de lignes du
  545. résultat de la requête à une ligne par valeur unique trouvé dans une(des) colonne(s) nommées) dans la clause
  546. <code>GROUP BY</code>.</para>
  547. <para>Dans <classname>Zend_Db_Select</classname>, vous pouvez spécifier la(es) colonne(s) à utiliser pour calculer les
  548. groupes de lignes en utilisant la méthode <code>group()</code>. L'argument de cette méthode est une colonne
  549. ou un tableau de colonnes à utiliser dans la clause <code>GROUP BY</code>.</para>
  550. <example id="zend.db.select.building.group.example">
  551. <title>Exemple d'utilisation de la méthode <code>group()</code></title>
  552. <programlisting role="php"><![CDATA[
  553. // Construire cette requête :
  554. // SELECT p."produit_id", COUNT(*) AS ligne_items_par_produit
  555. // FROM "produits" AS p JOIN "ligne_items" AS l
  556. // ON p.produit_id = l.produit_id
  557. // GROUP BY p.produit_id
  558. $select = $db->select()
  559. ->from(array('p' => 'produits'),
  560. array('produit_id'))
  561. ->join(array('l' => 'ligne_items'),
  562. 'p.produit_id = l.produit_id',
  563. array('ligne_items_par_produit' => 'COUNT(*)'))
  564. ->group('p.produit_id');
  565. ]]></programlisting>
  566. </example>
  567. <para>Comme le tableau de colonnes de la méthode <code>from()</code>, vous pouvez utiliser des noms d'alias
  568. dans le nom de la colonne, et la colonne est échappée comme un identificateur à moins que la chaîne ne
  569. contiennent des parenthèses ou que ce soit un objet de type <classname>Zend_Db_Expr</classname>.</para>
  570. </sect3>
  571. <sect3 id="zend.db.select.building.having">
  572. <title>Ajouter une clause HAVING</title>
  573. <para>Dans la syntaxe SQL, la clause <code>HAVING</code> applique une restriction sur un groupe de lignes.
  574. Ceci est similaire à la manière dont la clause <code>WHERE</code> applique une restriction sur des lignes.
  575. Mais les deux clauses sont différentes car les conditions <code>WHERE</code> sont appliquées avant que les
  576. groupes de lignes ne soient définis, alors que les conditions <code>HAVING</code> sont appliquées après que
  577. les groupes aient été définis.</para>
  578. <para>Dans <classname>Zend_Db_Select</classname>, vous pouvez spécifier des conditions pour restreindre des groupes en
  579. utilisant la méthode <code>having()</code>. Son utilisation est similaire à celle de la méthode
  580. <code>where()</code>. Le premier argument est une chaîne contenant une expression SQL. Le second argument
  581. facultatif est une valeur qui est utilisé pour remplacer le caractère de substitution positionné dans
  582. l'expression SQL. Les expressions passées dans de multiples appels de la méthode <code>having()</code> sont
  583. combinées en utilisant l'opérateur booléen <code>AND</code>, ou l'opérateur <code>OR</code> si vous utilisez
  584. la méthode <code>orHaving()</code>.</para>
  585. <example id="zend.db.select.building.having.example">
  586. <title>Exemple d'utilisation de la méthode <code>having()</code></title>
  587. <programlisting role="php"><![CDATA[
  588. // Construire cette requête :
  589. // SELECT p."produit_id", COUNT(*) AS ligne_items_par_produit
  590. // FROM "produits" AS p JOIN "ligne_items" AS l
  591. // ON p.produit_id = l.produit_id
  592. // GROUP BY p.produit_id
  593. // HAVING ligne_items_par_produit > 10
  594. $select = $db->select()
  595. ->from(array('p' => 'produits'),
  596. array('produit_id'))
  597. ->join(array('l' => 'ligne_items'),
  598. 'p.produit_id = l.produit_id',
  599. array('ligne_items_par_produit' => 'COUNT(*)'))
  600. ->group('p.produit_id')
  601. ->having('ligne_items_par_produit > 10');
  602. ]]></programlisting>
  603. </example>
  604. <note>
  605. <para>Aucun échappement n'est appliqué aux expressions fournies aux méthodes <code>having()</code> ou
  606. <code>orHaving()</code>. Si vous avez des noms de colonnes qui nécessitent d'être échappées, vous devez
  607. utiliser <code>quoteIdentifier()</code> quand vous générez la chaîne de cette condition.</para>
  608. </note>
  609. </sect3>
  610. <sect3 id="zend.db.select.building.order">
  611. <title>Ajouter une clause ORDER BY</title>
  612. <para>Dans la syntaxe SQL, la clause <code>ORDER BY</code> spécifie une ou plusieurs colonnes ou expressions
  613. suivant lesquelles le résultat d'une requête doit être trié. Si plusieurs colonnes sont listées, les
  614. colonnes secondaires sont utilisées pour résoudre les égalités ; l'ordre du tri est déterminé par les
  615. colonnes secondaires si les colonnes précédentes contiennent des valeurs identiques. Le tri par défaut est
  616. ascendant (du plus petit vers le plus grand). Vous pouvez aussi appliqué un tri descendant (du plus grand
  617. vers le plus petit) pour une colonne en spécifiant le mot-clé <code>DESC</code> après la colonne.</para>
  618. <para>Dans <classname>Zend_Db_Select</classname>, vous pouvez utiliser la méthode <code>order()</code> pour spécifier
  619. une colonne ou un tableau de colonnes par lesquelles vous voulez trier. Chaque élément du tableau est une
  620. chaîne nommant une colonne, facultativement suivi les mots-clés <code>ASC</code> ou <code>DESC</code> en
  621. séparant avec un espace.</para>
  622. <para>Comme pour les méthodes <code>from()</code> et <code>group()</code>, les noms de colonnes sont
  623. échappées comme des identificateurs, à moins qu'elles ne contiennent des parenthèses ou ne soient des objets
  624. de type <classname>Zend_Db_Expr</classname>.</para>
  625. <example id="zend.db.select.building.order.example">
  626. <title>Exemple d'utilisation de la méthode <code>order()</code></title>
  627. <programlisting role="php"><![CDATA[
  628. // Construire cette requête :
  629. // SELECT p."produit_id", COUNT(*) AS ligne_items_par_produit
  630. // FROM "produits" AS p JOIN "ligne_items" AS l
  631. // ON p.produit_id = l.produit_id
  632. // GROUP BY p.produit_id
  633. // ORDER BY "ligne_items_par_produit" DESC, "produit_id"
  634. $select = $db->select()
  635. ->from(array('p' => 'produits'),
  636. array('produit_id'))
  637. ->join(array('l' => 'ligne_items'),
  638. 'p.produit_id = l.produit_id',
  639. array('ligne_items_par_produit' => 'COUNT(*)'))
  640. ->group('p.produit_id')
  641. ->order(array('ligne_items_par_produit DESC',
  642. 'produit_id'));
  643. ]]></programlisting>
  644. </example>
  645. </sect3>
  646. <sect3 id="zend.db.select.building.limit">
  647. <title>Ajouter une clause LIMIT</title>
  648. <para>Certaines marques de SGBDR étendent la syntaxe SQL avec une clause <code>LIMIT</code>. Cette clause
  649. réduit le nombre de lignes d'un résultat à un nombre maximum que vous spécifiez. Vous pouvez de plus
  650. indiquer un nombre de lignes à éviter avant de commencer à produire le résultat. Cette fonctionnalité
  651. facilite l'extraction d'un sous-ensemble d'un résultat, par exemple quand vous affichez des résultats avec
  652. un défilement de pages.</para>
  653. <para>Dans <classname>Zend_Db_Select</classname>, vous pouvez utiliser la méthode <code>limit()</code> pour spécifier
  654. le nombre de lignes ainsi que le nombre de lignes à omettre. Le premier argument de cette méthode est le
  655. nombre de lignes désirées. Le second argument est le nombre de lignes à omettre.</para>
  656. <example id="zend.db.select.building.limit.example">
  657. <title>Exemple d'utilisation de la méthode <code>limit()</code></title>
  658. <programlisting role="php"><![CDATA[
  659. // Construire cette requête :
  660. // SELECT p."produit_id", p."produit_nom"
  661. // FROM "produits" AS p
  662. // LIMIT 10, 20
  663. $select = $db->select()
  664. ->from(array('p' => 'produits'),
  665. array('produit_id', 'produit_nom'))
  666. ->limit(10, 20);
  667. ]]></programlisting>
  668. </example>
  669. <note>
  670. <para>La syntaxe <code>LIMIT</code> n'est pas supporté par toutes les marques de SGBDR. Quelques SGBDR
  671. nécessite une syntaxe différente pour supporter une fonctionnalité similaire. Chaque classe
  672. <classname>Zend_Db_Adapter_Abstract</classname> inclue une méthode pour produire le code SQL approprié à ce
  673. SGBDR.</para>
  674. </note>
  675. <para>Utilisez de manière alternative la méthode <code>limitPage()</code> pour spécifier le nombre de lignes
  676. et le décalage. Cette méthode vous permet de limiter le jeu de résultats à une série d'un nombre fixé de
  677. résultats issus du jeu total de résultats de la requête. En d'autres termes, vous spécifiez la taille de la
  678. "page" de résultats, et le nombre ordinal de la page unique de résultats que vous souhaitez voir retourner
  679. par la requête. Le numéro de la page est le premier argument de la méthode <code>limitPage()</code>, et la
  680. taille de la page est le second argument. Les deux arguments sont obligatoires ; ils n'ont pas de valeurs
  681. par défaut.</para>
  682. <example id="zend.db.select.building.limit.example2">
  683. <title>Exemple d'utilisation de la méthode <code>limitPage()</code></title>
  684. <programlisting role="php"><![CDATA[
  685. // Construire cette requête :
  686. // SELECT p."product_id", p."product_name"
  687. // FROM "products" AS p
  688. // LIMIT 10, 20
  689. $select = $db->select()
  690. ->from(array('p' => 'products'),
  691. array('product_id', 'product_name'))
  692. ->limitPage(2, 10);
  693. ]]></programlisting>
  694. </example>
  695. </sect3>
  696. <sect3 id="zend.db.select.building.distinct">
  697. <title>Ajouter le modificateur de requête DISTINCT</title>
  698. <para>La méthode <code>distinct()</code> vous permet d'ajouter le mot-clé <code>DISTINCT</code> à votre
  699. requête SQL.</para>
  700. <example id="zend.db.select.building.distinct.example">
  701. <title>Exemple d'utilisation de la méthode <code>distinct()</code></title>
  702. <programlisting role="php"><![CDATA[
  703. // Construire cette requête :
  704. // SELECT DISTINCT p."produit_nom"
  705. // FROM "produits" AS p
  706. $select = $db->select()
  707. ->distinct()
  708. ->from(array('p' => 'produits'), 'produit_nom');
  709. ]]></programlisting>
  710. </example>
  711. </sect3>
  712. <sect3 id="zend.db.select.building.for-update">
  713. <title>Ajouter le modificateur de requête FOR UPDATE</title>
  714. <para>La méthode <code>forUpdate()</code> vous permet d'ajouter le modificateur <code>FOR UPDATE</code> à
  715. votre requête SQL.</para>
  716. <example id="zend.db.select.building.for-update.example">
  717. <title>Exemple d'utilisation de la méthode <code>forUpdate()</code></title>
  718. <programlisting role="php"><![CDATA[
  719. // Construire cette requête :
  720. // SELECT FOR UPDATE p.*
  721. // FROM "produits" AS p
  722. $select = $db->select()
  723. ->forUpdate()
  724. ->from(array('p' => 'produits'));
  725. ]]></programlisting>
  726. </example>
  727. </sect3>
  728. </sect2>
  729. <sect2 id="zend.db.select.execute">
  730. <title>Exécuter des requêtes Select</title>
  731. <para>Cette section décrit comment exécuter une requête représentée par un objet
  732. <classname>Zend_Db_Select</classname>.</para>
  733. <sect3 id="zend.db.select.execute.query-adapter">
  734. <title>Exécuter des requêtes Select à partir de l'adaptateur Db</title>
  735. <para>Vous pouvez exécuter la requête représentée par l'objet <classname>Zend_Db_Select</classname> en le passant
  736. comme premier argument de la méthode <code>query()</code> d'un objet <classname>Zend_Db_Adapter_Abstract</classname>.
  737. Utilisez les objets <classname>Zend_Db_Select</classname> plutôt qu'une simple chaîne de requête.</para>
  738. <para>La méthode <code>query()</code> retourne un objet de type <classname>Zend_Db_Statement</classname> ou
  739. <code>PDOStatement</code>, dépendant du type d'adaptateur.</para>
  740. <example id="zend.db.select.execute.query-adapter.example">
  741. <title>Exemple d'utilisation de la méthode <code>query()</code> de l'adaptateur Db</title>
  742. <programlisting role="php"><![CDATA[
  743. $select = $db->select()
  744. ->from('produits');
  745. $stmt = $db->query($select);
  746. $result = $stmt->fetchAll();
  747. ]]></programlisting>
  748. </example>
  749. </sect3>
  750. <sect3 id="zend.db.select.execute.query-select">
  751. <title>Exécuter des requêtes Select à partir de objet Select</title>
  752. <para>Comme alternative à l'emploi de la méthode <code>query()</code>de l'objet adaptateur, vous pouvez
  753. utiliser la méthode <code>query()</code> de l'objet <classname>Zend_Db_Select</classname>. Les deux méthodes retourne
  754. un objet de type <classname>Zend_Db_Statement</classname> ou <code>PDOStatement</code>, dépendant du type
  755. d'adaptateur.</para>
  756. <example id="zend.db.select.execute.query-select.example">
  757. <title>Exemple d'utilisation de la méthode query() de l'objet Select</title>
  758. <programlisting role="php"><![CDATA[
  759. $select = $db->select()
  760. ->from('produits');
  761. $stmt = $select->query();
  762. $result = $stmt->fetchAll();
  763. ]]></programlisting>
  764. </example>
  765. </sect3>
  766. <sect3 id="zend.db.select.execute.tostring">
  767. <title>Convertir un objet Select en une chaîne SQL</title>
  768. <para>Si vous devez accéder à la chaîne représentant la requête SQL correspondant à un objet
  769. <classname>Zend_Db_Select</classname>, utilisez la méthode <code>__toString()</code>.</para>
  770. <example id="zend.db.select.execute.tostring.example">
  771. <title>Exemple d'utilisation de la méthode <code>__toString()</code></title>
  772. <programlisting role="php"><![CDATA[
  773. $select = $db->select()
  774. ->from('produits');
  775. $sql = $select->__toString();
  776. echo "$sql\n";
  777. // L'affichage est la chaîne :
  778. // SELECT * FROM "produits"
  779. ]]></programlisting>
  780. </example>
  781. </sect3>
  782. </sect2>
  783. <sect2 id="zend.db.select.other">
  784. <title>Autres méthodes</title>
  785. <para>Cette section décrit les autres méthodes de la classe <classname>Zend_Db_Select</classname> qui ne sont pas
  786. couvertes ci-dessus : <code>getPart()</code> et <code>reset()</code>.</para>
  787. <sect3 id="zend.db.select.other.get-part">
  788. <title>Récupérer des parties de l'objet Select</title>
  789. <para>La méthode <code>getPart()</code> retourne une représentation d'une partie de votre requête SQL. Par
  790. exemple, vous pouvez utiliser cette méthode pour retourner un tableau d'expressions pour la clause
  791. <code>WHERE</code>, ou un tableau de colonnes (ou d'expressions de colonnes) qui sont dans l'élément
  792. <code>SELECT</code>, ou les valeurs de nombre et de décalage pour la clause <code>LIMIT</code>.</para>
  793. <para>La valeur retournée n'est pas une chaîne de caractère contenant un fragment de syntaxe SQL. La valeur
  794. retournée est une représentation interne, qui est typiquement une structure de type tableau contenant des
  795. valeurs et des expressions. Chaque partie de la requête a une structure différente.</para>
  796. <para>L'argument unique de la méthode <code>getPart()</code> est une chaîne qui identifie quelle partie de
  797. la requête Select doit être retournée. Par exemple, la chaîne "<code>from</code>" identifie la partie de
  798. l'objet Select qui stocke l'information concernant les tables dans la clause <code>FROM</code>, incluant les
  799. tables jointes.</para>
  800. <para>La classe Zend_Db_Select définit des constantes que vous pouvez utiliser pour les parties de la
  801. requête SQL. Vous pouvez utiliser ces constantes ou des chaînes de caractères littérales.</para>
  802. <table id="zend.db.select.other.get-part.table">
  803. <title>Constantes utilisées par <code>getPart()</code> et <code>reset()</code></title>
  804. <tgroup cols="2">
  805. <thead>
  806. <row>
  807. <entry>Constante</entry>
  808. <entry>Chaîne correspondante</entry>
  809. </row>
  810. </thead>
  811. <tbody>
  812. <row>
  813. <entry><classname>Zend_Db_Select::DISTINCT</classname></entry>
  814. <entry><code>'distinct'</code></entry>
  815. </row>
  816. <row>
  817. <entry><classname>Zend_Db_Select::FOR_UPDATE</classname></entry>
  818. <entry><code>'forupdate'</code></entry>
  819. </row>
  820. <row>
  821. <entry><classname>Zend_Db_Select::COLUMNS</classname></entry>
  822. <entry><code>'columns'</code></entry>
  823. </row>
  824. <row>
  825. <entry><classname>Zend_Db_Select::FROM</classname></entry>
  826. <entry><code>'from'</code></entry>
  827. </row>
  828. <row>
  829. <entry><classname>Zend_Db_Select::WHERE</classname></entry>
  830. <entry><code>'where'</code></entry>
  831. </row>
  832. <row>
  833. <entry><classname>Zend_Db_Select::GROUP</classname></entry>
  834. <entry><code>'group'</code></entry>
  835. </row>
  836. <row>
  837. <entry><classname>Zend_Db_Select::HAVING</classname></entry>
  838. <entry><code>'having'</code></entry>
  839. </row>
  840. <row>
  841. <entry><classname>Zend_Db_Select::ORDER</classname></entry>
  842. <entry><code>'order'</code></entry>
  843. </row>
  844. <row>
  845. <entry><classname>Zend_Db_Select::LIMIT_COUNT</classname></entry>
  846. <entry><code>'limitcount'</code></entry>
  847. </row>
  848. <row>
  849. <entry><classname>Zend_Db_Select::LIMIT_OFFSET</classname></entry>
  850. <entry><code>'limitoffset'</code></entry>
  851. </row>
  852. </tbody>
  853. </tgroup>
  854. </table>
  855. <example id="zend.db.select.other.get-part.example">
  856. <title>Exemple d'utilisation de la méthode <code>getPart()</code></title>
  857. <programlisting role="php"><![CDATA[
  858. $select = $db->select()
  859. ->from('produits')
  860. ->order('produit_id');
  861. // Vous pouvez spécifier une chaîne littérale
  862. $orderData = $select->getPart( 'order' );
  863. // Vous pouvez utiliser une constante
  864. $orderData = $select->getPart( Zend_Db_Select::ORDER );
  865. // La valeur retournée peut être une structure tableau, pas une chaîne.
  866. // Chaque partie a une structure différente
  867. print_r( $orderData );
  868. ]]></programlisting>
  869. </example>
  870. </sect3>
  871. <sect3 id="zend.db.select.other.reset">
  872. <title>Effacer des parties de l'objet Select</title>
  873. <para>La méthode <code>reset()</code> vous permet de vider une partie spécifique de la requête SQL, ou
  874. toutes les parties si vous omettez l'argument.</para>
  875. <para>L'argument unique est facultatif. Vous pouvez spécifier la partie de la requête à effacer, en
  876. utilisant les mêmes chaînes que vous utilisez en tant qu'argument de la méthode <code>getPart()</code>. La
  877. partie de la requête que vous spécifiez est initialisée à l'état par défaut.</para>
  878. <para>Si vous omettez le paramètre, <code>reset()</code> initialise toutes les parties de la requête à leurs
  879. valeurs par défaut. Ceci rend l'objet Zend_Db_Select équivalent à un nouvel objet, comme si vous l'aviez
  880. tout juste instancié.</para>
  881. <example id="zend.db.select.other.reset.example">
  882. <title>Exemple d'utilisation de la méthode <code>reset()</code></title>
  883. <programlisting role="php"><![CDATA[
  884. // Construire cette requête :
  885. // SELECT p.*
  886. // FROM "produits" AS p
  887. // ORDER BY "produit_nom"
  888. $select = $db->select()
  889. ->from(array('p' => 'produits')
  890. ->order('produit_nom');
  891. // Changer la condition d'ordre avec une colonne différente :
  892. // SELECT p.*
  893. // FROM "produits" AS p
  894. // ORDER BY "produit_id"
  895. // Vider la partie afin de la redéfinir
  896. $select->reset( Zend_Db_Select::ORDER );
  897. // Et spécifier une colonne différente
  898. $select->order('produit_id');
  899. // Vider toutes les parties de la requête
  900. $select->reset();
  901. ]]></programlisting>
  902. </example>
  903. </sect3>
  904. </sect2>
  905. </sect1>