Zend_Db_Select.xml 60 KB

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