Zend_Db_Select.xml 59 KB

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