Zend_Db_Select.xml 55 KB

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