Zend_Db_Table.xml 67 KB

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