Zend_Db_Select.xml 63 KB

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