Zend_Db_Table.xml 67 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15851 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.table">
  5. <title>Zend_Db_Table</title>
  6. <sect2 id="zend.db.table.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. Die <classname>Zend_Db_Table</classname> Klasse ist eine Objekt-Orientierte
  10. Schnittstelle zu Datenbank Tabellen. Sie bietet Methoden für viele gängige Operationen
  11. an Tabellen. Die Basisklasse ist erweiterbar, daher kann eigene Logik eingeführt werden.
  12. </para>
  13. <para>
  14. Die <classname>Zend_Db_Table</classname> Lösung ist eine Implementation des
  15. <ulink url="http://www.martinfowler.com/eaaCatalog/tableDataGateway.html">Table Data
  16. Gateway</ulink> Patterns. Die Lösung schließt außerdem eine Klasse ein, welche das
  17. <ulink url="http://www.martinfowler.com/eaaCatalog/rowDataGateway.html">Row Data
  18. Gateway</ulink> Pattern implementiert.
  19. </para>
  20. </sect2>
  21. <sect2 id="zend.db.table.defining">
  22. <title>Definieren einer Table Klasse</title>
  23. <para>
  24. Für jede Tabelle der Datenbank auf die zugegriffen werden soll, sollte eine eine Klasse
  25. erzeugt werden, welche <classname>Zend_Db_Table_Abstract</classname> erweitert.
  26. </para>
  27. <sect3 id="zend.db.table.defining.table-schema">
  28. <title>Definieren des Tabellennamens und Schemas</title>
  29. <para>
  30. Die Tabelle der Datenbank, für welche die Klasse bestimmt ist, wird mit der
  31. protected Variablen <varname>$_name</varname> angegeben. Es ist ein String, welcher den
  32. Namen der Tabelle enthalten muss, wie er in der Datenbank erscheint.
  33. </para>
  34. <example id="zend.db.table.defining.table-schema.example1">
  35. <title>Angeben einer Table Klasse mit ausdrücklichem Tabellennamen</title>
  36. <programlisting language="php"><![CDATA[
  37. class Bugs extends Zend_Db_Table_Abstract
  38. {
  39. protected $_name = 'bugs';
  40. }
  41. ]]></programlisting>
  42. </example>
  43. <para>
  44. Wird keine Tabellenname angegeben, so wird ein Standard verwendet, welcher dem
  45. Namen der Klasse entspricht. Wird sich auf diesen Standard verlassen, so muss der
  46. Klassenname der Schreibweise der Tabelle entsprechen, wie sie in der Datenbank
  47. erscheint.
  48. </para>
  49. <example id="zend.db.table.defining.table-schema.example">
  50. <title>Angeben einer Table Klasse mit inbegriffenem Tabellennamen</title>
  51. <programlisting language="php"><![CDATA[
  52. class bugs extends Zend_Db_Table_Abstract
  53. {
  54. // Tabellenname entspricht dem Klassennamen
  55. }
  56. ]]></programlisting>
  57. </example>
  58. <para>
  59. Es kann auch ein Schema für die Tabelle angegeben werden. Entweder mit der protected
  60. Variablen <varname>$_schema</varname> oder mit dem Schema vorangestellt in der
  61. <varname>$_name</varname> Eigenschaft. Jedes Schema welches in der <varname>$_name</varname>
  62. Eigenschaft angegeben ist wird vorrangig gegenüber dem Schema der
  63. <varname>$_schema</varname> Eigenschaft behandelt. In einigen RDBMS Marken ist die
  64. Bezeichnung für Schema "database" oder "tablespace", wird aber ähnlich verwendet.
  65. </para>
  66. <example id="zend.db.table.defining.table-schema.example3">
  67. <title>Angeben einer Table Klasse mit Schema</title>
  68. <programlisting language="php"><![CDATA[
  69. // Erste Möglichkeit:
  70. class Bugs extends Zend_Db_Table_Abstract
  71. {
  72. protected $_schema = 'bug_db';
  73. protected $_name = 'bugs';
  74. }
  75. // Zweite Möglichkeit:
  76. class Bugs extends Zend_Db_Table_Abstract
  77. {
  78. protected $_name = 'bug_db.bugs';
  79. }
  80. // Wenn Schema sowohl in $_name als auch $_schema angegeben wird, so bekommt $_name vorrang:
  81. class Bugs extends Zend_Db_Table_Abstract
  82. {
  83. protected $_name = 'bug_db.bugs';
  84. protected $_schema = 'ignored';
  85. }
  86. ]]></programlisting>
  87. </example>
  88. <para>
  89. Die Schema und Tabellennamen können auch mit Konstruktor Konfigurationsdirektiven
  90. angegeben werden, welche jegliche Standardwerte, angegeben in den
  91. <varname>$_name</varname> und <varname>$_schema</varname> Eigenschaften, überschreiben. Eine
  92. Schema Angabe welche mit der <code>name</code> Directive angegeben wurde
  93. überschreibt jeglichen Wert welcher von der <code>schema</code> Option
  94. bereitgestellt ist.
  95. </para>
  96. <example id="zend.db.table.defining.table-schema.example.constructor">
  97. <title>Angebend von Tabellen und Schemanamen während der Instanziierung</title>
  98. <programlisting language="php"><![CDATA[
  99. class Bugs extends Zend_Db_Table_Abstract
  100. {
  101. }
  102. // Erste Möglichkeit:
  103. $tableBugs = new Bugs(array('name' => 'bugs', 'schema' => 'bug_db'));
  104. // Zweite Möglichkeit:
  105. $tableBugs = new Bugs(array('name' => 'bug_db.bugs'));
  106. // Wenn Schema sowohl in $_name als auch $_schema angegeben wird,
  107. // so bekommt $_name vorrang:
  108. $tableBugs = new Bugs(array('name' => 'bug_db.bugs',
  109. 'schema' => 'ignored'));
  110. ]]></programlisting>
  111. </example>
  112. <para>
  113. Wenn kein Schemaname angegeben wird, so wird als Standard der Schemaname des
  114. Datenbankadapters verwendet.
  115. </para>
  116. </sect3>
  117. <sect3 id="zend.db.table.defining.primary-key">
  118. <title>Angeben des Primärschlüssels der Tabelle</title>
  119. <para>
  120. Jede Tabelle muss einen Primärschlüssel haben. Die Spalte des Primärschlüssels kann
  121. mit der protected Variablen <varname>$_primary</varname> angegeben werden. Sie enthält
  122. entweder einen String, welcher die einzelen Spalte benennt, oder ein Array von
  123. Spaltennamen, wenn der Primärschlüssel ein zusammengesetzter Schlüssel ist.
  124. </para>
  125. <example id="zend.db.table.defining.primary-key.example">
  126. <title>Beispiel für das spezifizieren eines Primärschlüssels</title>
  127. <programlisting language="php"><![CDATA[
  128. class Bugs extends Zend_Db_Table_Abstract
  129. {
  130. protected $_name = 'bugs';
  131. protected $_primary = 'bug_id';
  132. }
  133. ]]></programlisting>
  134. </example>
  135. <para>
  136. Wenn kein Primärschlüssel angegeben wird, versucht
  137. <classname>Zend_Db_Table_Abstract</classname> den Primärschlüssel mit Hilfe der
  138. <code>describeTable()</code> Methode zu ermitteln.
  139. </para>
  140. <note>
  141. <para>
  142. Jede Table Klasse muss wissen mit welche(r/n) Spalte(n) Zeilen eindeutig
  143. identifiziert werden können. Wenn keine Primärschlüssel Spalte(n) in der
  144. Klassendefinition oder als Argument für den Konstruktor angegeben wurde und
  145. nicht aus den Metadaten der Tabelle mit Hilfe der <code>describeTable()</code>
  146. Methode ermittelt werden kann, dann kann die Tabelle nicht mit
  147. <classname>Zend_Db_Table</classname> verwendet werden.
  148. </para>
  149. </note>
  150. </sect3>
  151. <sect3 id="zend.db.table.defining.setup">
  152. <title>Überschreiben von Table Setup Methoden</title>
  153. <para>
  154. Wenn eine Instanz einer Table Klasse erzeugt wird, ruft der Konstruktor einige
  155. protected Methoden auf, die Metadaten der Tabelle initialisieren. Jede dieser
  156. Methoden kann erweitert werden um Metadaten explizit anzugeben. Dabei darf nicht
  157. vergessen werden am Ende der eigenen Methode die gleichnamige Methode der
  158. Parentklasse aufzurufen.
  159. </para>
  160. <example id="zend.db.table.defining.setup.example">
  161. <title>Beispiel für das Überschreiben der _setupTableName() Methode</title>
  162. <programlisting language="php"><![CDATA[
  163. class Bugs extends Zend_Db_Table_Abstract
  164. {
  165. protected function _setupTableName()
  166. {
  167. $this->_name = 'bugs';
  168. parent::_setupTableName();
  169. }
  170. }
  171. ]]></programlisting>
  172. </example>
  173. <para>
  174. Folgende Setup Methoden sind überschreibbar:
  175. </para>
  176. <itemizedlist>
  177. <listitem>
  178. <para>
  179. <code>_setupDatabaseAdapter()</code> überprüft ob ein Adapter bereitgestellt
  180. wird; nimmt einen Standardadapter aus der Registry, wenn benötigt. Durch das
  181. Überschreiben dieser Methode kann ein Datenbankadapter aus einer anderen
  182. Quelle gesetzt werden.
  183. </para>
  184. </listitem>
  185. <listitem>
  186. <para>
  187. <code>_setupTableName()</code> setzt den standard Tabellennamen auf den
  188. Namen der Klasse. Durch das Überschreiben dieser Methode kann der
  189. Tabellenname gesetzt werden bevor dieses Standardverhalten abläuft.
  190. </para>
  191. </listitem>
  192. <listitem>
  193. <para>
  194. <code>_setupMetadata()</code> setzt das Schema wenn der Tabellenname dem
  195. Muster "schema.table" entspricht; ruft <code>describeTable()</code> auf um
  196. Metadaten Informationen zu erhalten; Standardisiert das <varname>$_cols</varname>
  197. Array auf die Spalten wie von <code>describeTable()</code> geliefert. Durch
  198. das Überschreiben dieser Methode können die Spalten angegeben werden.
  199. </para>
  200. </listitem>
  201. <listitem>
  202. <para>
  203. <code>_setupPrimaryKey()</code> standardisiert die Primärschlüssel Spalten
  204. zu denen geliefert von <code>describeTable()</code>; prüft ob die
  205. Primärschlüssel Spalten im <varname>$_cols</varname> Array enthalten sind. Durch
  206. das Überschreiben dieser Methode können die Primärschlüssel Spalten
  207. angegeben werden.
  208. </para>
  209. </listitem>
  210. </itemizedlist>
  211. </sect3>
  212. <sect3 id="zend.db.table.initialization">
  213. <title>Tabellen Initialisierung</title>
  214. <para>
  215. Wenn Anwendungs-spezifische Logik initialisiert werden soll wenn eine Tabellenklasse
  216. erstellt wird, kann man entscheiden die Aufgaben in die <code>init()</code> Methode
  217. zu verschieben, die aufgerufen wird nachdem alle Tabellen Metadaten bearbeitet
  218. wurden. Das ist besser als die <code>__construct</code> Methode wenn die Metadaten
  219. nicht programmtechnisch verändert werden sollen.
  220. </para>
  221. <example id="zend.db.table.defining.init.usage.example">
  222. <title>Beispielverwendung der init() Methode</title>
  223. <programlisting language="php"><![CDATA[
  224. class Bugs extends Zend_Db_Table_Abstract
  225. {
  226. protected $_observer;
  227. public function init()
  228. {
  229. $this->_observer = new MyObserverClass();
  230. }
  231. }
  232. ]]></programlisting>
  233. </example>
  234. </sect3>
  235. </sect2>
  236. <sect2 id="zend.db.table.constructing">
  237. <title>Erzeugen einer Instanz einer Tabelle</title>
  238. <para>
  239. Bevor eine Table Klasse verwendet werden kann muss eine Instanz mit dem Konstruktor
  240. erzeugt werden. Das Konstruktor Argument ist ein Array von Optionen. Die wichtigste
  241. Option für einen Tabellenkonstruktor ist die Instanz der Adapterklasse, welche eine live
  242. Verbindung zu einem RDBMS repräsentiert. Es gibt drei Möglichkeiten den Datenbankadapter
  243. einer Tabellenklasse anzugeben und diese sind unten beschrieben:
  244. </para>
  245. <sect3 id="zend.db.table.constructing.adapter">
  246. <title>Angeben eines Datenbankadapters</title>
  247. <para>
  248. Der erste Weg einen Datenbankadapter an eine Table Klasse bereitzustellen ist, ein
  249. Objekt des Typs <classname>Zend_Db_Adapter_Abstract</classname> im Options Array,
  250. bezeichnet mit dem Schlüssel <code>'db'</code>, zu übergeben.
  251. </para>
  252. <example id="zend.db.table.constructing.adapter.example">
  253. <title>
  254. Beispiel für das Erzeugen einer Tabelle mit Nutzung eines Adapterobjekts
  255. </title>
  256. <programlisting language="php"><![CDATA[
  257. $db = Zend_Db::factory('PDO_MYSQL', $options);
  258. $table = new Bugs(array('db' => $db));
  259. ]]></programlisting>
  260. </example>
  261. </sect3>
  262. <sect3 id="zend.db.table.constructing.default-adapter">
  263. <title>Setzen eines Standard-Datenbankadapters</title>
  264. <para>
  265. Der zweite Weg einer Table Klasse einen Datenbankadapter bereit zu stellen ist es,
  266. ein Objekt des Typs <classname>Zend_Db_Adapter_Abstract</classname> zu deklarieren
  267. und als Standard für alle nachfolgenden Instanzen von Table der Applikation zu
  268. setzen. Dies kann mit der static Methode
  269. <classname>Zend_Db_Table_Abstract::setDefaultAdapter()</classname> getan werden. Das
  270. Argument ist ein Objekt des Typs <classname>Zend_Db_Adapter_Abstract</classname>.
  271. </para>
  272. <example id="zend.db.table.constructing.default-adapter.example">
  273. <title>Beispiel für das erstellen von Table mit einem Standardadapter</title>
  274. <programlisting language="php"><![CDATA[
  275. $db = Zend_Db::factory('PDO_MYSQL', $options);
  276. Zend_Db_Table_Abstract::setDefaultAdapter($db);
  277. // Später...
  278. $table = new Bugs();
  279. ]]></programlisting>
  280. </example>
  281. <para>
  282. Es kann geeignet sein den Datenbankadapter an einer zentralen Stelle der Anwendung,
  283. wie dem Bootstrap, zu erzeugen, und als Standardadapter zu speichern. Dies hilft
  284. sicher zu stellen, das der verwendete Adapter in der gesamten Anwendung der gleiche
  285. ist. Allerdings kann nur eine einzelne Adapterinstanz als Standardadapter verwendet
  286. werden.
  287. </para>
  288. </sect3>
  289. <sect3 id="zend.db.table.constructing.registry">
  290. <title>Speichern eines Datenbankadapters in der Registry</title>
  291. <para>
  292. Der dritte Weg einer Table Klasse einen Datenbankadapter bereit zu stellen ist es
  293. einen String in dem Optionsarray zu übergeben, auch mit dem <code>'db'</code>
  294. Schlüssel identifiziert. Der String wird als Schlüssel der statischen
  295. <classname>Zend_Registry</classname> Instanz verwendet, wo der Eintrag mit dem
  296. Schlüssel ein Objekt des Typs <classname>Zend_Db_Adapter_Abstract</classname> ist.
  297. </para>
  298. <example id="zend.db.table.constructing.registry.example">
  299. <title>Beispiel für das Erzeugen von Table mit einem Registry Schlüssel</title>
  300. <programlisting language="php"><![CDATA[
  301. $db = Zend_Db::factory('PDO_MYSQL', $options);
  302. Zend_Registry::set('my_db', $db);
  303. // Später...
  304. $table = new Bugs(array('db' => 'my_db'));
  305. ]]></programlisting>
  306. </example>
  307. <para>
  308. Wie das Setzen eines Standardadapters, bietet auch dieses sicher zu stellen das die
  309. gleiche Adapter Instanz in der gesamten Anwendung verwendet wird. Nutzen der
  310. Registry ist flexibler, da mehr als eine Adapterinstanz gepeichert werden kann. Eine
  311. angegebene Adapterinstanz ist spezifisch für eine bestimmte RDBMS Marke und
  312. Datenbankinstanz. Wenn die Anwendung Zugriff auf mehrere Datenbanken benötigt oder
  313. auch mehrere Datenbank Marken, dann müssen mehrere Adapter verwendet werden.
  314. </para>
  315. </sect3>
  316. </sect2>
  317. <sect2 id="zend.db.table.insert">
  318. <title>Zeilen in eine Tabelle einfügen</title>
  319. <para>
  320. Table Objekte können verwendet werden um Zeilen in die Datenbank Tabelle einzufügen auf
  321. der das Table Objekt basiert. Hierzu kann die <code>insert()</code> Methode des Table
  322. Objektes verwendet werden. Das Argument ist ein assoziatives Array, das Spalten Namen
  323. mit Werten verbindet.
  324. </para>
  325. <example id="zend.db.table.insert.example">
  326. <title>Beispiel für das Einfügen in eine Tabelle</title>
  327. <programlisting language="php"><![CDATA[
  328. $table = new Bugs();
  329. $data = array(
  330. 'created_on' => '2007-03-22',
  331. 'bug_description' => 'Irgendwas falsch',
  332. 'bug_status' => 'NEW'
  333. );
  334. $table->insert($data);
  335. ]]></programlisting>
  336. </example>
  337. <para>
  338. Standardmäßig werden Werte im Daten Array als literale Werte eingefügt durch das
  339. Verwenden von Parametern. Wenn es notwendig ist das diese als SQL Ausdruck behandelt
  340. werden, muß sichergestellt werden das Sie sich von reinen Strings unterscheiden. Es kann
  341. ein Objekt vom Typ <classname>Zend_Db_Expr</classname> verwendet werden um das zu
  342. bewerkstelligen.
  343. </para>
  344. <example id="zend.db.table.insert.example-expr">
  345. <title>Beispiel für das Einfügen von Ausdrücken in einer Tabelle</title>
  346. <programlisting language="php"><![CDATA[
  347. $table = new Bugs();
  348. $data = array(
  349. 'created_on' => new Zend_Db_Expr('CURDATE()'),
  350. 'bug_description' => 'Irgendwas ist falsch',
  351. 'bug_status' => 'NEU'
  352. );
  353. ]]></programlisting>
  354. </example>
  355. <para>
  356. Um obigen Beispiel vom Einfügen von Zeilen, wird angenommen das die Tabelle einen automatischen
  357. Primärschlüssel hat. Das ist das Standardverhalten von <classname>Zend_Db_Table_Abstract</classname>,
  358. aber es gibt auch andere Typen von Primärschlüssel. Das folgende Kapitel beschreibt wie
  359. verschiedene Typen von Primärschlüssel unterstützt werden.
  360. </para>
  361. <sect3 id="zend.db.table.insert.key-auto">
  362. <title>Eine Tabelle mit einem automatischen Primärschlüssel verwenden</title>
  363. <para>
  364. Ein automatischer Primärschlüssel erzeigt einen eindeutigen Integerwert wenn die
  365. Spalte des Primären Typs in der eigenen SQL <code>INSERT</code> Anweisung unterdrückt wird.
  366. </para>
  367. <para>
  368. Wenn die geschützte Variable <varname>$_sequence</varname>, in <classname>Zend_Db_Table_Abstract</classname>, als
  369. boolscher Wert <constant>TRUE</constant> definiert wird, nimmt die Klasse an das die Tabelle
  370. einen automatischen Primärschlüssel hat.
  371. </para>
  372. <example id="zend.db.table.insert.key-auto.example">
  373. <title>
  374. Beispiel für das Deklarierens einer Tabelle mit einem automatischen
  375. Primärschlüssel
  376. </title>
  377. <programlisting language="php"><![CDATA[
  378. class Bugs extends Zend_Db_Table_Abstract
  379. {
  380. protected $_name = 'bugs';
  381. // Das ist der Standardwert in der Zend_Db_Table_Abstract Klasse;
  382. // er muß nicht definiert werden.
  383. protected $_sequence = true;
  384. }
  385. ]]></programlisting>
  386. </example>
  387. <para>
  388. MySQL, Microsoft SQL Server, und SQLite sind Beispiele von RDBMS Marken die
  389. automatische Primärschlüssel unterstützen.
  390. </para>
  391. <para>
  392. PostgreSQL hat eine <code>SERIAL</code> Notation die implizit eine Sequenz definiert
  393. die auf den Tabellen- und Spaltennamen basiert, und diese Sequenz verwendet, um
  394. einen Schlüsselwert für neue Zeilen zu erstellen. IBM DB2 hat eine
  395. <code>IDENTITY</code> Notation die ähnlich arbeitet. Wenn eine dieser Notationen
  396. verwendet wird, muß der <classname>Zend_Db_Table</classname> Klasse mitgeteilt
  397. werden das Sie eine automatische Spalte hat, indem <varname>$_sequence</varname> auf
  398. <constant>TRUE</constant> gesetzt wird.
  399. </para>
  400. </sect3>
  401. <sect3 id="zend.db.table.insert.key-sequence">
  402. <title>Eine Tabelle mit einer Sequenz verwenden</title>
  403. <para>
  404. Eine Sequenz ist ein Datenbank Objekt das einen eindeutigen Wert erstellt, der als
  405. Wert des Primärschlüssels in einer oder mehreren Tabellen der Datenbank verwendet
  406. werden kann.
  407. </para>
  408. <para>
  409. Wenn <varname>$_sequence</varname> als String definiert wird, nimmt
  410. <classname>Zend_Db_Table_Abstract</classname> an das der String den Namen des
  411. Sequenz Objektes in der Datenbank benennt. Die Sequenz wird aufgerufen um einen
  412. neuen Wert zu erstellen, und dieser Wert wird in der <code>INSERT</code> Operation
  413. verwendet.
  414. </para>
  415. <example id="zend.db.table.insert.key-sequence.example">
  416. <title>Beispiel für das Deklaration einer Tabelle mit einer Sequenz</title>
  417. <programlisting language="php"><![CDATA[
  418. class Bugs extends Zend_Db_Table_Abstract
  419. {
  420. protected $_name = 'bugs';
  421. protected $_sequence = 'bug_sequence';
  422. }
  423. ]]></programlisting>
  424. </example>
  425. <para>
  426. Oracle, PostgreSQL, und IBM DB2 sind Beispiele von RDBMS Marken die Sequenz Objekte
  427. in der Datenbank unterstützen.
  428. </para>
  429. <para>
  430. PostgreSQL und IBM DB2 haben auch einen Syntax der Sequenzen implizit definiert und
  431. diese mit Spalten assoziiert. Wenn diese Notation verwendet wird, muß der Tabelle
  432. gesagt werden das Sie eine automatische Schlüsselspalte besitzt. Der Name der
  433. Sequenz muß nur in den Fällen als String definiert werden in denen die Sequenz
  434. explizit aufgerufen wird um den nächsten Schlüsselwert zu erhalten.
  435. </para>
  436. </sect3>
  437. <sect3 id="zend.db.table.insert.key-natural">
  438. <title>Eine Tabelle mit einem natürlichen Schlüssel verwenden</title>
  439. <para>
  440. Einige Tabellen haben natürliche Schlüssel. Das bedeutet das der Schlüssel nicht
  441. automatisch durch die Tabelle oder eine Sequenz erstellt wird. Der Wert für den
  442. Primärschlüssel muß in diesem Fall selbst definiert werden.
  443. </para>
  444. <para>
  445. Wenn <varname>$_sequence</varname> als boolsches <constant>FALSE</constant> definiert wird, nimmt
  446. <classname>Zend_Db_Table_Abstract</classname> an das die Tabelle einen natürlichen
  447. Primärschlüssel hat. Es müssen Werte für die Spalte des Primärschlüssels im Array
  448. der Daten definiert werden die an die <code>insert()</code> Methode übergeben
  449. werden, andernfalls wird diese Methode eine
  450. <classname>Zend_Db_Table_Exception</classname> werfen.
  451. </para>
  452. <example id="zend.db.table.insert.key-natural.example">
  453. <title>
  454. Beispiel für das Definieren einer Tabelle mit einem natürlichen Schlüssel
  455. </title>
  456. <programlisting language="php"><![CDATA[
  457. class BugStatus extends Zend_Db_Table_Abstract
  458. {
  459. protected $_name = 'bug_status';
  460. protected $_sequence = false;
  461. }
  462. ]]></programlisting>
  463. </example>
  464. <note>
  465. <para>
  466. Alle RDBMS Marken unterstützen Tabellen mit natürlichen Schlüsseln. Beispiele
  467. von Tabellen die oft so definiert werden das Sie natürliche Schlüssel besitzen
  468. sind Lookup Tabellen, Durchschnitts Tabellen in viele-zu-viele Beziehungen, oder
  469. die meisten Tabellen mit komponierten Primärschlüsseln.
  470. </para>
  471. </note>
  472. </sect3>
  473. </sect2>
  474. <sect2 id="zend.db.table.update">
  475. <title>Zeilen in einer Tabelle aktualisieren</title>
  476. <para>
  477. Spalten können in der Datenbanktabelle aktualisiert werden indem die <code>update</code>
  478. Methode der Table Klasse verwendet wird. Diese Methode nimmt zwei Argumente: ein
  479. assoziatives Array von Spalten die geändert werden sollen und neue Werte die diesen
  480. Spalten hinzugefügt werden; und einen SQL Ausdruck der in der <code>WHERE</code> Klausel
  481. verwendet wird, als Kriterium für die Zeilen die in der <code>UPDATE</code> Operation
  482. geändert werden sollen.
  483. </para>
  484. <example id="zend.db.table.update.example">
  485. <title>Beispiel für das Aktualisieren von Zeilen in einer Tabelle</title>
  486. <programlisting language="php"><![CDATA[
  487. $table = new Bugs();
  488. $data = array(
  489. 'updated_on' => '2007-03-23',
  490. 'bug_status' => 'FIXED'
  491. );
  492. $where = $table->getAdapter()->quoteInto('bug_id = ?', 1234);
  493. $table->update($data, $where);
  494. ]]></programlisting>
  495. </example>
  496. <para>
  497. Da die <code>update()</code> Methode der Tabelle zur
  498. <link linkend="zend.db.adapter.write.update"><code>update()</code></link> Methode des
  499. Datenbank Adapters weiterleitet, kann das zweite Argument ein Array von SQL Ausdrücken
  500. sein. Diese Ausdrücke werden als Boolsche Terme kombiniert indem ein <code>AND</code>
  501. Operator verwendet wird.
  502. </para>
  503. <note>
  504. <para>
  505. Die Werte und Identifizierer im SQL Ausdruck werden nicht in Anführungszeichen
  506. gesetzt. Wenn Werte oder Identifizierer vorhanden sind die das Setzen in
  507. Anführungszeichen benötigen, ist man selbst dafür zuständig das das getan wird. Die
  508. <code>quote()</code>, <code>quoteInto()</code> und <code>quoteIdentifier()</code>
  509. Methoden des Datenbank Adapters können dafür verwendet werden.
  510. </para>
  511. </note>
  512. </sect2>
  513. <sect2 id="zend.db.table.delete">
  514. <title>Zeilen aus einer Tabelle löschen</title>
  515. <para>
  516. Zeilen können von einer Datenbanktabelle gelöscht werden indem die <code>delete()</code>
  517. Methode verwendet wird. Diese Methode nimmt ein Argument, welches ein SQL Ausdruck ist,
  518. der in der <code>WHERE</code> Klausel als Kriterium dafür verwendet wird, welche Zeilen
  519. gelöscht werden sollen.
  520. </para>
  521. <example id="zend.db.table.delete.example">
  522. <title>Beispiel für das Löschen von Zeilen einer Tabelle</title>
  523. <programlisting language="php"><![CDATA[
  524. $table = new Bugs();
  525. $where = $table->getAdapter()->quoteInto('bug_id = ?', 1235);
  526. $table->delete($where);
  527. ]]></programlisting>
  528. </example>
  529. <para>
  530. Da die <code>delete()</code> Methode der Tabelle zur
  531. <link linkend="zend.db.adapter.write.delete"><code>delete()</code></link> Methode des
  532. Datenbank Adapters weiterleitet, kann das Argument ein Array von SQL Ausdrücken sein.
  533. Diese Ausdrücke werden als boolsche Terme kombiniert indem ein <code>AND</code> Operator
  534. verwendet wird.
  535. </para>
  536. <note>
  537. <para>
  538. Die Werte und Identifizierer im SQL Ausdruck werden nicht in Anführungszeichen
  539. gesetzt. Wenn Werte oder Identifizierer vorhanden sind die das Setzen in
  540. Anführungszeichen benötigen, ist man selbst dafür zuständig das das getan wird. Die
  541. <code>quote()</code>, <code>quoteInto()</code> und <code>quoteIdentifier()</code>
  542. Methoden des Datenbank Adapters können dafür verwendet werden.
  543. </para>
  544. </note>
  545. </sect2>
  546. <sect2 id="zend.db.table.find">
  547. <title>Zeilen durch den Primärschlüssel finden</title>
  548. <para>
  549. Die Datenbanktabelle kann nach passenden Zeilen für spezifizierte Werte im
  550. Primärschlüssel abgefragt werden, indem die <code>find()</code> Methode verwendet wird.
  551. Das erste Argument dieser Methode ist entweder ein einzelner Wert oder ein Array von
  552. Werten die dem Primärschlüssel dieser Tabelle entsprechen.
  553. </para>
  554. <example id="zend.db.table.find.example">
  555. <title>Beispiel für das Finden von Zeilen durch Werte des Primärschlüssels</title>
  556. <programlisting language="php"><![CDATA[
  557. $table = new Bugs();
  558. // Eine einzelne Zeile finden
  559. // Gibt ein Rowset zurück
  560. $rows = $table->find(1234);
  561. // Mehrere Zeilen finden
  562. // Gibt auch ein Rowset zurück
  563. $rows = $table->find(array(1234, 5678));
  564. ]]></programlisting>
  565. </example>
  566. <para>
  567. Wenn ein einzelner Wert spezifiziert wird, gibt die Methode auch maximal eine Zeile
  568. zurück, weil ein Primärschlüssel keinen doppelten Wert haben kann und es maximal eine
  569. Zeile in der Datenbank gibt die dem spezifizierten Wert entspricht. Wenn mehrere Werte
  570. in einem Array spezifiziert werden, gibt die Methode maximal soviele Zeilen zurück wie
  571. die Anzahl an unterschiedlichen Werten die spezifiziert wurden.
  572. </para>
  573. <para>
  574. Die <code>find()</code> Methode kann weniger Zeilen zurückgeben als die Anzahl an Werten
  575. die für den Primärschlüssel definiert wurden, wenn einige der Werte keiner Zeile in der
  576. Datenbank Tabelle entsprechen. Die Methode kann sogar null Zeilen zurückgeben. Weil die
  577. Anzahl an zurückgegebenen Zeilen variabel ist, gibt die <code>find()</code> Methode ein
  578. Objekt vom Typ <classname>Zend_Db_Table_Rowset_Abstract</classname> zurück.
  579. </para>
  580. <para>
  581. Wenn der Primärschlüssel ein komponierter Schlüssel ist, als einer der aus mehreren
  582. Spalten besteht, können die zusätzlichen Spalten als zusätzliche Argumente in der
  583. <code>find()</code> Methode definiert werden. Es müssen soviele Argumente angegeben
  584. werden wie Spalten im Primärschlüssel der Tabelle existieren.
  585. </para>
  586. <para>
  587. Um mehrere Zeilen von einer Tabelle mit einem kombinierten Primärschlüssel zu finden,
  588. muß ein Array für jedes der Argumente übergeben werden. Alle dieser Arrays müssen die
  589. gleiche Anzahl an Elementen haben. Die Werte in jedem Array werden in Tupeln geformt und
  590. gereiht; zum Beispiel definiert das erste Element in allen Array Argumenten den ersten
  591. kombinierten Wert des Primärschlüssels, das zweite Element von allen Arrays definiert
  592. den zweiten kombinierten Wert des Primärschlüssels, und so weiter.
  593. </para>
  594. <example id="zend.db.table.find.example-compound">
  595. <title>
  596. Beispiel für das Finden von Zeilen durch Werte von kombinierten Primärschlüsseln
  597. </title>
  598. <para>
  599. Der Aufruf von <code>find()</code> anbei um mehreren Zeilen zu entsprechen kann zwei
  600. Zeilen in der Datenbank entsprechen. Die erste Zeile muß den Wert des
  601. Primärenschlüssels (1234, 'ABC') haben, und die zweite Zeile den Wert des
  602. Primärschlüssels (5678, 'DEF').
  603. </para>
  604. <programlisting language="php"><![CDATA[
  605. class BugsProducts extends Zend_Db_Table_Abstract
  606. {
  607. protected $_name = 'bugs_products';
  608. protected $_primary = array('bug_id', 'product_id');
  609. }
  610. $table = new BugsProducts();
  611. // Eine einzelne Zeilen mit einem kombinierten Primärschlüssel finden
  612. // Gibt ein Rowset zurück
  613. $rows = $table->find(1234, 'ABC');
  614. // Mehrere Zeilen mit einem kombinierten Primärschlüssel finden
  615. // Gibt auch ein Rowset zurück
  616. $rows = $table->find(array(1234, 5678), array('ABC', 'DEF'));
  617. ]]></programlisting>
  618. </example>
  619. </sect2>
  620. <sect2 id="zend.db.table.fetch-all">
  621. <title>Ein Set von Zeilen abfragen</title>
  622. <sect3 id="zend.db.table.fetch-all.select">
  623. <title>Select API</title>
  624. <para>
  625. <warning>
  626. <para>
  627. Die API für die Hol-Operationen wurde ausgeweitet um einem
  628. <classname>Zend_Db_Table_Select</classname> Objekt zu erlauben die Abfrage
  629. zu modifizieren. Trotzdem wird die veraltete Verwendung der
  630. <code>fetchRow()</code> und <code>fetchAll()</code> Methoden weiterhin ohne
  631. Änderungen funktionieren.
  632. </para>
  633. <para>
  634. Die folgenden Ausdrücke sind gültig und funktionell identisch, trotzdem wird
  635. empfohlen den Code zu aktualisieren um Vorteil aus der neuen Verwendung zu
  636. ziehen wo das möglich ist.
  637. </para>
  638. <para>
  639. <programlisting language="php"><![CDATA[
  640. // Ein Rowset holen
  641. $rows = $table->fetchAll('bug_status = "NEW"', 'bug_id ASC', 10, 0);
  642. $rows = $table->fetchAll($table->select()->where('bug_status = ?', 'NEW')
  643. ->order('bug_id ASC')
  644. ->limit(10, 0));
  645. // Eine einzelne Zeile holen
  646. $row = $table->fetchRow('bug_status = "NEW"', 'bug_id ASC');
  647. $row = $table->fetchRow($table->select()->where('bug_status = ?', 'NEW')
  648. ->order('bug_id ASC'));
  649. ]]></programlisting>
  650. </para>
  651. </warning>
  652. </para>
  653. <para>
  654. Das <classname>Zend_Db_Table_Select</classname> Objekt ist eine Erweiterung des
  655. <classname>Zend_Db_Select</classname> Objekts das spezielle Einschränkungen zu einer
  656. Abfrage hinzufügt. Die Verbesserungen und Einschränkungen sind folgende:
  657. </para>
  658. <itemizedlist>
  659. <listitem>
  660. <para>
  661. Man <emphasis>kann</emphasis> sich entscheiden ein Subset von Zeilen einer
  662. fetchRow oder fetchAll Abfrage zurückzuerhalten. Dann kann Vorteile durch
  663. Optimierung bieten, wenn die Rückgabe eines großes Sets an Ergebnissen für
  664. alle Zeilen nicht gewünscht wird.
  665. </para>
  666. </listitem>
  667. <listitem>
  668. <para>
  669. Man <emphasis>kann</emphasis> Zeilen spezifizieren die Ausdrücke innerhalb
  670. der ausgewählten Tabelle evaluieren. Trotzdem bedeutet das, das die
  671. zurückgegebene Zeile oder Zeilenset <property>readOnly</property> (nur
  672. lesbar) ist und nicht für save() Operationen verwendet werden kann. Eine
  673. <classname>Zend_Db_Table_Row</classname> mit <property>readOnly</property>
  674. Status wird eine Exception werfen wenn eine <code>save()</code> Operation
  675. versucht wird.
  676. </para>
  677. </listitem>
  678. <listitem>
  679. <para>
  680. Man <emphasis>kann</emphasis> JOIN Klauseln auf einer Auswahl erlauben um
  681. Mehrfach-Tabellen Lookups zu erlauben.
  682. </para>
  683. </listitem>
  684. <listitem>
  685. <para>
  686. Man <emphasis>kann keine</emphasis> Spalten von einer geJOINten Tabelle
  687. spezifizieren damit Sie in einer Zeile/Zeilenset zurückgegeben werden. Wenn
  688. das versucht wird, wird ein PHP Fehler getriggert. Das wurde getan um
  689. Sicherzustellen das die Integrität von <classname>Zend_Db_Table gewahrt
  690. bleibt</classname>. z.B. ein <classname>Zend_Db_Table_Row</classname> sollte
  691. nur Spalten referenzieren die von seiner Elterntabelle abgeleitet sind.
  692. </para>
  693. </listitem>
  694. </itemizedlist>
  695. <para>
  696. <example id="zend.db.table.qry.rows.set.simple.usage.example">
  697. <title>Einfache Verwendung</title>
  698. <programlisting language="php"><![CDATA[
  699. $table = new Bugs();
  700. $select = $table->select();
  701. $select->where('bug_status = ?', 'NEW');
  702. $rows = $table->fetchAll($select);
  703. ]]></programlisting>
  704. </example>
  705. </para>
  706. <para>
  707. Flüssige Interfaces sind über alle Komponenten hinweg implementiert, sodas das zu
  708. einer mehr abgekürzteren Form umgeschrieben werden kann.
  709. </para>
  710. <para>
  711. <example id="zend.db.table.qry.rows.set.fluent.interface.example">
  712. <title>Example of fluent interface</title>
  713. <programlisting language="php"><![CDATA[
  714. $table = new Bugs();
  715. $rows =
  716. $table->fetchAll($table->select()->where('bug_status = ?', 'NEW'));
  717. ]]></programlisting>
  718. </example>
  719. </para>
  720. </sect3>
  721. <sect3 id="zend.db.table.fetch-all.usage">
  722. <title>Ein Set von Zeilen abfragen</title>
  723. <para>
  724. Ein Set von Zeilen kann abgefragt werden indem irgendein Kriterium verwendet wird,
  725. das anders als die Werte des Primärschlüssels sind, indem die
  726. <code>fetchAll()</code> Methode der Tabellen Klasse verwendet wird. Diese Methode
  727. gibt ein Objekt vom Typ <classname>Zend_Db_Table_Rowset_Abstract</classname> zurück.
  728. </para>
  729. <example id="zend.db.table.qry.rows.set.finding.row.example">
  730. <title>Beispiel für das Finden von Zeilen durch einen Ausdruck</title>
  731. <programlisting language="php"><![CDATA[
  732. $table = new Bugs();
  733. $select = $table->select()->where('bug_status = ?', 'NEW');
  734. $rows = $table->fetchAll($select);
  735. ]]></programlisting>
  736. </example>
  737. <para>
  738. Der <code>ORDER BY</code> kann auch ein Sortier-Kriterium übergeben werden, genauso
  739. wie auch Count und Offset Integer Werte, verwendet werden können damit die Abfrage
  740. ein spezielles Subset von Zeilen zurück gibt. Diese Werte werden in einer
  741. <code>LIMIT</code> Klausel verwendet oder in einer ähnlichen Logik für RDBMS Marken
  742. die die <code>LIMIT</code> Syntax nicht unterstützen.
  743. </para>
  744. <example id="zend.db.table.fetch-all.example2">
  745. <title>Beispiel für das Finden von Zeilen durch einen Ausdruck</title>
  746. <programlisting language="php"><![CDATA[
  747. $table = new Bugs();
  748. $order = 'bug_id';
  749. // Gibt die Zeilen 21 bis 30 zurück
  750. $count = 10;
  751. $offset = 20;
  752. $select = $table->select()->where(array('bug_status = ?' => 'NEW'))
  753. ->order($order)
  754. ->limit($count, $offset);
  755. $rows = $table->fetchAll($select);
  756. ]]></programlisting>
  757. </example>
  758. <para>
  759. Alle diese Argumente sind optional. Wenn die ORDER Klausel unterdrückt wird, dann
  760. enthält das Ergebnis die Zeilen der Tabelle in einer unvorhersagbaren Reihenfolge.
  761. Wenn keine LIMIT Klausel gesetzt ist, dann wird jede Zeile dieser Tabelle
  762. zurückgegeben die der WHERE Klausen entspricht.
  763. </para>
  764. </sect3>
  765. <sect3 id="zend.db.table.advanced.usage">
  766. <title>Fortgeschrittene Verwendung</title>
  767. <para>
  768. Für speziellere und optimierte Ergebnisse, kann es gewünscht sein die Anzahl der
  769. zurückgegebenen Zeilen/Sets zu limitieren. Das kann durch die Übergabe einer FROM
  770. Klausel an das Select Objekt getan werden. Das erste Argument in der FROM Klausel
  771. ist identisch mit den des <classname>Zend_Db_Select</classname> Objekts wobei man
  772. zusätzlich eine Instanz von <classname>Zend_Db_Table_Abstract</classname> übergeben
  773. und damit den Tabellen Namen automatisch ermitteln lassen kann.
  774. </para>
  775. <para>
  776. <example id="zend.db.table.qry.rows.set.retrieving.a.example">
  777. <title>Spezielle Spalten erhalten</title>
  778. <programlisting language="php"><![CDATA[
  779. $table = new Bugs();
  780. $select = $table->select();
  781. $select->from($table, array('bug_id', 'bug_description'))
  782. ->where('bug_status = ?', 'NEW');
  783. $rows = $table->fetchAll($select);
  784. ]]></programlisting>
  785. </example>
  786. </para>
  787. <para>
  788. <important>
  789. <para>
  790. Das Rowset enthält Zeilen die trotzdem 'gültig' sind - sie enthalten bloß
  791. ein Subset der Spalten einer Tabelle. Wenn eine save() Methode auf dem Teil
  792. einer Zeile aufgerufen wird dann werden nur die vorhandenen Felder geändert.
  793. aufgerufen
  794. </para>
  795. </important>
  796. Es können Ausdrücke in einer FROM Klausel spezifiziert werden die dann als readOnly
  797. Zeile/Set zurückgegeben werden. In diesem Beispiel werden Zeilen von der Bugs
  798. Tabelle zurückgegeben die einen Bereich von Nummern neuer Bugs zeigen die von
  799. Individuen mitgeteilt wurden. Die GROUP Klausel ist zu beachten. Die 'count' Spalte
  800. wird der Zeile für Evaluation angefügt und es kann auch Sie zugegriffen werden wie
  801. wenn Sie ein Teil des Schemas wäre.
  802. </para>
  803. <para>
  804. <example id="zend.db.table.qry.rows.set.retrieving.b.example">
  805. <title>Ausdrücke als Spalten erhalten</title>
  806. <programlisting language="php"><![CDATA[
  807. $table = new Bugs();
  808. $select = $table->select();
  809. $select->from($table,
  810. array('COUNT(reported_by) as `count`', 'reported_by'))
  811. ->where('bug_status = ?', 'NEW')
  812. ->group('reported_by');
  813. $rows = $table->fetchAll($select);
  814. ]]></programlisting>
  815. </example>
  816. Es kann auch ein Lookup als Teil der Abfrage verwendet werden um die Fetch
  817. Operation zu verfeinern. In diesem Beispiel wird die Accounts Tabelle als Teil
  818. einer Suche nach allen Bugs die von 'Bob' gemeldet wurden, abgefragt.
  819. </para>
  820. <para>
  821. <example id="zend.db.table.qry.rows.set.refine.example">
  822. <title>Beispiel für das Finden von Zeilen durch einen Ausdruck</title>
  823. <programlisting language="php"><![CDATA[
  824. $table = new Bugs();
  825. // Bei gesetztem From Abschnitt empfangen, wichtig wenn gejoint werden soll
  826. $select = $table->select(Zend_Db_Table::SELECT_WITH_FROM_PART);
  827. $select->setIntegrityCheck(false)
  828. ->where('bug_status = ?', 'NEW')
  829. ->join('accounts', 'accounts.account_name = bugs.reported_by')
  830. ->where('accounts.account_name = ?', 'Bob');
  831. $rows = $table->fetchAll($select);
  832. ]]></programlisting>
  833. </example>
  834. </para>
  835. <para>
  836. <classname>Zend_Db_Table_Select</classname> wird primär verwendet um zu verbinden
  837. und zu prüfen um die Kriterien für einen legalen SELECT Query sicherzustellen.
  838. Trotzdem gibt es viele Fälle in denen man die Flexibilität der
  839. <classname>Zend_Db_Table_Row</classname> benötigt und Zeilen nicht geschrieben oder
  840. gelöscht werden müssen. Für diesen speziellen Fall ist es möglich Zeilen/-sets durch
  841. die Übergabe eines false Wertes an setIntegrityCheck zu erhalten. Das resultierende
  842. Zeilen/-set wird als eine 'locked' Zeile zurückgegeben (das bedeutet das save(),
  843. delete() und jede andere Mothode die Felder setzt wird eine Ausnahme werfen).
  844. </para>
  845. <example id="zend.db.table.qry.rows.set.integrity.example">
  846. <title>
  847. Entfernen des Integritäts Checks von Zend_Db_Table_Select um geJOINte Zeilen zu
  848. erlauben
  849. </title>
  850. <programlisting language="php"><![CDATA[
  851. $table = new Bugs();
  852. $select = $table->select(Zend_Db_Table::SELECT_WITH_FROM_PART)->setIntegrityCheck(false);
  853. $select->where('bug_status = ?', 'NEW')
  854. ->join('accounts',
  855. 'accounts.account_name= bugs.reported_by',
  856. 'account_name')
  857. ->where('accounts.account_name = ?', 'Bob');
  858. $rows = $table->fetchAll($select);
  859. ]]></programlisting>
  860. </example>
  861. </sect3>
  862. </sect2>
  863. <sect2 id="zend.db.table.fetch-row">
  864. <title>Eine einzelne Zeilen abfragen</title>
  865. <para>
  866. Eine einzelne Zeile kann abgefragt werden indem Kriterien verwendet werden die ähnlich
  867. denen der <code>fetchAll()</code> Methode sind.
  868. </para>
  869. <example id="zend.db.table.fetch-row.example1">
  870. <title>Beispiel für das Finden einer einzelnen Zeilen durch einen Ausdruck</title>
  871. <programlisting language="php"><![CDATA[
  872. $table = new Bugs();
  873. $select = $table->select()->where('bug_status = ?', 'NEW')
  874. ->order('bug_id');
  875. $row = $table->fetchRow($select);
  876. ]]></programlisting>
  877. </example>
  878. <para>
  879. Diese Methode gibt ein Objekt vom Typ <classname>Zend_Db_Table_Row_Abstract</classname>
  880. zurück. Wenn die spezifizierten Sortier-Kriterien keiner Zeile in der Datenbank Tabelle
  881. entsprechen gibt <code>fetchRow()</code> PHP's <constant>NULL</constant> Wert zurück.
  882. </para>
  883. </sect2>
  884. <sect2 id="zend.db.table.info">
  885. <title>Informationen der Tabellen Metadaten erhalten</title>
  886. <para>
  887. Die <classname>Zend_Db_Table_Abstract</classname> Klasse bietet einige Informationen
  888. über Ihre Metadaten. Die <code>info()</code> Methode gibt eine Array Struktur mit
  889. Informationen über die Tabelle, Ihre Spalten und Primärschlüssel zurück, sowie andere
  890. Metadaten.
  891. </para>
  892. <example id="zend.db.table.info.example">
  893. <title>Beispiel für das Erhalten des Namens einer Tabelle</title>
  894. <programlisting language="php"><![CDATA[
  895. $table = new Bugs();
  896. $info = $table->info();
  897. echo "Der Name der Tabelle ist " . $info['name'] . "\n";
  898. ]]></programlisting>
  899. </example>
  900. <para>
  901. Die Schlüssel des Arrays das von der <code>info()</code> Methode zurückgegeben wird sind
  902. anbei beschrieben:
  903. </para>
  904. <itemizedlist>
  905. <listitem>
  906. <para>
  907. <emphasis>name</emphasis> => der Name der Tabelle.
  908. </para>
  909. </listitem>
  910. <listitem>
  911. <para>
  912. <emphasis>cols</emphasis> => ein Array das die Spalte(n) der Tabelle benennt.
  913. </para>
  914. </listitem>
  915. <listitem>
  916. <para>
  917. <emphasis>primary</emphasis> => ein Array das die Spalte(n) des Primärschlüssels
  918. benennt.
  919. </para>
  920. </listitem>
  921. <listitem>
  922. <para>
  923. <emphasis>metadata</emphasis> => ein assoziatives Array das die Spaltennamen
  924. mit Informationen über die Spalten zusammenführt. Das ist die Information die
  925. durch die <code>describeTable()</code> Methode zurückgegeben wird.
  926. </para>
  927. </listitem>
  928. <listitem>
  929. <para>
  930. <emphasis>rowClass</emphasis> => der Name der konkreten Klasse die für
  931. Zeilen Objekte verwendet wird und von den Methoden dieser Table Instanz
  932. zurückgegeben wird. Der Standardwert ist
  933. <classname>Zend_Db_Table_Row</classname>.
  934. </para>
  935. </listitem>
  936. <listitem>
  937. <para>
  938. <emphasis>rowsetClass</emphasis> => Name der konkreten Klasse für für Rowset
  939. Objekte verwendet wird und von den Methoden dieser Table Instanz zurückgegeben
  940. wird. Der Standardwert ist <classname>Zend_Db_Table_Rowset</classname>.
  941. </para>
  942. </listitem>
  943. <listitem>
  944. <para>
  945. <emphasis>referenceMap</emphasis> => ist ein assoziatives Array von
  946. Klassennamen von Tabellen die diese Tabelle referenzieren. Siese
  947. <xref linkend="zend.db.table.relationships.defining" />.
  948. </para>
  949. </listitem>
  950. <listitem>
  951. <para>
  952. <emphasis>dependentTables</emphasis> => ein Array von Klassennamen von
  953. Tabellen die diese Tabelle referenzieren. Siese
  954. <xref linkend="zend.db.table.relationships.defining" />.
  955. </para>
  956. </listitem>
  957. <listitem>
  958. <para>
  959. <emphasis>schema</emphasis> => der Name des Schemas (oder der
  960. Datenbank oder dem Tabellenraum) für diese Tabelle.
  961. </para>
  962. </listitem>
  963. </itemizedlist>
  964. </sect2>
  965. <sect2 id="zend.db.table.metadata.caching">
  966. <title>Tabellen Metadaten cachen</title>
  967. <para>
  968. Standardmäßig fragt <classname>Zend_Db_Table_Abstract</classname> die darunterliegende
  969. Datenbank für die <link linkend="zend.db.table.info">Metadaten der Tabelle</link> ab
  970. immer wenn diese diese Daten benötigt werden um Tabellenoperationen durchzuführen. Das
  971. Tableobjekt holt die Metadaten der Tabelle von der Datenbank indem es die
  972. <code>describeTable()</code> Methode des Adapters verwendet. Operationen die diese
  973. Einsicht benötigten sind:
  974. </para>
  975. <itemizedlist>
  976. <listitem><para><code>insert()</code></para></listitem>
  977. <listitem><para><code>find()</code></para></listitem>
  978. <listitem><para><code>info()</code></para></listitem>
  979. </itemizedlist>
  980. <para>
  981. In einigen Fällen, speziell wenn viele Table Objekte auf der gleichen Datenbanktabelle
  982. instanziert werden kann das Abfragen der Datenbank nach den Metadaten der Tabelle für
  983. jede Instanz unerwünscht sein wegen der Geschwindigkeit. In solchen Fällen, können
  984. Benutzer davon profitieren das die Metadaten der Tabelle, die von der Datenbank
  985. empfangen werden, gecached werden.
  986. </para>
  987. <para>
  988. Es gibt zwei grundsätzliche Wege bei denen ein Benutzer Vorteile davon haben kann wenn
  989. die Metadaten der Tabelle gecached werden:
  990. <itemizedlist>
  991. <listitem>
  992. <para>
  993. <emphasis>Aufruf von
  994. <classname>Zend_Db_Table_Abstract::setDefaultMetadataCache()</classname></emphasis>
  995. - Das erlaubt es Entwicklern das Standardcacheobjekt zu setzen das für alle
  996. Tabellenklassen verwendet werden soll.
  997. </para>
  998. </listitem>
  999. <listitem>
  1000. <para>
  1001. <emphasis>Konfigurieren von
  1002. <classname>Zend_Db_Table_Abstract::__construct()</classname></emphasis> -
  1003. Das erlaubt es Entwicklern das Cacheobjekt zu setzen das für eine spezielle
  1004. Instanz der Tabellenklasse verwendet werden soll.
  1005. </para>
  1006. </listitem>
  1007. </itemizedlist>
  1008. In beiden Fällen muß die Spezifikation des Caches entweder <constant>NULL</constant> (wenn kein
  1009. Cache verwendet wird) oder eine Instanz von
  1010. <link linkend="zend.cache.frontends.core"><classname>Zend_Cache_Core</classname></link>
  1011. sein. Die Methoden können in Verbindung zueinander verwendet werden wenn es gewünscht
  1012. ist beides zu haben, einen standardmäßigen Cache für die Metadaten und die Möglichkeit
  1013. den Cache eines individuellen Tabellenobjektes zu ändern.
  1014. </para>
  1015. <example id="zend.db.table.metadata.caching-default">
  1016. <title>
  1017. Verwenden eines standardmäßigen Caches für Metadaten für alle Tabellenobjekte
  1018. </title>
  1019. <para>
  1020. Der folgende Code demonstriert wie ein standardmäßiger Cache für die Metadaten
  1021. gesetzt werden kann der für alle Tabellenobjekte verwendet wird:
  1022. </para>
  1023. <programlisting language="php"><![CDATA[
  1024. // Zuerst muß der Cache vorbereitet werden
  1025. $frontendOptions = array(
  1026. 'automatic_serialization' => true
  1027. );
  1028. $backendOptions = array(
  1029. 'cache_dir' => 'cacheDir'
  1030. );
  1031. $cache = Zend_Cache::factory('Core',
  1032. 'File',
  1033. $frontendOptions,
  1034. $backendOptions);
  1035. // Als nächstes, den Cache setzen der mit allen Tabellenobjekten verwendet werden soll
  1036. Zend_Db_Table_Abstract::setDefaultMetadataCache($cache);
  1037. // Eine Tabellenklasse wird auch benötigt
  1038. class Bugs extends Zend_Db_Table_Abstract
  1039. {
  1040. // ...
  1041. }
  1042. // Jede Instanz von Bugs verwenden nur den Standardmäßigen Cache fpr die Metadaten
  1043. $bugs = new Bugs();
  1044. ]]></programlisting>
  1045. </example>
  1046. <example id="zend.db.table.metadata.caching-instance">
  1047. <title>Einen Metadaten Cache für ein spezielles Tabellenobjekt verwenden</title>
  1048. <para>
  1049. Der folgende Code demonstriert wie ein Cache für Metadaten für eine spezielle
  1050. Instanz eines Tabellenobjektes gesetzt werden kann:
  1051. </para>
  1052. <programlisting language="php"><![CDATA[
  1053. // Zuerst den Cache vorbereiten
  1054. $frontendOptions = array(
  1055. 'automatic_serialization' => true
  1056. );
  1057. $backendOptions = array(
  1058. 'cache_dir' => 'cacheDir'
  1059. );
  1060. $cache = Zend_Cache::factory('Core',
  1061. 'File',
  1062. $frontendOptions,
  1063. $backendOptions);
  1064. // Eine Tabellenklasse wird auch benötigt
  1065. class Bugs extends Zend_Db_Table_Abstract
  1066. {
  1067. // ...
  1068. }
  1069. // Eine Instanz für die Instanzierung konfgurieren
  1070. $bugs = new Bugs(array('metadataCache' => $cache));
  1071. ]]></programlisting>
  1072. </example>
  1073. <note>
  1074. <title>Automatische Serialisierung mit dem Cache Frontend</title>
  1075. <para>
  1076. Da die Information die von der describeTable() Methode des Adapters zurückgegeben
  1077. wird, ein Array ist, muß sichergestellt werden das die
  1078. <code>automatic_serialization</code> Option für das
  1079. <classname>Zend_Cache_Core</classname> Frontend auf <constant>TRUE</constant> gesetzt wird.
  1080. </para>
  1081. </note>
  1082. <para>
  1083. Obwohl die obigen Beispiele <classname>Zend_Cache_Backend_File</classname> verwenden,
  1084. können Entwickler jegliches Cache Backend verwenden das der Situation am besten
  1085. entspricht. Siehe <link linkend="zend.cache">Zend_Cache</link> für weitere
  1086. Informationen.
  1087. </para>
  1088. <sect3 id="zend.db.table.metadata.caching.hardcoding">
  1089. <title>Tabellen Metadaten hardcoden</title>
  1090. <para>
  1091. Um das Cachen von Metadaten einen weiteren Schritt weiterzubringen, kann man sich
  1092. auch entscheiden die Metadaten hardzucoden. In diesem speziellen Fall benötigt jede
  1093. Änderung trotzdem eine Änderung im Code. Als solches, ist es nur empfohlen für jene
  1094. die eine Produktionsumgebung optimieren wollen.
  1095. </para>
  1096. <para>
  1097. Die Struktur der Metadaten ist wie folgt:
  1098. </para>
  1099. <programlisting language="php"><![CDATA[
  1100. protected $_metadata = array(
  1101. '<column_name>' => array(
  1102. 'SCHEMA_NAME' => <string>,
  1103. 'TABLE_NAME' => <string>,
  1104. 'COLUMN_NAME' => <string>,
  1105. 'COLUMN_POSITION' => <int>,
  1106. 'DATA_TYPE' => <string>,
  1107. 'DEFAULT' => NULL|<value>,
  1108. 'NULLABLE' => <bool>,
  1109. 'LENGTH' => <string - length>,
  1110. 'SCALE' => NULL|<value>,
  1111. 'PRECISION' => NULL|<value>,
  1112. 'UNSIGNED' => NULL|<bool>,
  1113. 'PRIMARY' => <bool>,
  1114. 'PRIMARY_POSITION' => <int>,
  1115. 'IDENTITY' => <bool>,
  1116. ),
  1117. // additional columns...
  1118. );
  1119. ]]></programlisting>
  1120. <para>
  1121. Ein einfacher Weg um die richtigen Werte zu erhalten ist es den Metadaten Cache zu
  1122. verwenden, und dann die Werte die im Cache gespeichert sind, zu deserialisieren.
  1123. </para>
  1124. <para>
  1125. Diese Optimierung kann ausgeschaltet werden indem das
  1126. <code>metadataCacheInClass</code> Flag ausgeschaltet wird:
  1127. </para>
  1128. <programlisting language="php"><![CDATA[
  1129. // Bei der Instanziierung:
  1130. $bugs = new Bugs(array('metadataCacheInClass' => false));
  1131. // Oder später:
  1132. $bugs->setMetadataCacheInClass(false);
  1133. ]]></programlisting>
  1134. <para>
  1135. Das Flag ist standardmäßig aktiviert, was sicherstellt das das
  1136. <varname>$_metadata</varname> Array nur einmal pro Instanz ausgeliefert wird.
  1137. </para>
  1138. </sect3>
  1139. </sect2>
  1140. <sect2 id="zend.db.table.extending">
  1141. <title>Eine Table Klasse erweitern und anpassen</title>
  1142. <sect3 id="zend.db.table.extending.row-rowset">
  1143. <title>Verwenden eigener Zeilen oder Rowset Klassen</title>
  1144. <para>
  1145. Standardmäßig geben die Methoden der Table Klasse ein Rowset als Instanzen der
  1146. konkreten Klasse <classname>Zend_Db_Table_Rowset</classname>, und Rowsets enthalten
  1147. eine Kollektion von Instanzen der konkreten Klasse
  1148. <classname>Zend_Db_Table_Row</classname>. Eine alternative Klasse kann für jede von
  1149. Ihnen als alternative Klasse definiert werden die verwendet werden soll, aber es
  1150. müssen Klassen sein die <classname>Zend_Db_Table_Rowset_Abstract</classname>
  1151. erweitern und respektiv <classname>Zend_Db_Table_Row_Abstract</classname>.
  1152. </para>
  1153. <para>
  1154. Es können Zeilen und Rowset Klassen definiert werden indem das Optionsarray des
  1155. Table Konstruktors verwendet wird, respektiv die Schlüssel <code>'rowClass'</code>
  1156. und <code>'rowsetClass'</code>. Die Namen der Klassen müssen spezifiziert werden
  1157. indem Strings verwendet werden.
  1158. </para>
  1159. <example id="zend.db.table.extending.row-rowset.example">
  1160. <title>
  1161. Beispiel dafür wie die Zeilen und Rowset Klassen spezifiziert werden können
  1162. </title>
  1163. <programlisting language="php"><![CDATA[
  1164. class My_Row extends Zend_Db_Table_Row_Abstract
  1165. {
  1166. ...
  1167. }
  1168. class My_Rowset extends Zend_Db_Table_Rowset_Abstract
  1169. {
  1170. ...
  1171. }
  1172. $table = new Bugs(
  1173. array(
  1174. 'rowClass' => 'My_Row',
  1175. 'rowsetClass' => 'My_Rowset'
  1176. )
  1177. );
  1178. $where = $table->getAdapter()->quoteInto('bug_status = ?', 'NEW')
  1179. // Gibt ein Objekt des Typs My_Rowset zurück
  1180. // das ein Array von Objekten des Typs My_Row enthält.
  1181. $rows = $table->fetchAll($where);
  1182. ]]></programlisting>
  1183. </example>
  1184. <para>
  1185. Die Klassen können geändert werden indem Sie mit den <code>setRowClass()</code> und
  1186. <code>setRowsetClass()</code> Methoden spezifiziert werden. Das entspricht den
  1187. Zeilen und Rowsets die nachfolgend erstellt werden; es ändert aber nicht die Klasse
  1188. von Zeilen- oder Rowsetobjekten die bereits davor erstellt wurden.
  1189. </para>
  1190. <example id="zend.db.table.extending.row-rowset.example2">
  1191. <title>Beispiel für das Ändern von Zeilen und Rowset Klassen</title>
  1192. <programlisting language="php"><![CDATA[
  1193. $table = new Bugs();
  1194. $where = $table->getAdapter()->quoteInto('bug_status = ?', 'NEW')
  1195. // Gibt ein Objekt vom Typ Zend_Db_Table_Rowset zurück das ein Array
  1196. // von Objekten des Typs Zend_Db_Table_Row enthält.
  1197. $rowsStandard = $table->fetchAll($where);
  1198. $table->setRowClass('My_Row');
  1199. $table->setRowsetClass('My_Rowset');
  1200. // Gibt ein Objekt vom Typ My_Rowset zurück das ein Array
  1201. // von Objekten des Typs My_Row enthält.
  1202. $rowsCustom = $table->fetchAll($where);
  1203. // Das $rowsStandard Objekt existiert noch immer, und es bleibt unverändert.
  1204. ]]></programlisting>
  1205. </example>
  1206. <para>
  1207. Für weitere Informationen über Zeilen und Rowset Klassenm siehe
  1208. <xref linkend="zend.db.table.row" /> und <xref linkend="zend.db.table.rowset" />.
  1209. </para>
  1210. </sect3>
  1211. <sect3 id="zend.db.table.extending.insert-update">
  1212. <title>Selbst definierte Logik für das Einfügen, Aktualisieren und Löschen</title>
  1213. <para>
  1214. Die <code>insert()</code> und <code>update()</code> Methoden in der Table Klasse
  1215. können überschrieben werden. Das bietet die Möglichkeit eigenen Code einzufügen der
  1216. ausgeführt wird bevor die Datenbank Operation durchgeführt wird. Es muß
  1217. sichergestellt werden das die Methode der Elternklasse aufgerufen wird wenn man
  1218. fertig ist.
  1219. </para>
  1220. <example id="zend.db.table.extending.insert-update.example">
  1221. <title>Eigene Logik um Zeitstempel zu managen</title>
  1222. <programlisting language="php"><![CDATA[
  1223. class Bugs extends Zend_Db_Table_Abstract
  1224. {
  1225. protected $_name = 'bugs';
  1226. public function insert(array $data)
  1227. {
  1228. // Einen Zeitstempel hinzufügen
  1229. if (empty($data['created_on'])) {
  1230. $data['created_on'] = time();
  1231. }
  1232. return parent::insert($data);
  1233. }
  1234. public function update(array $data, $where)
  1235. {
  1236. // Einen Zeitstempel hinzufügen
  1237. if (empty($data['updated_on'])) {
  1238. $data['updated_on'] = time();
  1239. }
  1240. return parent::update($data, $where);
  1241. }
  1242. }
  1243. ]]></programlisting>
  1244. </example>
  1245. <para>
  1246. Auch die <code>delete()</code> Methode kann überschrieben werden.
  1247. </para>
  1248. </sect3>
  1249. <sect3 id="zend.db.table.extending.finders">
  1250. <title>Eigene Such Methoden in Zend_Db_Table definieren</title>
  1251. <para>
  1252. Es können eigene Abfrage Methoden in der Table Klasse implementiert werden, wenn oft
  1253. die Notwendigkeit besteht Abragen mit speziellen Kriterien auf der Table Klasse
  1254. durchzuführen. Die meisten Abfragen können mit <code>fetchAll()</code> geschrieben
  1255. werden, das bedeutet aber das Code dupliziert werden muß um Abfragekonditionen zu
  1256. formen die Abfrage in verschiedenen Orten der Anwendung auszuführen. Hierfür kann es
  1257. nützlich sein eine Methode in der Table Klasse zu definieren um oft benutzte
  1258. Abfragen an dieser Tabelle durchzuführen.
  1259. </para>
  1260. <example id="zend.db.table.extending.finders.example">
  1261. <title>Eigene Methode um Fehler durch den Status zu finden</title>
  1262. <programlisting language="php"><![CDATA[
  1263. class Bugs extends Zend_Db_Table_Abstract
  1264. {
  1265. protected $_name = 'bugs';
  1266. public function findByStatus($status)
  1267. {
  1268. $where = $this->getAdapter()->quoteInto('bug_status = ?', $status);
  1269. return $this->fetchAll($where, 'bug_id');
  1270. }
  1271. }
  1272. ]]></programlisting>
  1273. </example>
  1274. </sect3>
  1275. <sect3 id="zend.db.table.extending.inflection">
  1276. <title>Inflection (Beugung) in Zend_Db_Table definieren</title>
  1277. <para>
  1278. Einige Leute bevorzugen das der Name der Table Klasse einem Tabellennamen in der
  1279. RDBMS, durch eine Stringumwandlung die <emphasis>Inflection</emphasis> (Beugung)
  1280. genannt wird, entspricht.
  1281. </para>
  1282. <para>
  1283. Wenn zum Beispiel der Name der Table Klasse "<code>BugsProducts</code>" ist, würde
  1284. Sie der physikalischen Tabelle in der Datenbank entsprechen die
  1285. "<code>bugs_products</code>" heißt, wenn die explizite Definition der
  1286. <varname>$_name</varname> Eigenschaft der Klasse unterdrückt wird. In dieser
  1287. Übereinstimmung der Beugung, wird der Klassenname im "CamelCase" Format geschrieben
  1288. und in Kleinschreibung transformiert, und Wörter mit einem Unterstrich seperiert.
  1289. </para>
  1290. <para>
  1291. Der Tabellenname der Datenbank kann unabhängig vom Klassennamen spezifiziert werden
  1292. indem der Tabellenname mit der Klasseneigenschaft <varname>$_name</varname> in jeder der
  1293. eigenen Tabellenklassen deklariert wird.
  1294. </para>
  1295. <para>
  1296. <classname>Zend_Db_Table_Abstract</classname> führt keine Beugung durch um die
  1297. Klassennamen mit den Tabellennamen in Übereinstimmung zu bringen. Wenn die
  1298. Deklaration von <varname>$_name</varname> in der eigenen Tabellenklasse unterdrückt wird,
  1299. wird die Klasse mit der Datenbanktabelle in Verbindung gebracht die der Schreibweise
  1300. des Klassennamens exakt entspricht.
  1301. </para>
  1302. <para>
  1303. Es ist unzureichend Identifizierer von der Datenbank zu transformieren, da das zu
  1304. Doppeldeutigkeiten führen kann oder einige Identifizierer sogar unerreichbar macht.
  1305. Die Verwendung der SQL Identifizierer exakt so wie Sie in der Datenbank vorhanden
  1306. sind, macht <classname>Zend_Db_Table_Abstract</classname> sowohl einfacher als auch
  1307. flexibler.
  1308. </para>
  1309. <para>
  1310. Wenn man es vorzieht Beugung zu verwenden, muß die Transformation selbst durch das
  1311. Überschreiben der <code>_setupTableName()</code> Methode in der eigenen
  1312. Tabellenklasse implementiert werden. Ein Weg um das zu tun ist die Definition einer
  1313. abstrakten Klase die <classname>Zend_Db_Table_Abstract</classname> erweitert. Der
  1314. Rest der eigenen Klassen erweitert dann die eigene neue abstrakte Klasse.
  1315. </para>
  1316. <example id="zend.db.table.extending.inflection.example">
  1317. <title>Beispiel einer abstrakten Tabellenklasse die Beugung implementiert</title>
  1318. <programlisting language="php"><![CDATA[
  1319. abstract class MyAbstractTable extends Zend_Db_Table_Abstract
  1320. {
  1321. protected function _setupTableName()
  1322. {
  1323. if (!$this->_name) {
  1324. $this->_name = myCustomInflector(get_class($this));
  1325. }
  1326. parent::_setupTableName();
  1327. }
  1328. }
  1329. class BugsProducts extends MyAbstractTable
  1330. {
  1331. }
  1332. ]]></programlisting>
  1333. </example>
  1334. <para>
  1335. Man ist selbst für das Schreiben von Funktionen verantwortlich um die Transformation
  1336. der Beugung auszuführen. Zend Framework bietet solche Funktionen nicht an.
  1337. </para>
  1338. </sect3>
  1339. </sect2>
  1340. </sect1>
  1341. <!--
  1342. vim:se ts=4 sw=4 et:
  1343. -->