Zend_Db_Select.xml 59 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15851 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.select">
  5. <title>Zend_Db_Select</title>
  6. <sect2 id="zend.db.select.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. Das <classname>Zend_Db_Select</classname> Objekt repräsentiert ein SQL
  10. <code>SELECT</code> Anfrage Statement. Die Klasse bietet Methoden um einzelne Teile der
  11. Anfrage hinzuzufügen. Einzelne Teile der Anfrage können mit Hilfe von PHP Methoden und
  12. Datenstrukturen angegeben werden, und die Klasse erzeugt korrekte SQL Syntax. Nachdem
  13. die Anfrage formuliert wurde kann sie ausgeführt werden als wäre sie mit einem normalen
  14. String geschrieben worden.
  15. </para>
  16. <para>
  17. <classname>Zend_Db_Select</classname> bietet folgenden Nutzen:
  18. </para>
  19. <itemizedlist>
  20. <listitem>
  21. <para>
  22. Objekt Orientierte Methoden um SQL Anfragen Stück für Stück zu formulieren.
  23. </para>
  24. </listitem>
  25. <listitem>
  26. <para>
  27. Datenbank unabhängige Abstraktion einiger Teile der SQL Anfrage.
  28. </para>
  29. </listitem>
  30. <listitem>
  31. <para>
  32. In den meisten Fällen automatische Quotierung von Metadaten um Bezeichner zu
  33. unterstützen welche reservierte SQL Wörter und spezielle Zeichen enthalten.
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. Quotierung von Bezeichnern und Werten um dabei zu helfen das Risiko von SQL
  39. Injektion Attacken zu reduzieren.
  40. </para>
  41. </listitem>
  42. </itemizedlist>
  43. <para>
  44. Nutzung von <classname>Zend_Db_Select</classname> ist nicht zwingend erforderlich. Für
  45. einfache SELECT Anfragen ist es normalerweise einfacher die gesamte SQL Anfrage in einem
  46. String zu formulieren und mit Hilfe der Methoden der Adapterklasse, wie
  47. <code>fetch()</code> oder <code>fetchAll()</code>, auszuführen. Die Nutzung von
  48. <classname>Zend_Db_Select</classname> ist hilfreich wenn eine SELECT Anfrage prozedural
  49. oder basierend auf der konditionellen Logik der Anwendung zusammengesetzt wird.
  50. </para>
  51. </sect2>
  52. <sect2 id="zend.db.select.creating">
  53. <title>Erzeugung eines Select Objekts</title>
  54. <para>
  55. Die Instanz eines <classname>Zend_Db_Select</classname> Objekts kann mit Hilfe der
  56. <code>select()</code> Methode des <classname>Zend_Db_Adapter_Abstract</classname>
  57. Objekts erzeugt werden.
  58. </para>
  59. <example id="zend.db.select.creating.example-db">
  60. <title>Beispiel für die Nutzung der select() Methode der Datenbankadapterklasse</title>
  61. <programlisting language="php"><![CDATA[
  62. $db = Zend_Db::factory( ...Optionen... );
  63. $select = $db->select();
  64. ]]></programlisting>
  65. </example>
  66. <para>
  67. Ein anderer Weg ein <classname>Zend_Db_Select</classname> Objekt zu erzeugen ist die
  68. Nutzung des Konstruktors unter Angabe des Datenbankadapters als Argument.
  69. </para>
  70. <example id="zend.db.select.creating.example-new">
  71. <title>Beispiel für die Erzeugung eines Select Objektes</title>
  72. <programlisting language="php"><![CDATA[
  73. $db = Zend_Db::factory( ...Optionen... );
  74. $select = new Zend_Db_Select($db);
  75. ]]></programlisting>
  76. </example>
  77. </sect2>
  78. <sect2 id="zend.db.select.building">
  79. <title>Erstellung von Select Anfragen</title>
  80. <para>
  81. Wenn die Anfrage erstellt wird können Bedingungen der Anfrage nacheinander hinzugefügt
  82. werden. Es gibt eine separate Methode für das Hinzufügen von verschiedenen Bedingungen
  83. zum <classname>Zend_Db_Select</classname> Objekt.
  84. </para>
  85. <example id="zend.db.select.building.example">
  86. <title>Beispiele für die Nutzung der Methoden zum Hinzufügen von Bedingungen</title>
  87. <programlisting language="php"><![CDATA[
  88. // Erzeugung des Zend_Db_Select Objekts
  89. $select = $db->select();
  90. // Hinzufügen einer FROM Bedingung
  91. $select->from( ...Angabe von Tabelle und Spalten... )
  92. // Hinzufügen einer WHERE Bedingung
  93. $select->where( ...Angabe von Suchkriterien... )
  94. // Hinzufügen einer ORDER BY Bedingung
  95. $select->order( ...Angabe von Sortierkriterien... );
  96. ]]></programlisting>
  97. </example>
  98. <para>
  99. Die meisten Methoden des <classname>Zend_Db_Select</classname> Objekts lassen sich auch
  100. über das bequeme Fluent Interface nutzen. Fluent Interface bedeutet das jede Methode
  101. eine Referenz auf das aufrufende Objekt zurück gibt, daher kann direkt eine andere
  102. Methode aufgerufen werden.
  103. </para>
  104. <example id="zend.db.select.building.example-fluent">
  105. <title>Beispiel für die Nutzung der flüssigen Schnittstelle</title>
  106. <programlisting language="php"><![CDATA[
  107. $select = $db->select()
  108. ->from( ...Angabe von Tabelle und Spalten... )
  109. ->where( ...Angabe von Suchkriterien... )
  110. ->order( ...Angabe von Sortierkriterien... );
  111. ]]></programlisting>
  112. </example>
  113. <para>
  114. Die Beispiele in diesem Abschnitt zeigen die Nutzung des Fluent Interface, es kann aber
  115. auch immer das normale Interface verwendet werden. Häufig ist es nötig das normale
  116. Interface zu nutzen, zum Beispiel wenn die Anwendung vor dem Hinzufügen der Bedingung
  117. Berechnungen durchführen muss.
  118. </para>
  119. <sect3 id="zend.db.select.building.from">
  120. <title>Hinzufügen eines FROM Abschnitts</title>
  121. <para>
  122. Um die Tabelle für die Anfrage an zu geben wird die <code>from()</code> Methode
  123. verwendet. Der Tabellenname kann als einfacher String übergeben werden.
  124. <classname>Zend_Db_Select</classname> wendet Bezeichner Quotierung an, es können
  125. also auch spezielle Zeichen verwendet werden.
  126. </para>
  127. <example id="zend.db.select.building.from.example">
  128. <title>Beispiel für die from() Methode</title>
  129. <programlisting language="php"><![CDATA[
  130. // Erstellen dieser Anfrage:
  131. // SELECT *
  132. // FROM "products"
  133. $select = $db->select()
  134. ->from( 'products' );
  135. ]]></programlisting>
  136. </example>
  137. <para>
  138. Es kann auch der Beziehungsname (auch Aliasname genannt) einer Tabelle angegeben
  139. werden. Anstelle eines einfachen Strings muss dann ein assoziatives Array übergeben
  140. werden, welches den Beziehungsnamen dem tatsächlichen Tabellennamen zuordnet. In
  141. anderen Bedingungen der SQL Anfrage kann dann dieser Beziehungsname verwendet
  142. werden. Wenn die Anfrage mehr als eine Tabelle verbindet, generiert
  143. <classname>Zend_Db_Select</classname> eindeutige Beziehungsnamen basierend auf den
  144. Tabellennamen, wenn keine Beziehungsnamen angegeben wurden.
  145. </para>
  146. <example id="zend.db.select.building.from.example-cname">
  147. <title>Beispiel für das Angeben eines Beziehungsnamens</title>
  148. <programlisting language="php"><![CDATA[
  149. // Erzeugt diese Anfrage:
  150. // SELECT p.*
  151. // FROM "products" AS p
  152. $select = $db->select()
  153. ->from( array('p' => 'products') );
  154. ]]></programlisting>
  155. </example>
  156. <para>
  157. Einige RDBMS Marken unterstützen einen voran stehenden Schemenbezeichner für eine
  158. Tabelle. Der Tabellenname kann mit "<code>schemaName.tabellenName</code>" angegeben
  159. werden, <classname>Zend_Db_Select</classname> Quotiert die einzelnen Teile für sich.
  160. Der Schemaname kann aber auch separat angegeben werden. Ein Schemaname, der mit dem
  161. Tabellennamen angegeben wurde bekommt Vorrang, falls beides angegeben wurde.
  162. </para>
  163. <example id="zend.db.select.building.from.example-schema">
  164. <title>Beispiel für das Angeben eines Schemanamens</title>
  165. <programlisting language="php"><![CDATA[
  166. // Erzeut diese Anfrage:
  167. // SELECT *
  168. // FROM "myschema"."products"
  169. $select = $db->select()
  170. ->from( 'myschema.products' );
  171. // oder
  172. $select = $db->select()
  173. ->from('products', '*', 'myschema');
  174. ]]></programlisting>
  175. </example>
  176. </sect3>
  177. <sect3 id="zend.db.select.building.columns">
  178. <title>Hinzufügen von Spalten</title>
  179. <para>
  180. Im zweiten Argument der <code>from()</code> Methode kann angegeben werden, welche
  181. Spalten der Tabelle ausgelesen werden sollen. Werden keine Spalten angegeben, so
  182. gilt der Standardwert <code>*</code>, der SQL Platzhalter für alle Spalten.
  183. </para>
  184. <para>
  185. Die Spalten können in einem einfachen Array von Strings oder einem assoziativen
  186. Array, in dem Aliasnamen a Spaltennamen zugewiesen werden, angegeben werden. Soll
  187. nur eine einzelne Spalte ohne Aliasnamen ausgelesen werden, so kann auch ein
  188. einfacher String übergeben werden.
  189. </para>
  190. <para>
  191. Wird ein leeres Array übergeben, so werden auch keine Spalten der Tabelle in den
  192. Ergebnissatz aufgenommen. Ein Codebeispiel gibt es unter
  193. <link linkend="zend.db.select.building.join.example-no-columns">code example</link>
  194. bei der <code>join()</code> Methode.
  195. </para>
  196. <para>
  197. Der Spaltenname kann mit "<code>beziehungsName.spaltenName</code>" angegeben
  198. werden. <classname>Zend_Db_Select</classname> Quotiert die einzelnen Teile für sich.
  199. Wird kein Beziehungsname für die Spalte angegeben, dann wird der Beziehungsname der
  200. Tabelle der aktuellen <code>from()</code> Methode verwendet.
  201. </para>
  202. <example id="zend.db.select.building.columns.example">
  203. <title>Beispiele für das Angeben von Spalten</title>
  204. <programlisting language="php"><![CDATA[
  205. // Erzeugt diese Anfrage:
  206. // SELECT p."product_id", p."product_name"
  207. // FROM "products" AS p
  208. $select = $db->select()
  209. ->from(array('p' => 'products'),
  210. array('product_id', 'product_name'));
  211. // Erzeugt dieselbe Anfrage, Angabe von Beziehungsnamen:
  212. // SELECT p."product_id", p."product_name"
  213. // FROM "products" AS p
  214. $select = $db->select()
  215. ->from(array('p' => 'products'),
  216. array('p.product_id', 'p.product_name'));
  217. // Erzeugt diese Anfrage mit einem Alias für eine Spalte:
  218. // SELECT p."product_id" AS prodno, p."product_name"
  219. // FROM "products" AS p
  220. $select = $db->select()
  221. ->from(array('p' => 'products'),
  222. array('prodno' => 'product_id', 'product_name'));
  223. ]]></programlisting>
  224. </example>
  225. </sect3>
  226. <sect3 id="zend.db.select.building.columns-expr">
  227. <title>Hinzufügen von Spalten mit Expressions</title>
  228. <para>
  229. Spalten in einer SQL Anfrage sind manchmal Expressions, keine einfachen
  230. Spaltennamen einer Tabelle. Expressions dürfen keine Beziehungsnamen oder
  231. Quotierungen bekommen. Wenn der Spaltenstring runde Klammern enthält erkennt
  232. <classname>Zend_Db_Select</classname> dies als eine Expression.
  233. </para>
  234. <para>
  235. Es kann auch ein Objekt des Typs <classname>Zend_Db_Expr</classname> erzeugt werden
  236. um zu verhindern das ein String wie ein Spaltenname behandelt wird.
  237. <classname>Zend_Db_Expr</classname> ist eine Minimalklasse die einen String enthält.
  238. <classname>Zend_Db_Select</classname> erkennt Objekte des Typs
  239. <classname>Zend_Db_Expr</classname> und konvertiert diese in Strings, nimmt aber
  240. keine Änderungen daran vor, wie Quotierung oder Beziehungsnamen.
  241. </para>
  242. <note>
  243. <para>
  244. Benutzung von <classname>Zend_Db_Expr</classname> für Spaltennamen ist nicht
  245. nötig wenn Spaltennamen Expressions runde Klammern enthalten.
  246. <classname>Zend_Db_Select</classname> erkennt diese und behandelt den String als
  247. eine Expression und lässt Quotierung und Beziehungsnamen aus.
  248. </para>
  249. </note>
  250. <example id="zend.db.select.building.columns-expr.example">
  251. <title>Beispiel für das angeben von Spaltennamen, die Expressions enthalten</title>
  252. <programlisting language="php"><![CDATA[
  253. // Erzeugt diese Anfrage:
  254. // SELECT p."product_id", LOWER(product_name)
  255. // FROM "products" AS p
  256. // Eine Expression eingeschlossen von runden Klammern wird zu Zend_Db_Expr.
  257. $select = $db->select()
  258. ->from(array('p' => 'products'),
  259. array('product_id', 'LOWER(product_name)'));
  260. // Erzeugt diese Anfrage:
  261. // SELECT p."product_id", (p.cost * 1.08) AS cost_plus_tax
  262. // FROM "products" AS p
  263. $select = $db->select()
  264. ->from(array('p' => 'products'),
  265. array('product_id',
  266. 'cost_plus_tax' => '(p.cost * 1.08)'));
  267. // Erzeugt diese Anfrage unter ausdrücklicher Verwendung von Zend_Db_Expr:
  268. // SELECT p."product_id", p.cost * 1.08 AS cost_plus_tax
  269. // FROM "products" AS p
  270. $select = $db->select()
  271. ->from(array('p' => 'products'),
  272. array('product_id',
  273. 'cost_plus_tax' =>
  274. new Zend_Db_Expr('p.cost * 1.08'))
  275. );
  276. ]]></programlisting>
  277. </example>
  278. <para>
  279. In den oben stehenden Fällen ändern <classname>Zend_Db_Select</classname> den String
  280. nicht mit Beziehungsnamen oder Bezeichnerquotierung. Wenn diese Änderungen notwendig
  281. sein sollten um doppeldeutigkeiten auf zu lösen, muss dies manuell am String
  282. geändert werden.
  283. </para>
  284. <para>
  285. Wenn die Spaltennamen aus SQL Schlüsselwörtern besteht oder spezielle Zeichen
  286. enthält sollte die <code>quoteIdentifier()</code> Methode verwendet werden und der
  287. Rückgabewert in den String eingefügt werden. Die <code>quoteIdentifier()</code>
  288. Methode verwendet SQL Quotierung um Bezeichner abzugrenzen, wodurch klar wird, das
  289. es sich um einen Bezeichner für eine Tabelle oder Spalte handelt, und nicht um
  290. einem anderen Teil der SQL Syntax.
  291. </para>
  292. <para>
  293. Der Code wird Datenbank unabhängiger wenn die <code>quoteIdentifier()</code>
  294. Methode anstelle von direkter Eingabe der Quotierungszeichen verwendet wird, da
  295. einige RDBMS Marken nicht-Standard Symbole für die Quotierung von Bezeichnern
  296. verwenden. Die <code>quoteIdentifier()</code> Methode wählt die passenden
  297. Quotierungssymbole für den Adaptertyp aus. Die <code>quoteIdentifier()</code>
  298. Methode ersetzt außerdem alle Quotierungszeichen innerhalb des Bezeichners.
  299. </para>
  300. <example id="zend.db.select.building.columns-quoteid.example">
  301. <title>Beispiel für die Quotierung von Spalten in einer Expression</title>
  302. <programlisting language="php"><![CDATA[
  303. // Erzeugt folgende Anfrage und Quotiert dabei einen Spaltennamen
  304. // "from" in der Expression:
  305. // SELECT p."from" + 10 AS origin
  306. // FROM "products" AS p
  307. $select = $db->select()
  308. ->from(array('p' => 'products'),
  309. array('origin' =>
  310. '(p.' . $db->quoteIdentifier('from') . ' + 10)')
  311. );
  312. ]]></programlisting>
  313. </example>
  314. </sect3>
  315. <sect3 id="zend.db.select.building.columns-atomic">
  316. <title>Spalten zu einer existierenden FROM oder JOIN Tabelle hinzufügen</title>
  317. <para>
  318. Es kann Fälle geben wo es gewünscht ist Spalten zu einer bestehenden FROM oder JOIN
  319. Tabelle hinzuzufügen nachdem diese Methoden aufgerufen wurde. Die
  320. <code>columns()</code> Methode erlaubt es spezifische Spalten an jedem Punkt
  321. hinzuzufügen bevor die Abfrage aufgeführt wird. Die Spalte kann entweder als String
  322. oder <classname>Zend_Db_Expr</classname> oder als Array dieser Elemente angegeben
  323. werden. Das zweite Argument dieser Methode kann unterdrückt werden, was impliziert
  324. das die Spalten zu der FROM Tabelle hinzugefügt werden sollen, andernfall muß ein
  325. bestehender Korrelationsname verwendet werden.
  326. </para>
  327. <example id="zend.db.select.building.columns-atomic.example">
  328. <title>Beispiel für das Hinzufügen von Spalten mit der columns() Methode</title>
  329. <programlisting language="php"><![CDATA[
  330. // Diese Abfrage bauen:
  331. // SELECT p."product_id", p."product_name"
  332. // FROM "products" AS p
  333. $select = $db->select()
  334. ->from(array('p' => 'products'), 'product_id')
  335. ->columns('product_name');
  336. // Die selbe Abfrage bauen, durch spezifizierung der Korrelationsnamen:
  337. // SELECT p."product_id", p."product_name"
  338. // FROM "products" AS p
  339. $select = $db->select()
  340. ->from(array('p' => 'products'), 'p.product_id')
  341. ->columns('product_name', 'p');
  342. // Alternativ kann columns('p.product_name') verwendet werden
  343. ]]></programlisting>
  344. </example>
  345. </sect3>
  346. <sect3 id="zend.db.select.building.join">
  347. <title>Hinzufügen einer weiteren Tabelle zu der Anfrage mit JOIN</title>
  348. <para>
  349. Viele nützliche Anfragen benötigen ein <code>JOIN</code> um mehrere Spalten
  350. verschiedener Tabellen miteinander zu kombinieren. Tabellen können zu einer
  351. <classname>Zend_Db_Select</classname> Anfrage mit der <code>join()</code> Methode
  352. hinzugefügt werden. Die Nutzung dieser Methode ist ähnlich der <code>from()</code>
  353. Methode, außer das in den meisten Fällen zusätzlich eine Join Bedingung angegeben
  354. werden kann.
  355. </para>
  356. <example id="zend.db.select.building.join.example">
  357. <title>Beispiel für die join() Methode</title>
  358. <programlisting language="php"><![CDATA[
  359. // Erzeugt diese Anfrage:
  360. // SELECT p."product_id", p."product_name", l.*
  361. // FROM "products" AS p JOIN "line_items" AS l
  362. // ON p.product_id = l.product_id
  363. $select = $db->select()
  364. ->from(array('p' => 'products'),
  365. array('product_id', 'product_name'))
  366. ->join(array('l' => 'line_items'),
  367. 'p.product_id = l.product_id');
  368. ]]></programlisting>
  369. </example>
  370. <para>
  371. Das zweite Argument der <code>join()</code> Methode ist ein String mit der Join
  372. Bedingung. Dies ist eine Exspression die Kriterien angibt, welche Zeilen in der
  373. einen Tabelle mit Zeilen einer anderen Tabelle verknüpft werden. Es können
  374. Beziehungsnamen in dieser Expression verwendet werden.
  375. </para>
  376. <note>
  377. <para>
  378. Es wird keine Quotierung auf die Expression für die Join Bedingung angewendet.
  379. Werden Spaltennamen verwendet, welche Quotierung benötigen, so muss
  380. <code>quoteIdentifier()</code> verwendet werden wenn der String für die Join
  381. Bedingung formuliert wird.
  382. </para>
  383. </note>
  384. <para>
  385. Das dritte Argument für <code>join()</code> ist ein Array von Spaltennahmen,
  386. entsprechend des Arrays der <code>from()</code> Methode. Der Standard ist ebenfalls
  387. "<code>*</code>" und unterstützt Beziehungsnamen, Expressions und
  388. <classname>Zend_Db_Expr</classname> in der gleichen Weise wie dem Array von
  389. Spaltennamen der <code>from()</code> Methode.
  390. </para>
  391. <para>
  392. Wenn keine Spalten einer Tabelle ausgewählt werden soll muss ein leeres Array für
  393. die Liste der Spaltennamen übergeben werden. Diese Nutzung funktioniert ebenfalls
  394. in der <code>from()</code> Methode, aber normalerweise werden einige Spalten der
  395. primären Tabelle in den Anfragen benötigt, während möglicherweise keine Spalten der
  396. verbundenen Tabelle ausgewählt werden sollen.
  397. </para>
  398. <example id="zend.db.select.building.join.example-no-columns">
  399. <title>Beispiel für das Angeben keiner Spalten</title>
  400. <programlisting language="php"><![CDATA[
  401. // Erzeugt diese Anfrage:
  402. // SELECT p."product_id", p."product_name"
  403. // FROM "products" AS p JOIN "line_items" AS l
  404. // ON p.product_id = l.product_id
  405. $select = $db->select()
  406. ->from(array('p' => 'products'),
  407. array('product_id', 'product_name'))
  408. ->join(array('l' => 'line_items'),
  409. 'p.product_id = l.product_id',
  410. array() ); // leere Liste von Spalten
  411. ]]></programlisting>
  412. <para>
  413. Zu beachten ist das leere <code>array()</code> in dem oben stehenden Beispiel,
  414. am Stelle einer Liste von Spalten der verbundenen Tabelle.
  415. </para>
  416. </example>
  417. <para>
  418. SQL kennt verschiedene Typen von Joins. In der unten stehen Liste sind Methoden zu
  419. finden, für die verschiedenen Join Typen die <classname>Zend_Db_Select</classname>
  420. unterstützt.
  421. </para>
  422. <itemizedlist>
  423. <listitem>
  424. <para>
  425. <command>INNER JOIN</command> mit den
  426. <code>join(tabelle, join, [spalten])</code> oder
  427. <code>joinInner(tabelle, join, [spalten])</code> Methoden.
  428. </para>
  429. <para>
  430. Dies wird der gebräuchlichste Typ von Join sein. Zeilen jeder Tabelle
  431. werden mit Hilfe der angegebenen Join Bedingung verglichen. Der
  432. Ergebnissatz enthält nur die Zeilen die der Join Bedingungen entsprechen.
  433. Der Ergebnissatz kann leer sein, wenn keine Zeile die Bedingung erfüllt.
  434. </para>
  435. <para>
  436. Alle RDBMS Marken unterstützen diesen Join Typ.
  437. </para>
  438. </listitem>
  439. <listitem>
  440. <para>
  441. <command>LEFT JOIN</command> mit der
  442. <code>joinLeft(tabelle, bedingung, [spalten])</code> Methode.
  443. </para>
  444. <para>
  445. Alle Zeilen der links vom Operanden stehenden Tabelle sind enthalten,
  446. passende Zeilen der rechts stehenden Tabelle sind ebenfalls enthalten. Die
  447. Spalten der rechts stehenden Tabelle werden mit NULL aufgefüllt, wenn keine
  448. zu der linken Tabelle passenden Zeilen existieren.
  449. </para>
  450. <para>
  451. Alle RDBMS Marken unterstützen diesen Join Typ.
  452. </para>
  453. </listitem>
  454. <listitem>
  455. <para>
  456. <command>RIGHT JOIN</command> mit der
  457. <code>joinRight(tabelle, bedingung, [spalten])</code> Methode.
  458. </para>
  459. <para>
  460. Right Outer Join ist das Gegenstück zu Left Outer Join. Alle Zeilen der
  461. rechts vom Operanden stehenden Tabelle sind enthalten, passende Zeilen der
  462. links stehenden Tabelle sind ebenfalls enthalten. Die Spalten der links
  463. stehenden Tabelle werden mit NULL aufgefüllt, wenn keine zu der rechten
  464. Tabelle passenden Zeilen existieren.
  465. </para>
  466. <para>
  467. Einige RDBMS Marken unterstützen diesen Join Typ nicht, aber grundsätzlich
  468. kann jeder Right Join durch einen Left Join mit umgekehrter Sortierung der
  469. Tabellen dargestellt werden.
  470. </para>
  471. </listitem>
  472. <listitem>
  473. <para>
  474. <command>FULL JOIN</command> mit der
  475. <code>joinFull(tabelle, bedingung, [spalten])</code> Methode.
  476. </para>
  477. <para>
  478. Ein Full Outer Join ist wie eine Kombination eines Left Outer Join mit
  479. einem Right Outer Join. Alle Zeilen beider Tabellen sind enthalten, gepaart
  480. miteinander in der gleichen Zeile des Ergebnissatzes wenn die Join
  481. Bedingung erfüllt wird, oder wenn nicht, mit NULL an Stelle der Spalten der
  482. anderen Tabelle.
  483. </para>
  484. <para>
  485. Einige RDBMS Marken unterstützen diesen Join Typ nicht.
  486. </para>
  487. </listitem>
  488. <listitem>
  489. <para>
  490. <command>CROSS JOIN</command> mit der
  491. <code>joinCross(tabelle, [spalten])</code> Methode.
  492. </para>
  493. <para>
  494. Ein Cross Join ist ein Kartesisches Produkt. Jede Zeile der ersten Tabelle
  495. wird mit jeder Zeile der zweiten Tabelle verbunden. Daher ist die Anzahl
  496. der Zeilen im Ergebnissatz gleich dem Produkt der Zeilenanzahlen der beiden
  497. Tabellen. Der Ergebnissatz kann mit Bedingungen einer WHERE Bedingung
  498. gefiltert werden. Ein Cross Join ist ähnlich der alten SQL-89 JOIN Syntax.
  499. </para>
  500. <para>
  501. Die <code>joinCross()</code> Methode hat keinen Parameter für die Join
  502. Bedingung. Einige RDBMS Marken unterstützen diesen Join Typ nicht.
  503. </para>
  504. </listitem>
  505. <listitem>
  506. <para>
  507. <command>NATURAL JOIN</command> mit der
  508. <code>joinNatural(tabelle, [spalten])</code> Methode.
  509. </para>
  510. <para>
  511. Ein Natural Join vergleicht alle Spalten die in beiden Tabellen mit
  512. gleichem Namen vorkommen. Der Vergleich prüft Gleichheit aller Spalten, ein
  513. Vergleich auf Ungleichheit ist kein Natural Join. Von dieser API werden nur
  514. Natural Inner Joins unterstützt, auch wenn SQL auch Natural Outer Joins
  515. erlaubt.
  516. </para>
  517. <para>
  518. Die <code>joinNatural()</code> Methode hat keinen Parameter für die Join
  519. Bedingung.
  520. </para>
  521. </listitem>
  522. </itemizedlist>
  523. <para>
  524. Zusätzlich zu diesen Join Methoden können Abfragen durch Verwendung der JoinUsing
  525. Methoden vereinfacht werden. Statt das eine komplette Definition des Joins
  526. angegeben wird, kann einfach der Spaltenname übergeben werden auf welchem gejoint
  527. werden soll und das <classname>Zend_Db_Select</classname> Objekt vervollständigt die
  528. Bedingung alleine.
  529. </para>
  530. <example id="zend.db.select.building.joinusing.example">
  531. <title>Beispiel für die joinUsing() Methode</title>
  532. <programlisting language="php"><![CDATA[
  533. // Erzeugt diese Abfrage
  534. // SELECT *
  535. // FROM "table1"
  536. // JOIN "table2"
  537. // ON "table1".column1 = "table2".column1
  538. // WHERE column2 = 'foo'
  539. $select = $db->select()
  540. ->from('table1')
  541. ->joinUsing('table2', 'column1')
  542. ->where('column2 = ?', 'foo');
  543. ]]></programlisting>
  544. </example>
  545. <para>
  546. Jede der anwendbaren Join Methoden in der <classname>Zend_Db_Select</classname>
  547. Komponente hat eine entsprechende 'using' Methode.
  548. </para>
  549. <itemizedlist>
  550. <listitem>
  551. <para>
  552. <code>joinUsing(table, join, [columns])</code> und
  553. <code>joinInnerUsing(table, join, [columns])</code>
  554. </para>
  555. </listitem>
  556. <listitem>
  557. <para>
  558. <code>joinLeftUsing(table, join, [columns])</code>
  559. </para>
  560. </listitem>
  561. <listitem>
  562. <para>
  563. <code>joinRightUsing(table, join, [columns])</code>
  564. </para>
  565. </listitem>
  566. <listitem>
  567. <para>
  568. <code>joinFullUsing(table, join, [columns])</code>
  569. </para>
  570. </listitem>
  571. </itemizedlist>
  572. </sect3>
  573. <sect3 id="zend.db.select.building.where">
  574. <title>Hinzufügen eines WHERE Abschnitts</title>
  575. <para>
  576. Es können Kriterien die den Ergebnissatz einschränken mit der <code>where()</code>
  577. Methode angegeben werden. Das erste Argument dieser Methode ist eine SQL
  578. Expression, welche im <code>WHERE</code> Abschnitt der Anfrage steht.
  579. </para>
  580. <example id="zend.db.select.building.where.example">
  581. <title>Beispiel für die where() Methode</title>
  582. <programlisting language="php"><![CDATA[
  583. // Erzeugt diese Anfrage:
  584. // SELECT product_id, product_name, price
  585. // FROM "products"
  586. // WHERE price > 100.00
  587. $select = $db->select()
  588. ->from('products',
  589. array('product_id', 'product_name', 'price'))
  590. ->where('price > 100.00');
  591. ]]></programlisting>
  592. </example>
  593. <note>
  594. <para>
  595. Auf Expressions die an <code>where()</code> oder <code>orWhere()</code>
  596. Methoden übergeben werden, wird keine Quotierung angewendet. Werden
  597. Spaltennamen verwendet die Quotiert werden müssen, so muss
  598. <code>quoteIdentifier()</code> verwendet werden wenn der String für die
  599. Bedingung formuliert wird.
  600. </para>
  601. </note>
  602. <para>
  603. Das zweite Argument der <code>where()</code> Methode ist optional. Es ist ein Wert
  604. der in die Expression eingesetzt wird. <classname>Zend_Db_Select</classname>
  605. Quotiert den Wert und ersetzt ihn für ein Fragezeichen ("<code>?</code>") in der
  606. Expression.
  607. </para>
  608. <para>
  609. Wenn in eine Expression mehr als eine Variable eingesetzt werden soll muss der
  610. String manuell formatiert werden und die Variablen müssen von Hand quotiert und
  611. eingesetzt werden.
  612. </para>
  613. <example id="zend.db.select.building.where.example-param">
  614. <title>Beispiel für einen Parameter in der where() Methode</title>
  615. <programlisting language="php"><![CDATA[
  616. // Erzeugt diese Anfrage:
  617. // SELECT product_id, product_name, price
  618. // FROM "products"
  619. // WHERE (price > 100.00)
  620. $minimumPrice = 100;
  621. $select = $db->select()
  622. ->from('products',
  623. array('product_id', 'product_name', 'price'))
  624. ->where('price > ?', $minimumPrice);
  625. ]]></programlisting>
  626. </example>
  627. <para>
  628. Die <code>where()</code> Methode kann mehrere Male in dem selben
  629. <classname>Zend_Db_Select</classname> Objekt aufgerufen werden. Die daraus folgenden
  630. Anfrage kombiniert die unterschiedlichen Ausdrücke unter Benutzung von
  631. <code>AND</code> zwischen ihnen.
  632. </para>
  633. <example id="zend.db.select.building.where.example-and">
  634. <title>Beispiel für mehrfach Aufruf der where() Methode</title>
  635. <programlisting language="php"><![CDATA[
  636. // Erzeugt diese Anfrage:
  637. // SELECT product_id, product_name, price
  638. // FROM "products"
  639. // WHERE (price > 100.00)
  640. // AND (price < 500.00)
  641. $minimumPrice = 100;
  642. $maximumPrice = 500;
  643. $select = $db->select()
  644. ->from('products',
  645. array('product_id', 'product_name', 'price'))
  646. ->where('price > ?', $minimumPrice)
  647. ->where('price < ?', $maximumPrice);
  648. ]]></programlisting>
  649. </example>
  650. <para>
  651. Wenn mehrere Ausdrücke mit <code>OR</code> verknüpft werden sollen kann die
  652. <code>orWhere()</code> Methode verwendet werden. Sie wird genauso benutzt wie
  653. die <code>where()</code> Methode, außer das dem angegebene Ausdruck ein
  654. <code>OR</code> vorangestellt wird, anstelle eines <code>AND</code>.
  655. </para>
  656. <example id="zend.db.select.building.where.example-or">
  657. <title>Beispiel für die orWhere() Methode</title>
  658. <programlisting language="php"><![CDATA[
  659. // Erzeugt diese Anfrage:
  660. // SELECT product_id, product_name, price
  661. // FROM "products"
  662. // WHERE (price < 100.00)
  663. // OR (price > 500.00)
  664. $minimumPrice = 100;
  665. $maximumPrice = 500;
  666. $select = $db->select()
  667. ->from('products',
  668. array('product_id', 'product_name', 'price'))
  669. ->where('price < ?', $minimumPrice)
  670. ->orWhere('price > ?', $maximumPrice);
  671. ]]></programlisting>
  672. </example>
  673. <para>
  674. <classname>Zend_Db_Select</classname> klammert Expressions automatisch mit runden
  675. Klammern ein wenn sie mit der <code>where()</code> oder <code>orWhere()</code>
  676. Methode angegeben wurden. Dies hilft sicher zu stellen dass das voranstellen von
  677. Boolean Operatoren keine unerwarteten Ergebnisse nach sich zieht.
  678. </para>
  679. <example id="zend.db.select.building.where.example-parens">
  680. <title>Beispiel für das Einklammern von Boolean Expressions</title>
  681. <programlisting language="php"><![CDATA[
  682. // Erzeugt diese Anfrage:
  683. // SELECT product_id, product_name, price
  684. // FROM "products"
  685. // WHERE (price < 100.00 OR price > 500.00)
  686. // AND (product_name = 'Apple')
  687. $minimumPrice = 100;
  688. $maximumPrice = 500;
  689. $prod = 'Apple';
  690. $select = $db->select()
  691. ->from('products',
  692. array('product_id', 'product_name', 'price'))
  693. ->where("price < $minimumPrice OR price > $maximumPrice")
  694. ->where('product_name = ?', $prod);
  695. ]]></programlisting>
  696. </example>
  697. <para>
  698. In dem oben stehenden Beispiel währen die Ergebnisse ohne den Klammern ziemlich
  699. anders, weil <code>AND</code> eine höhere Priorität als <code>OR</code> hat.
  700. <classname>Zend_Db_Select</classname> erzeugt runde Klammern wodurch jede Expression
  701. von aufeinander folgenden Aufrufen der <code>where()</code> Methode fester binden
  702. als das <code>AND</code> welches die Expressions kombiniert.
  703. </para>
  704. </sect3>
  705. <sect3 id="zend.db.select.building.group">
  706. <title>Hinzufügen eines GROUP BY Abschnitts</title>
  707. <para>
  708. In SQL ermöglicht der <code>GROUP BY</code> Abschnitt die Zeilenzahl des
  709. Ergebnissatzes auf eine Zeile pro eindeutigem Wert der Spalte(n), welche in dem
  710. <code>GROUP BY</code> Abschnitt benannt sind, einzuschränken.
  711. </para>
  712. <para>
  713. In <classname>Zend_Db_Select</classname> können diese Spalte(n) mit der
  714. <code>group()</code> Methode angegeben werden. Das Argument der Methode ist ein
  715. Spaltenname oder ein Array von Spaltennamen, welche im <code>GROUP BY</code>
  716. Abschnitt stehen sollen.
  717. </para>
  718. <example id="zend.db.select.building.group.example">
  719. <title>Beispiel für die group() Methode</title>
  720. <programlisting language="php"><![CDATA[
  721. // Erzeugt diese Anfrage:
  722. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  723. // FROM "products" AS p JOIN "line_items" AS l
  724. // ON p.product_id = l.product_id
  725. // GROUP BY p.product_id
  726. $select = $db->select()
  727. ->from(array('p' => 'products'),
  728. array('product_id'))
  729. ->join(array('l' => 'line_items'),
  730. 'p.product_id = l.product_id',
  731. array('line_items_per_product' => 'COUNT(*)'))
  732. ->group('p.product_id');
  733. ]]></programlisting>
  734. </example>
  735. <para>
  736. Wie in dem Array von Spaltennamen der <code>from()</code> Methode, so können auch
  737. hier Beziehungsnamen in den Strings der Spaltennamen verwendet werden, und der
  738. Spaltenname wird als Bezeichner Quotiert, wenn er nicht in runden Klammern steht
  739. oder ein Objekt des Typs <classname>Zend_Db_Expr</classname> ist.
  740. </para>
  741. </sect3>
  742. <sect3 id="zend.db.select.building.having">
  743. <title>Hinzufügen eines HAVING Abschnittes</title>
  744. <para>
  745. In SQL fügt der <code>HAVING</code> Abschnitt eine Beschränkungsbedingung für
  746. Gruppen von Zeilen ein. Dies ist ähnlich der Einschränkungsbedingungen auf Zeilen,
  747. des <code>WHERE</code> Abschnittes. Die beiden Abschnitte unterscheiden sich
  748. jedoch, denn die <code>WHERE</code> Bedingungen werden abgewendet bevor Gruppen
  749. definiert wurden. Im Gegensatz werden <code>HAVING</code> Bedingungen erst
  750. angewendet nach dem Gruppen definiert wurden.
  751. </para>
  752. <para>
  753. In <classname>Zend_Db_Select</classname> können Bedingungen für die Einschränkung
  754. von Gruppen mit der <code>having()</code> Methode angegeben werden. Die Nutzung ist
  755. ähnlich wie die der <code>where()</code> Methode. Das erste Argument ist ein String,
  756. welcher eine SQL Expression enthält. Das zweite Argument ist optional und wird
  757. verwendet um einen positionierten Parameter Platzhalter in der SQL Expression zu
  758. ersetzen. Expressions die durch mehrfaches Aufrufen der <code>having()</code>
  759. Methode erzeugt wurden werden mit dem Boolean <code>AND</code> Operator verknüpft,
  760. oder mit dem <code>OR</code> Operator wenn die <code>orHaving()</code> Methode
  761. verwendet wird.
  762. </para>
  763. <example id="zend.db.select.building.having.example">
  764. <title>Beispiel für die having() Methode</title>
  765. <programlisting language="php"><![CDATA[
  766. // Erzeugt diese Anfrage:
  767. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  768. // FROM "products" AS p JOIN "line_items" AS l
  769. // ON p.product_id = l.product_id
  770. // GROUP BY p.product_id
  771. // HAVING line_items_per_product > 10
  772. $select = $db->select()
  773. ->from(array('p' => 'products'),
  774. array('product_id'))
  775. ->join(array('l' => 'line_items'),
  776. 'p.product_id = l.product_id',
  777. array('line_items_per_product' => 'COUNT(*)'))
  778. ->group('p.product_id')
  779. ->having('line_items_per_product > 10');
  780. ]]></programlisting>
  781. </example>
  782. <note>
  783. <para>
  784. Es wird keine Quotierung bei den Expressions welche an die
  785. <code>having()</code> oder <code>orHaving()</code> Methoden übergeben werden.
  786. Werden Spaltennamen verwendet die Quotiert werden müssen, so muss
  787. <code>quoteIdentifier()</code> verwendet werden wenn der String für die
  788. Bedingung formuliert wird.
  789. </para>
  790. </note>
  791. </sect3>
  792. <sect3 id="zend.db.select.building.order">
  793. <title>Hinzufügen eines ORDER BY Abschnitts</title>
  794. <para>
  795. In SQL gibt der <code>ORDER BY</code> Abschnitt eine oder mehrere Spalten oder
  796. Expressions an, wonach ein Ergebnissatz sortiert wird. Wenn mehrere Spalten
  797. angegeben sind, werden die sekundären Spalten verwendet um "ties" aufzulösen; die
  798. Sortierung wird von sekundären Spalten bestimmt, wenn vorhergehende Spalten
  799. identische Werte enthalten. Die standard Sortierung ist vom kleinsten zum größten
  800. Wert. Dieses Verhalten kann umgekehrt werden, wenn das Schlüsselwort
  801. <code>DESC</code> nach der Spalte angegeben wird.
  802. </para>
  803. <para>
  804. In <classname>Zend_Db_Select</classname> kann die <code>order()</code> Methode
  805. verwendet werden um Spalten, oder Arrays von Spalten, anzugeben, nach denen sortiert
  806. werden soll. Jedes Element des Arrays ist ein String, welcher die Spalte benennt.
  807. Optional kann auf den Namen eines der Schlüsselwörter <code>ASC</code>
  808. <code>DESC</code> folgen, abgetrennt durch ein Leerzeichen.
  809. </para>
  810. <para>
  811. Wie in den <code>from()</code> und <code>group()</code> Methoden, werden Spalten
  812. als Bezeichner Quotiert, wenn sie nicht von runden Klammern eingeschlossen oder vom
  813. Objekttyp <classname>Zend_Db_Expr</classname> sind.
  814. </para>
  815. <example id="zend.db.select.building.order.example">
  816. <title>Beispiel für die order() Methode</title>
  817. <programlisting language="php"><![CDATA[
  818. // Erzeugt diese Anfrage:
  819. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  820. // FROM "products" AS p JOIN "line_items" AS l
  821. // ON p.product_id = l.product_id
  822. // GROUP BY p.product_id
  823. // ORDER BY "line_items_per_product" DESC, "product_id"
  824. $select = $db->select()
  825. ->from(array('p' => 'products'),
  826. array('product_id'))
  827. ->join(array('l' => 'line_items'),
  828. 'p.product_id = l.product_id',
  829. array('line_items_per_product' => 'COUNT(*)'))
  830. ->group('p.product_id')
  831. ->order(array('line_items_per_product DESC',
  832. 'product_id'));
  833. ]]></programlisting>
  834. </example>
  835. </sect3>
  836. <sect3 id="zend.db.select.building.limit">
  837. <title>Hinzufügen eines LIMIT Abschnitts</title>
  838. <para>
  839. Einige RDBMS Marken erweitern SQL mit einem Anfrage Abschnitt, bekannt als
  840. <code>LIMIT</code> Abschnitt. Dieser Abschnitt begrenzt die Anzahl der Zeilen in
  841. einem Ergebnissatz auf die angegebene Höchstanzahl. Es kann ebenfalls angegeben
  842. werden, dass eine Anzahl von Zeilen ausgelassen werden soll. Dieses Feature erlaubt
  843. es eine Untermenge des Ergebnissatzes zu holen, zum Beispiel wenn Anfrage
  844. Ergebnisse auf aufeinander folgenden Seiten angezeigt werden sollen.
  845. </para>
  846. <para>
  847. In <classname>Zend_Db_Select</classname> kann die <code>limit()</code> Methode
  848. verwendet werden um die Anzahl von Zeilen und die Anzahl der auszulassenden Spalten
  849. anzugeben. Das erste Argument ist die gewünschte Anzahl von Zeilen. Das zweite
  850. Argument gibt die Anzahl der auszulassenden Zeilen an.
  851. </para>
  852. <example id="zend.db.select.building.limit.example">
  853. <title>Beispiel für die limit() Methode</title>
  854. <programlisting language="php"><![CDATA[
  855. // Erzeugt diese Anfrage:
  856. // SELECT p."product_id", p."product_name"
  857. // FROM "products" AS p
  858. // LIMIT 10, 20
  859. $select = $db->select()
  860. ->from(array('p' => 'products'),
  861. array('product_id', 'product_name'))
  862. ->limit(10, 20);
  863. ]]></programlisting>
  864. </example>
  865. <note>
  866. <para>
  867. Die <code>LIMIT</code> Syntax wird nicht von allen RDBMS Marken unterstützt.
  868. Einige RDBMS benötigen eine unterschiedliche Syntax für eine ähnliche
  869. Funktionalität. Jede <classname>Zend_Db_Adapter_Abstract</classname> Klasse
  870. enthält eine Methode um für das RDBMS passende Syntax zu erzeugen.
  871. </para>
  872. </note>
  873. <para>
  874. Die <code>limitPage()</code> Methode kann als alternativer Weg verwendet werden um
  875. Zeilenanzahl und Offset zu spezifizieren. Diese Methode erlaubt den Ergebnissatz
  876. auf einen Subset, aus einer Serie von Subsets mit Reihen einer fixe Länge, auf dem
  877. totalen Ergebnissatz der Abfrage, zu limitieren. In anderen Worten, spezifiziert
  878. man die Länge einer Seite ("page") von Ergebnissen, und die ordinale Anzahl an
  879. Ergebnissen einer einzelnen Seite, die als von der Abfrage zurück gegeben werden
  880. sollen. Die Seitennummer ist das erste Argument der <code>limitPage()</code>
  881. Methode, nud die Seitenlänge ist das zweite Argument. Beide Argumente werden
  882. benötigt; sie haben keinen Standardwert.
  883. </para>
  884. <example id="zend.db.select.building.limit.example2">
  885. <title>Beispiel der limitPage() Methode</title>
  886. <programlisting language="php"><![CDATA[
  887. // Erstelle diese Abfrage:
  888. // SELECT p."product_id", p."product_name"
  889. // FROM "products" AS p
  890. // LIMIT 10, 20
  891. $select = $db->select()
  892. ->from(array('p' => 'products'),
  893. array('product_id', 'product_name'))
  894. ->limitPage(2, 10);
  895. ]]></programlisting>
  896. </example>
  897. </sect3>
  898. <sect3 id="zend.db.select.building.distinct">
  899. <title>Hinzufügen des DISTINCT Anfragewandlers</title>
  900. <para>
  901. Die <code>distinct()</code> Methode ermöglicht es <code>DISTINCT</code>
  902. Schlüsselworte in die SQL Syntax einzufügen.
  903. </para>
  904. <example id="zend.db.select.building.distinct.example">
  905. <title>Beispiel für die distinct() Methode</title>
  906. <programlisting language="php"><![CDATA[
  907. // Erzeugt diese Anfrage:
  908. // SELECT DISTINCT p."product_name"
  909. // FROM "products" AS p
  910. $select = $db->select()
  911. ->distinct()
  912. ->from(array('p' => 'products'), 'product_name');
  913. ]]></programlisting>
  914. </example>
  915. </sect3>
  916. <sect3 id="zend.db.select.building.for-update">
  917. <title>Hinzufügen des FOR UPDATE Anfragewandlers</title>
  918. <para>
  919. Die <code>forUpdate()</code> Methode ermöglicht es <code>FOR UPDATE</code>
  920. Schlüsselworte in die SQL Syntax einzufügen.
  921. </para>
  922. <example id="zend.db.select.building.for-update.example">
  923. <title>Beispiel der forUpdate() Methode</title>
  924. <programlisting language="php"><![CDATA[
  925. // Erzeugt diese Anfrage:
  926. // SELECT FOR UPDATE p.*
  927. // FROM "products" AS p
  928. $select = $db->select()
  929. ->forUpdate()
  930. ->from(array('p' => 'products'));
  931. ]]></programlisting>
  932. </example>
  933. </sect3>
  934. </sect2>
  935. <sect2 id="zend.db.select.execute">
  936. <title>Ausführen von SELECT Anfrage</title>
  937. <para>
  938. Dieser Abschnitt beschreibt wie Anfragen ausgeführt werden, die durch ein
  939. <classname>Zend_Db_Select</classname> Objekt repräsentiert werden.
  940. </para>
  941. <sect3 id="zend.db.select.execute.query-adapter">
  942. <title>Ausführen von Select Anfragen aus dem Db Adapter</title>
  943. <para>
  944. Die Anfrage, die durch das <classname>Zend_Db_Select</classname> Objekt
  945. repräsentiert wird kann ausgeführt werden, indem sie als erstes Argument an die
  946. <code>query()</code> Methode des <classname>Zend_Db_Adapter_Abstract</classname>
  947. Objekts übergeben wird. Dabei wird das <classname>Zend_Db_Select</classname>
  948. anstelle eines Strings verwendet.
  949. </para>
  950. <para>
  951. Die <code>query()</code> Methode gibt ein Objekt vom Typ
  952. <classname>Zend_Db_Statement</classname> oder PDOStatement zurück, je nachdem
  953. welcher Adaptertyp verwendet wird.
  954. </para>
  955. <example id="zend.db.select.execute.query-adapter.example">
  956. <title>Beispiel für die Nutzung der query() Methode des Db Adapters</title>
  957. <programlisting language="php"><![CDATA[
  958. $select = $db->select()
  959. ->from('products');
  960. $stmt = $db->query($select);
  961. $result = $stmt->fetchAll();
  962. ]]></programlisting>
  963. </example>
  964. </sect3>
  965. <sect3 id="zend.db.select.execute.query-select">
  966. <title>Ausführen von Select Anfragen mit dem objekt</title>
  967. <para>
  968. Als Alternative zur Nutzung der <code>query()</code> Methode des Adapterobjekts
  969. kann auch die <code>query()</code> Methode des <classname>Zend_Db_Select</classname>
  970. Objekts verwendet werden. Beide Methoden geben ein Objekt vom Typ
  971. <classname>Zend_Db_Statement</classname> oder PDOStatement zurück, je nachdem
  972. welcher Adaptertyp verwendet wird.
  973. </para>
  974. <example id="zend.db.select.execute.query-select.example">
  975. <title>Beispiel für die Nutzung der query() Methode des Select Objekts</title>
  976. <programlisting language="php"><![CDATA[
  977. $select = $db->select()
  978. ->from('products');
  979. $stmt = $select->query();
  980. $result = $stmt->fetchAll();
  981. ]]></programlisting>
  982. </example>
  983. </sect3>
  984. <sect3 id="zend.db.select.execute.tostring">
  985. <title>Konvertieren eines Select Objekts in einen SQL String</title>
  986. <para>
  987. Wenn Zugriff zu auf eine String Repräsentante der SQL Anfrage, entsprechend dem
  988. <classname>Zend_Db_Select</classname>, benötigt wird, kann die
  989. <code>__toString()</code> Methode verwendet werden.
  990. </para>
  991. <example id="zend.db.select.execute.tostring.example">
  992. <title>Beispiel für die __toString() Methode</title>
  993. <programlisting language="php"><![CDATA[
  994. $select = $db->select()
  995. ->from('products');
  996. $sql = $select->__toString();
  997. echo "$sql\n";
  998. // Ausgabe ist dieser String:
  999. // SELECT * FROM "products"
  1000. ]]></programlisting>
  1001. </example>
  1002. </sect3>
  1003. </sect2>
  1004. <sect2 id="zend.db.select.other">
  1005. <title>Andere Methoden</title>
  1006. <para>
  1007. Dieser Abschnitt beschreibt andere Methoden der <classname>Zend_Db_Select</classname>
  1008. Klasse, welche bisher nicht beschrieben wurden: <code>getPart()</code> und
  1009. <code>reset()</code>.
  1010. </para>
  1011. <sect3 id="zend.db.select.other.get-part">
  1012. <title>Abfragen von Teilen des Select Objekts</title>
  1013. <para>
  1014. Die <code>getPart()</code> Methode gibt eine Repräsentante eines Teils der SQL
  1015. Anfrage zurück. Zum Beispiel kann diese Methode verwendet werden um, ein Array von
  1016. Expressions des <code>WHERE</code> Abschnitts, ein Array von Spalten (oder Spalten
  1017. Expressions) von <code>SELECT</code> oder die Werte der Spaltenzahl und
  1018. Auslassungen des <code>LIMIT</code> Abschnitts, zu erhalten.
  1019. </para>
  1020. <para>
  1021. Die Rückgabe ist kein String der ein Fragment der SQL Syntax enthält. Der
  1022. Rückgabewert ist eine interne Repräsentante, was typischerweise eine Arraystruktur
  1023. ist, welche Werte und Expressions enthält. Jeder Teil der Anfrage hat eine
  1024. unterschiedliche Struktur.
  1025. </para>
  1026. <para>
  1027. Das einzige Argument der <code>getPart()</code> Methode ist ein String der den
  1028. zurück zu gebenden Teil der Anfrage bezeichnet. Zum Beispiel bezeichnet der String
  1029. <code>'from'</code> den Teil des Select Objekts, welcher Informationen über den
  1030. <code>FROM</code> Abschnitt, einschließlich verbundener Tabellen enthält.
  1031. </para>
  1032. <para>
  1033. Die <classname>Zend_Db_Select</classname> Klasse definiert Konstanten die für Teile
  1034. der SQL Anfrage verwendet werden können. Es können die Konstantendefinitionen oder
  1035. die literalen Strings verwendet werden.
  1036. </para>
  1037. <table id="zend.db.select.other.get-part.table">
  1038. <title>Konstanten die von getPart() und reset() verwendet werden</title>
  1039. <tgroup cols="2">
  1040. <thead>
  1041. <row>
  1042. <entry>Konstante</entry>
  1043. <entry>String Wert</entry>
  1044. </row>
  1045. </thead>
  1046. <tbody>
  1047. <row>
  1048. <entry><classname>Zend_Db_Select::DISTINCT</classname></entry>
  1049. <entry><code>'distinct'</code></entry>
  1050. </row>
  1051. <row>
  1052. <entry><classname>Zend_Db_Select::FOR_UPDATE</classname></entry>
  1053. <entry><code>'forupdate'</code></entry>
  1054. </row>
  1055. <row>
  1056. <entry><classname>Zend_Db_Select::COLUMNS</classname></entry>
  1057. <entry><code>'columns'</code></entry>
  1058. </row>
  1059. <row>
  1060. <entry><classname>Zend_Db_Select::FROM</classname></entry>
  1061. <entry><code>'from'</code></entry>
  1062. </row>
  1063. <row>
  1064. <entry><classname>Zend_Db_Select::WHERE</classname></entry>
  1065. <entry><code>'where'</code></entry>
  1066. </row>
  1067. <row>
  1068. <entry><classname>Zend_Db_Select::GROUP</classname></entry>
  1069. <entry><code>'group'</code></entry>
  1070. </row>
  1071. <row>
  1072. <entry><classname>Zend_Db_Select::HAVING</classname></entry>
  1073. <entry><code>'having'</code></entry>
  1074. </row>
  1075. <row>
  1076. <entry><classname>Zend_Db_Select::ORDER</classname></entry>
  1077. <entry><code>'order'</code></entry>
  1078. </row>
  1079. <row>
  1080. <entry><classname>Zend_Db_Select::LIMIT_COUNT</classname></entry>
  1081. <entry><code>'limitcount'</code></entry>
  1082. </row>
  1083. <row>
  1084. <entry><classname>Zend_Db_Select::LIMIT_OFFSET</classname></entry>
  1085. <entry><code>'limitoffset'</code></entry>
  1086. </row>
  1087. </tbody>
  1088. </tgroup>
  1089. </table>
  1090. <example id="zend.db.select.other.get-part.example">
  1091. <title>Beispiel der getPart() Methode</title>
  1092. <programlisting language="php"><![CDATA[
  1093. $select = $db->select()
  1094. ->from('products')
  1095. ->order('product_id');
  1096. // Ein literaler String kann verwendet werden um den Abschnitt zu definieren
  1097. $orderData = $select->getPart( 'order' );
  1098. // Eine Konstante kann verwendet werden um den selben Abschnitt zu definieren
  1099. $orderData = $select->getPart( Zend_Db_Select::ORDER );
  1100. // Der zurückgegebene Wert kann eine Array Struktur sein, kein String.
  1101. // Jeder Abschnitt hat eine unterschiedliche Struktur.
  1102. print_r( $orderData );
  1103. ]]></programlisting>
  1104. </example>
  1105. </sect3>
  1106. <sect3 id="zend.db.select.other.reset">
  1107. <title>Zurücksetzen von Teilen des Select Objekts</title>
  1108. <para>
  1109. Die <code>reset()</code> Methode ermöglicht es einen angegebenen Teil der SQL
  1110. Anfrage zu löschen oder, wenn der Parameter ausgelassen ist, alle Teile zu löschen.
  1111. </para>
  1112. <para>
  1113. Das einzige Argument ist optional. Es kann der Teil der Anfrage angegeben werden,
  1114. der gelöscht werden soll, unter Nutzung des gleichen Strings wie er als Argument
  1115. der <code>getPart()</code> Methode verwendet wird. Der angegebene Teil wird auf ein
  1116. Standardwert zurück gesetzt.
  1117. </para>
  1118. <para>
  1119. Wenn der Parameter ausgelassen wird, setzt <code>reset()</code> alle geänderten
  1120. Teile auf einen Standardwert zurück. Dadurch ist das
  1121. <classname>Zend_Db_Select</classname> Objekt gleichwertig mit einem neuen Objekt,
  1122. wie wenn es gerade Instanziiert wurde.
  1123. </para>
  1124. <example id="zend.db.select.other.reset.example">
  1125. <title>Beispiel der reset() Methode</title>
  1126. <programlisting language="php"><![CDATA[
  1127. // Erzeugt diese Anfrage:
  1128. // SELECT p.*
  1129. // FROM "products" AS p
  1130. // ORDER BY "product_name"
  1131. $select = $db->select()
  1132. ->from(array('p' => 'products')
  1133. ->order('product_name');
  1134. // Geänderte Anforderungen, stattdessen sortiert nach einer anderen Spalte:
  1135. // SELECT p.*
  1136. // FROM "products" AS p
  1137. // ORDER BY "product_id"
  1138. // Lösche einen Abschnitt damit er neu defniert werden kann
  1139. $select->reset( Zend_Db_Select::ORDER );
  1140. // und definiere eine andere Spalte
  1141. $select->order('product_id');
  1142. // Lösche alle Abschnitte von der Abfrage
  1143. $select->reset();
  1144. ]]></programlisting>
  1145. </example>
  1146. </sect3>
  1147. </sect2>
  1148. </sect1>
  1149. <!--
  1150. vim:se ts=4 sw=4 et:
  1151. -->