Zend_Db_Adapter.xml 96 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 16447 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.adapter">
  5. <title>Zend_Db_Adapter</title>
  6. <para>
  7. <classname>Zend_Db</classname> und die zugehörigen Klassen bieten eine einfache SQL
  8. Schnittstelle für Zend Framework. <classname>Zend_Db_Adapter</classname> ist die Basisklasse
  9. zur Anbindung einer PHP Anwendung an ein RDBMS. Es gibt für jede RDBMS Marke einen eigenen
  10. Adapter.
  11. </para>
  12. <para>
  13. Die <classname>Zend_Db</classname> Adapter bilden eine Schnittstelle zu den Hersteller
  14. spezifischen PHP Erweiterungen und unterstützen dadurch die Entwicklung einer PHP Anwendung
  15. für verschiedene RDBMS mit geringem Aufwand.
  16. </para>
  17. <para>
  18. Die Schnittstellen der Adapterklasse ähneln denen der
  19. <ulink url="http://www.php.net/pdo">PHP Data Objects</ulink> Erweiterung.
  20. <classname>Zend_Db</classname> bietet Adapterklassen für PDO Treiber der folgenden RDBMS
  21. Marken:
  22. </para>
  23. <itemizedlist>
  24. <listitem>
  25. <para>
  26. IBM DB2 und Informix Dynamic Server (IDS), verwenden die
  27. <ulink url="http://www.php.net/pdo-ibm">pdo_ibm</ulink> PHP Erweiterung
  28. </para>
  29. </listitem>
  30. <listitem>
  31. <para>
  32. MySQL, verwendet die <ulink url="http://www.php.net/pdo-mysql">pdo_mysql</ulink> PHP
  33. Erweiterung
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. Microsoft SQL Server, verwendet die <ulink
  39. url="http://www.php.net/pdo-mssql">pdo_mssql</ulink> PHP Erweiterung
  40. </para>
  41. </listitem>
  42. <listitem>
  43. <para>
  44. Oracle, verwendet die <ulink url="http://www.php.net/pdo-oci">pdo_oci</ulink> PHP
  45. Erweiterung
  46. </para>
  47. </listitem>
  48. <listitem>
  49. <para>
  50. PostgreSQL, verwendet die <ulink
  51. url="http://www.php.net/pdo-pgsql">pdo_pgsql</ulink> PHP Erweiterung
  52. </para>
  53. </listitem>
  54. <listitem>
  55. <para>
  56. SQLite, verwendet die <ulink url="http://www.php.net/pdo-sqlite">pdo_sqlite</ulink>
  57. PHP Erweiterung
  58. </para>
  59. </listitem>
  60. </itemizedlist>
  61. <para>
  62. Zusätzlich bietet <classname>Zend_Db</classname> Adapterklassen für die folgenden Marken,
  63. welche eigene PHP Datenbank Erweiterungen nutzen:
  64. </para>
  65. <itemizedlist>
  66. <listitem>
  67. <para>
  68. MySQL, mit der <ulink url="http://www.php.net/mysqli">mysqli</ulink> PHP Erweiterung
  69. </para>
  70. </listitem>
  71. <listitem>
  72. <para>
  73. Oracle, mit der <ulink url="http://www.php.net/oci8">oci8</ulink> PHP Erweiterung
  74. </para>
  75. </listitem>
  76. <listitem>
  77. <para>
  78. IBM DB2 und DB2/i5, mit der <ulink url="http://www.php.net/ibm_db2">ibm_db2</ulink>
  79. PHP Erweiterung
  80. </para>
  81. </listitem>
  82. <listitem>
  83. <para>
  84. Firebird/Interbase, mit der <ulink
  85. url="http://www.php.net/ibase">php_interbase</ulink> PHP Erweiterung
  86. </para>
  87. </listitem>
  88. </itemizedlist>
  89. <note>
  90. <para>
  91. Jeder <classname>Zend_Db</classname> Adapter nutzt eine PHP Erweiterung. Die
  92. entsprechend PHP Erweiterung muss in der PHP Umgebung aktiviert sein um den
  93. <classname>Zend_Db</classname> Adapter zu nutzen. Zum Beispiel muss bei der Nutzung
  94. eines PDO <classname>Zend_Db</classname> Adapters sowohl die PDO Erweiterung, als auch
  95. der PDO Treiber für die jeweilige Marke geladen sein.
  96. </para>
  97. </note>
  98. <sect2 id="zend.db.adapter.connecting">
  99. <title>Anbindung einer Datenbank mit einem Adapter</title>
  100. <para>
  101. Dieser Abschnitt beschreibt wie eine Instanz eines Datenbankadapters erzeugt wird. Dies
  102. entspricht der Erzeugung einer Verbindung an ein RDBMS Server in einer PHP Anwendung.
  103. </para>
  104. <sect3 id="zend.db.adapter.connecting.constructor">
  105. <title>Nutzung des Zend_Db Adapter Konstruktors</title>
  106. <para>
  107. Man kann eine Instanz eines Adapters erzeugen, indem man den Konstruktor verwendet.
  108. Ein Adapter Konstruktur benötigt ein Argument, wobei es sich um ein Array mit
  109. Parametern für die Verbindung handelt.
  110. </para>
  111. <example id="zend.db.adapter.connecting.constructor.example">
  112. <title>Nutzung eines Adapter Konstruktors</title>
  113. <programlisting language="php"><![CDATA[
  114. $db = new Zend_Db_Adapter_Pdo_Mysql(array(
  115. 'host' => '127.0.0.1',
  116. 'username' => 'webuser',
  117. 'password' => 'xxxxxxxx',
  118. 'dbname' => 'test'
  119. ));
  120. ]]></programlisting>
  121. </example>
  122. </sect3>
  123. <sect3 id="zend.db.adapter.connecting.factory">
  124. <title>Nutzung der Zend_Db Factory</title>
  125. <para>
  126. Als Alternative zur direkten Nutzung des Konstruktors kann man auch eine Instanz des
  127. Adapters erzeugen indem man die statische Methode
  128. <classname>Zend_Db::factory()</classname> nutzt. Diese Methode lädt die
  129. Adapterklasse dynamisch bei Aufruf unter Nutzung von <link
  130. linkend="zend.loader.load.class">Zend_Loader::loadClass()</link>.
  131. </para>
  132. <para>
  133. Das erste Argument ist ein String der den Namen der Adapterklasse enthält. Zum
  134. Beispiel entspricht der String 'Pdo_Mysql' der Klasse Zend_Db_Adapter_Pdo_Mysql. Das
  135. zweite Argument ist das gleiche Array von Parametern wie bei der Verwendung des
  136. Adapter Konstruktors.
  137. </para>
  138. <example id="zend.db.adapter.connecting.factory.example">
  139. <title>Nutzung der Adapter factory() Methode</title>
  140. <programlisting language="php"><![CDATA[
  141. // Wir benötigen das folgende Statement nicht da die
  142. // Zend_Db_Adapter_Pdo_Mysql Datei für uns durch die Factory
  143. // Methode von Zend_Db geladen wird
  144. // require_once 'Zend/Db/Adapter/Pdo/Mysql.php';
  145. // Lädt automatisch die Klasse Zend_Db_Adapter_Pdo_Mysql
  146. // und erzeugt eine Instanz von Ihr.
  147. $db = Zend_Db::factory('Pdo_Mysql', array(
  148. 'host' => '127.0.0.1',
  149. 'username' => 'webuser',
  150. 'password' => 'xxxxxxxx',
  151. 'dbname' => 'test'
  152. ));
  153. ]]></programlisting>
  154. </example>
  155. <para>
  156. Wenn eine eigene Klasse geschrieben wird, die
  157. <classname>Zend_Db_Adapter_Abstract_Adapter</classname> erweitert aber nicht mit
  158. dem Präfix "Zend_Db_Adapter" beginnt, kann die <methodname>factory()</methodname>
  159. Methode verwendet werden um den Adapter zu Laden wenn der führende Teil der Adapter
  160. Klasse mit dem 'adapterNamespace' Schlüssel im Parameter Array spezifiziert wird.
  161. </para>
  162. <example id="zend.db.adapter.connecting.factory.example2">
  163. <title>Die factory Methode für eine eigene Adapter Klasse verwenden</title>
  164. <programlisting language="php"><![CDATA[
  165. // Wir müssen die Datei der Adapter Klasse nicht laden
  166. // weil Sie für uns durch die Factory Methode von Zend_Db geladen wird
  167. // Die MyProject_Db_Adapter_Pdo_Mysql Klasse automatisch laden
  168. // und eine Instanz von Ihr erstellen.
  169. $db = Zend_Db::factory('Pdo_Mysql', array(
  170. 'host' => '127.0.0.1',
  171. 'username' => 'webuser',
  172. 'password' => 'xxxxxxxx',
  173. 'dbname' => 'test',
  174. 'adapterNamespace' => 'MyProject_Db_Adapter'
  175. ));
  176. ]]></programlisting>
  177. </example>
  178. </sect3>
  179. <sect3 id="zend.db.adapter.connecting.factory-config">
  180. <title>Zend_Config mit Zend_Db_Factory verwenden</title>
  181. <para>
  182. Optional kann jedes Argument der <methodname>factory()</methodname> Methode als
  183. Objekt des Typs <link linkend="zend.config">Zend_Config</link> spezifiziert werden.
  184. </para>
  185. <para>
  186. Wenn das erste Argument ein Config Objekt ist, wird erwartet das es eine Eigenschaft
  187. enthält die <code>adapter</code> heißt und einen String enthält der nach dem Adapter
  188. Basis Klassen Namen benannt ist. Optional kann das Objekt eine Eigenschaft genannt
  189. <code>params</code> enthalten, mit Subeigenschaften korrespondierend zu den
  190. Parameter Namen des Adapters. Das wird nur verwendet wenn das zweite Argument für
  191. die <methodname>factory()</methodname> Methode nicht angegeben wird.
  192. </para>
  193. <example id="zend.db.adapter.connecting.factory.example1">
  194. <title>
  195. Verwenden der Factory Methode des Adapters mit einem Zend_Config Objekt
  196. </title>
  197. <para>
  198. Im Beispiel anbei wird ein <classname>Zend_Config</classname> Objekt von einem
  199. Array erstellt. Die Daten können auch aus einer externen Datei geladen werden
  200. indem Klassen wie zum Beispiel <link
  201. linkend="zend.config.adapters.ini">Zend_Config_Ini</link> oder <link
  202. linkend="zend.config.adapters.xml">Zend_Config_Xml</link> verwendet werden.
  203. </para>
  204. <programlisting language="php"><![CDATA[
  205. $config = new Zend_Config(
  206. array(
  207. 'database' => array(
  208. 'adapter' => 'Mysqli',
  209. 'params' => array(
  210. 'host' => '127.0.0.1',
  211. 'dbname' => 'test',
  212. 'username' => 'webuser',
  213. 'password' => 'secret',
  214. )
  215. )
  216. )
  217. );
  218. $db = Zend_Db::factory($config->database);
  219. ]]></programlisting>
  220. </example>
  221. <para>
  222. Das zweite Argument der <methodname>factory()</methodname> Methode kann ein
  223. assoziatives Array sein das Einträge enthält die den Parameters des Adapters
  224. entsprechen. Dieses Argument ist optional. Wenn das erste Argument vom Typ
  225. <classname>Zend_Config</classname> ist, wird angenommen das es alle Parameter
  226. enthält, und das zweite Argument wird ignoriert.
  227. </para>
  228. </sect3>
  229. <sect3 id="zend.db.adapter.connecting.parameters">
  230. <title>Adapter Parameter</title>
  231. <para>
  232. Die folgende Liste erklärt die gemeinsamen Parameter die von
  233. <classname>Zend_Db</classname> Adapterklassen erkannt werden.
  234. </para>
  235. <itemizedlist>
  236. <listitem>
  237. <para>
  238. <emphasis>host</emphasis>:
  239. Ein String der den Hostname oder die Ip-Adresse des Datenbankservers
  240. beinhaltet. Wenn die Datenbank auf dem gleichen Host wie die PHP Anwendung
  241. läuft wird 'localhost' oder '127.0.0.1' verwendet.
  242. </para>
  243. </listitem>
  244. <listitem>
  245. <para>
  246. <emphasis>username</emphasis>:
  247. Konto Kennung zur Authentisierung einer Verbindung zum RDBMS Server.
  248. </para>
  249. </listitem>
  250. <listitem>
  251. <para>
  252. <emphasis>password</emphasis>:
  253. Konto Passwort zur Authentisierung einer Verbindung zum RDBMS Server.
  254. </para>
  255. </listitem>
  256. <listitem>
  257. <para>
  258. <emphasis>dbname</emphasis>:
  259. Datenbank Name auf dem RDBMS Server.
  260. </para>
  261. </listitem>
  262. <listitem>
  263. <para>
  264. <emphasis>port</emphasis>:
  265. Einige RDBMS Server können Netzwerkverbindungen an vom Administrator
  266. spezifizierten Ports akzeptieren. Der Port-Parameter gibt die Möglichkeit
  267. die Portnummer anzugeben, an welche die PHP Anwendung verbindet um der
  268. Port-Konfiguration des RDBMS Servers zu entsprechen.
  269. </para>
  270. </listitem>
  271. <listitem>
  272. <para>
  273. <emphasis>options</emphasis>:
  274. Dieser Parameter ist ein assoziatives Array von Optionen die in allen
  275. Zend_Db_Adapter Klassen enthalten sind.
  276. </para>
  277. </listitem>
  278. <listitem>
  279. <para>
  280. <emphasis>driver_options</emphasis>: Dieser Parameter ist ein assoziatives
  281. Array von zusätzlichen Optionen die spezifisch für die angegebene
  282. Datenbankerweiterung sind. Eine typische Anwendung dieses Parameters ist,
  283. Attribute für einen PDO Treiber zu setzen.
  284. </para>
  285. </listitem>
  286. <listitem>
  287. <para>
  288. <emphasis>adapterNamespace</emphasis>:
  289. Benennt den führenden Teil des Klassen Namens für den Adapter statt
  290. 'Zend_Db_Adapter'. Dies kann verwendet werden wenn man die
  291. <methodname>factory()</methodname>Methode verwenden muß um eine nicht von
  292. Zend kommende Datenbank Adapter Klasse zu laden.
  293. </para>
  294. </listitem>
  295. </itemizedlist>
  296. <example id="zend.db.adapter.connecting.parameters.example1">
  297. <title>Übergeben der case-folding Option an die factory</title>
  298. <para>
  299. Diese Option kann über die Konstante
  300. <classname>Zend_Db::CASE_FOLDING</classname> angegeben werden. Sie entspricht
  301. dem <constant>ATTR_CASE</constant> Attribut in PDO and IBM DB2
  302. Datenbanktreibern und stellt die Schreibweise von String Schlüsseln in
  303. Abfrageergebnissen ein. Die Option kann den Wert
  304. <constant>Zend_Db::CASE_NATURAL</constant> (der Standard),
  305. <constant>Zend_Db::CASE_UPPER</constant> oder
  306. <constant>Zend_Db::CASE_LOWER</constant> annehmen.
  307. </para>
  308. <programlisting language="php"><![CDATA[
  309. $options = array(
  310. Zend_Db::CASE_FOLDING => Zend_Db::CASE_UPPER
  311. );
  312. $params = array(
  313. 'host' => '127.0.0.1',
  314. 'username' => 'webuser',
  315. 'password' => 'xxxxxxxx',
  316. 'dbname' => 'test',
  317. 'options' => $options
  318. );
  319. $db = Zend_Db::factory('Db2', $params);
  320. ]]></programlisting>
  321. </example>
  322. <example id="zend.db.adapter.connecting.parameters.example2">
  323. <title>Übergeben der auto-quoting Option an die factory</title>
  324. <para>
  325. Diese Option kann über die Konstante
  326. <classname>Zend_Db::AUTO_QUOTE_IDENTIFIERS</classname> angegeben werden. Wenn
  327. der Wert <constant>TRUE</constant> (der Standard) ist, werden Bezeichner wie
  328. Tabellennamen, Spaltennamen und auch Aliase in jeder SQL Syntax die vom Adapter
  329. Objekt generiert wurde begrenzt. Dies macht es einfach Bezeichner zu verwenden,
  330. die SQL Schlüsselwörter oder spezielle Zeichen enthalten. Wenn der Wert
  331. <constant>FALSE</constant> ist, werden Bezeichner nicht automatisch begrenzt. Wenn
  332. Bezeichner begrenzt werden müssen, so kann dies über die
  333. <methodname>quoteIdentifier()</methodname> Methode von Hand getan werden.
  334. </para>
  335. <programlisting language="php"><![CDATA[
  336. $options = array(
  337. Zend_Db::AUTO_QUOTE_IDENTIFIERS => false
  338. );
  339. $params = array(
  340. 'host' => '127.0.0.1',
  341. 'username' => 'webuser',
  342. 'password' => 'xxxxxxxx',
  343. 'dbname' => 'test',
  344. 'options' => $options
  345. );
  346. $db = Zend_Db::factory('Pdo_Mysql', $params);
  347. ]]></programlisting>
  348. </example>
  349. <example id="zend.db.adapter.connecting.parameters.example3">
  350. <title>Übergeben von PDO Treiber Optionen an die factory</title>
  351. <programlisting language="php"><![CDATA[
  352. $pdoParams = array(
  353. PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true
  354. );
  355. $params = array(
  356. 'host' => '127.0.0.1',
  357. 'username' => 'webuser',
  358. 'password' => 'xxxxxxxx',
  359. 'dbname' => 'test',
  360. 'driver_options' => $pdoParams
  361. );
  362. $db = Zend_Db::factory('Pdo_Mysql', $params);
  363. echo $db->getConnection()
  364. ->getAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY);
  365. ]]></programlisting>
  366. </example>
  367. <example id="zend.db.adapter.connecting.parameters.example4">
  368. <title>Übergabe einer Serialisierungs Option an die Factory</title>
  369. <programlisting language="php"><![CDATA[
  370. $options = array(
  371. Zend_Db::ALLOW_SERIALIZATION => false
  372. );
  373. $params = array(
  374. 'host' => '127.0.0.1',
  375. 'username' => 'webuser',
  376. 'password' => 'xxxxxxxx',
  377. 'dbname' => 'test',
  378. 'options' => $options
  379. );
  380. $db = Zend_Db::factory('Pdo_Mysql', $params);
  381. ]]></programlisting>
  382. </example>
  383. </sect3>
  384. <sect3 id="zend.db.adapter.connecting.getconnection">
  385. <title>Verwalten von Lazy Connections</title>
  386. <para>
  387. Die Erzeugung einer Instanz der Adapterklasse stellt nicht gleichzeitig eine
  388. Verbindung zum RDBMS her. Der Adapter speichert die Verbindungsparameter und stellt
  389. die tatsächliche Verbindung bei Bedarf her, wenn die erste Anfrage ausgeführt wird.
  390. Dies stellt sicher, dass die Erzeugung eines Adapterobjekts schnell und sparsam ist.
  391. Dadurch kann auch dann eine Instanz eines Adapters erzeugt werden, wenn nicht
  392. zwingend eine Datenbankanfrage für die aktuell gelieferte Darstellung der Anwendung
  393. benötigt wird.
  394. </para>
  395. <para>
  396. Wenn der Adapter zwingend eine Verbindung zum RDBMS herstellen soll, kann die
  397. <methodname>getConnection()</methodname> Methode verwendet werden. Diese liefert
  398. ein Objekt der Verbindung, welches eine Verbindung entsprechend der verwendeten PHP
  399. Erweiterung repräsentiert. Wenn zum Beispiel irgendeine der PDO Adapterklassen
  400. verwendet wird, dann liefert <methodname>getConnection()</methodname> das PDO
  401. Object, nachdem es als eine live Verbindung zu der entsprechenden Datenbank
  402. initialisiert wurde.
  403. </para>
  404. <para>
  405. Es kann nützlich sein eine Verbindung zu erzwingen um jegliche Exceptions
  406. abzufangen, die als Resultat falscher Konto Berechtigungen oder einem anderen Fehler
  407. bei der Verbindung zum RDBMS auftreten. Diese Exceptions treten nicht auf, bis die
  408. tatsächliche Verbindung hergestellt ist, daher kann es den Anwendungs-Code
  409. vereinfachen, wenn diese Exceptions an einer Stelle bearbeitet werden, und nicht
  410. erst bei der ersten Anfrage.
  411. </para>
  412. <para>
  413. Zusätzlich kann ein Adapter serialisiert werden um Ihn zu speichern, zum Beispiel in
  414. einer Session Variable. Das kann sehr nütlich sein, nicht nur für den Adapter
  415. selbst, sondern auch für andere Objekte die Ihn verwenden, wie ein
  416. <classname>Zend_Db_Select</classname> Objekt. Standardmäßig, ist es Adaptern erlaubt
  417. serialisiert zu werden. Wenn man das nicht will, sollte man die
  418. <classname>Zend_Db::ALLOW_SERIALIZATION=false</classname> Option übergeben, wie im
  419. Beispiel anbei gezeigt. Um das Prinzip von Lazy Connections zu erlauben, wird der
  420. Adapter sich selbst nicht wiederverbinden wenn er deserialisiert wird. Man muß
  421. <methodname>getConnection()</methodname> selbst aufrufen. Mann kann den Adapter
  422. dazu bringen sich automatisch wieder zu verbinden indem
  423. <classname>Zend_Db::AUTO_RECONNECT_ON_UNSERIALIZE=true</classname> als Option zum
  424. Adapter übergeben wird.
  425. </para>
  426. <example
  427. id="zend.db.adapter.connecting.getconnection.example">
  428. <title>Umgang mit Verbindungs Exceptions</title>
  429. <programlisting language="php"><![CDATA[
  430. try {
  431. $db = Zend_Db::factory('Pdo_Mysql', $parameters);
  432. $db->getConnection();
  433. } catch (Zend_Db_Adapter_Exception $e) {
  434. // Möglicherweise ein fehlgeschlagener login,
  435. // oder die RDBMS läuft möglicherweise nicht
  436. } catch (Zend_Exception $e) {
  437. // Möglicherweise kann factory() die definierte Adapter Klasse nicht laden
  438. }
  439. ]]></programlisting>
  440. </example>
  441. </sect3>
  442. </sect2>
  443. <sect2 id="zend.db.adapter.example-database">
  444. <title>Beispiel Datenbank</title>
  445. <para>
  446. In der Dokumentation für die <classname>Zend_Db</classname> Klassen verwenden wir einige
  447. einfache Tabellen um die Verwendung der Klassen und Methoden zu erläutern. Diese
  448. Beispieltabellen können Informationen für das Bugtracking in einem Softwareprojekt
  449. speichern. Die Datenbank enthält vier Tabellen:
  450. </para>
  451. <itemizedlist>
  452. <listitem>
  453. <para>
  454. <emphasis>accounts</emphasis> speichert Informationen über jeden Benutzer des
  455. Bugtracking Systems.
  456. </para>
  457. </listitem>
  458. <listitem>
  459. <para>
  460. <emphasis>products</emphasis> speichert Informationen über jedes Produkt für das
  461. ein Bug erfasst werden kann.
  462. </para>
  463. </listitem>
  464. <listitem>
  465. <para>
  466. <emphasis>bugs</emphasis> speichert informationen über Bugs, dazu gehört der
  467. derzeitige Status des Bugs, die Person die den Bug berichtet hat, die Person die
  468. den Bug beheben soll und die Person die die Fehlerbehebung verifizieren soll.
  469. </para>
  470. </listitem>
  471. <listitem>
  472. <para>
  473. <emphasis>bugs_products</emphasis> speichert Beziehungen zwischen Bugs und
  474. Produkten. Dies enthält eine Viele-zu-Viele Beziehung, da ein Bug für mehrere
  475. Produkte relevant sein kann. Und natürlich kann ein Produkt auch mehrere Bugs
  476. enthalten.
  477. </para>
  478. </listitem>
  479. </itemizedlist>
  480. <para>
  481. Der folgende SQL Daten Definitions Sprache Pseudocode beschreibt die Tabellen in dieser
  482. Beispieldatenbank. Diese Beispieltabellen werden intensiv bei den automatisierten
  483. Unit-Tests für <classname>Zend_Db</classname> verwendet.
  484. </para>
  485. <programlisting language="sql"><![CDATA[
  486. CREATE TABLE accounts (
  487. account_name VARCHAR(100) NOT NULL PRIMARY KEY
  488. );
  489. CREATE TABLE products (
  490. product_id INTEGER NOT NULL PRIMARY KEY,
  491. product_name VARCHAR(100)
  492. );
  493. CREATE TABLE bugs (
  494. bug_id INTEGER NOT NULL PRIMARY KEY,
  495. bug_description VARCHAR(100),
  496. bug_status VARCHAR(20),
  497. reported_by VARCHAR(100) REFERENCES accounts(account_name),
  498. assigned_to VARCHAR(100) REFERENCES accounts(account_name),
  499. verified_by VARCHAR(100) REFERENCES accounts(account_name)
  500. );
  501. CREATE TABLE bugs_products (
  502. bug_id INTEGER NOT NULL REFERENCES bugs,
  503. product_id INTEGER NOT NULL REFERENCES products,
  504. PRIMARY KEY (bug_id, product_id)
  505. );
  506. ]]></programlisting>
  507. <para>
  508. Weiterhin zu beachten ist, dass die <code>bugs</code> Tabelle mehrere Foreign-Key
  509. References zu der <code>accounts</code> Tabelle enthält. Jeder dieser Foreign-Keys kann
  510. auf eine andere Zeile für einen angegebenen Bug in der <code>accounts</code> Tabelle
  511. verweisen.
  512. </para>
  513. <para>
  514. Das unten stehende Diagramm illustriert das physische Datenmodell der Beispieldatenbank.
  515. </para>
  516. <para>
  517. <inlinegraphic width="387" scale="100" align="center" valign="middle"
  518. fileref="figures/zend.db.adapter.example-database.png" format="PNG" />
  519. </para>
  520. </sect2>
  521. <sect2 id="zend.db.adapter.select">
  522. <title>Lesen von Abfrageergebnissen</title>
  523. <para>
  524. Dieser Abschnitt beschreibt Methoden der Adapterklasse mit denen SELECT Abfragen
  525. ausgeführt werden können um Abfrageergebnisse abzurufen.
  526. </para>
  527. <sect3 id="zend.db.adapter.select.fetchall">
  528. <title>Holen des kompletten Ergebnisssatzes</title>
  529. <para>
  530. Man kann eine SQL SELECT Anfrage ausführen und alle Ergebnisse auf einmal mit der
  531. <methodname>fetchAll()</methodname> Methode abrufen.
  532. </para>
  533. <para>
  534. Das erste Argument dieser Methode ist ein String der die SELECT Anweisung enthält.
  535. Als Alternative kann das erste Argument auch ein Objekt der
  536. <link linkend="zend.db.select">Zend_Db_Select</link> Klasse sein. Der Adapter
  537. konvertiert dieses automatisch in einen String der die SELECT Anweisung
  538. repräsentiert.
  539. </para>
  540. <para>
  541. Das zweite Argument von <methodname>fetchAll()</methodname> ist ein Array von
  542. Werten die Parameterplatzhalter in der SQL Anweisung ersetzen.
  543. </para>
  544. <example id="zend.db.adapter.select.fetchall.example">
  545. <title>Nutzung von fetchAll()</title>
  546. <programlisting language="php"><![CDATA[
  547. $sql = 'SELECT * FROM bugs WHERE bug_id = ?';
  548. $result = $db->fetchAll($sql, 2);
  549. ]]></programlisting>
  550. </example>
  551. </sect3>
  552. <sect3 id="zend.db.adapter.select.fetch-mode">
  553. <title>Ändern des Fetch Modus</title>
  554. <para>
  555. Standardmäßig gibt <methodname>fetchAll()</methodname> ein Array von Zeilen, jede
  556. als assoziatives Array, zurück. Die Schlüssel von diesem assoziativem Array
  557. entsprechen den Spalten oder Spaltenaliasen wie sie in der SELECT Anfrage benannt
  558. sind.
  559. </para>
  560. <para>
  561. Man kann einen anderen Stil für das Holen der Ergebnisse mit der
  562. <methodname>setFetchMode()</methodname> Methode angeben. Die unterstützten Modi
  563. werden mit folgenden Konstanten identifiziert:
  564. </para>
  565. <itemizedlist>
  566. <listitem>
  567. <para>
  568. <emphasis>Zend_Db::FETCH_ASSOC</emphasis>:
  569. Gibt Daten in einem assoziativem Array zurück. Die Array Schlüssel sind
  570. Strings der Spaltennamen. Dies ist der Standardmodus für
  571. <classname>Zend_Db_Adapter</classname> Klassen.
  572. </para>
  573. <para>
  574. Zu beachten ist, dass wenn die Select-Liste mehr als eine Spalte mit dem
  575. selben Namen enthält, zum Beispiel wenn diese aus verschiedenen Tabellen
  576. durch einem JOIN bestehen, kann nur einer der Einträge in dem assoziativem
  577. Array enthalten sein. Wenn der FETCH_ASSOC Modus verwandt wird, sollten
  578. Spaltenaliase in der SELECT Anfrage angegeben werden um sicherzustellen das
  579. die Namen eindeutige Arrayschlüssel ergeben.
  580. </para>
  581. <para>
  582. Standardmäßig werden die Strings so zurück gegeben wie sie von dem
  583. Datenbanktreiber geliefert werden. Dies entspricht der typischen
  584. Schreibweise der Spaltennamen auf dem RDBMS Server. Die Schreibweise dieser
  585. Strings kann mit der <classname>Zend_Db::CASE_FOLDING</classname> Option
  586. angegeben werden. Dies muss bei der Instanziierung des Adapters angegeben
  587. werden. Beschreibung unter
  588. <xref linkend="zend.db.adapter.connecting.parameters.example1" />.
  589. </para>
  590. </listitem>
  591. <listitem>
  592. <para>
  593. <emphasis>Zend_Db::FETCH_NUM</emphasis>: Gibt Daten in einem Array von
  594. Arrays zurück. Die Arrays werden über Integer indiziert, entsprechend der
  595. Position der betreffenden Felder in der Select-Liste der Anfrage.
  596. </para>
  597. </listitem>
  598. <listitem>
  599. <para>
  600. <emphasis>Zend_Db::FETCH_BOTH</emphasis>: Gibt ein Array von Arrays zurück.
  601. Die Arrayschlüssel sind sowohl Strings wie beim FETCH_ASSOC Modus, als auch
  602. Integer wie beim FETCH_NUM modus. Zu beachten ist, dass die Anzahl der
  603. Elemente in dem Array doppelt so groß ist, als wenn FETCH_ASSOC oder
  604. FETCH_NUM verwendet worden wäre.
  605. </para>
  606. </listitem>
  607. <listitem>
  608. <para>
  609. <emphasis>Zend_Db::FETCH_COLUMN</emphasis>: Gibt Daten in einem Array von
  610. Werten zurück. Die Werte in jedem Array sind die Werte wie sie in einer
  611. Spalte des Ergebnisses zurück gegeben wurden. Standardmäßig ist die erste
  612. Spalte mit 0 indiziert.
  613. </para>
  614. </listitem>
  615. <listitem>
  616. <para>
  617. <emphasis>Zend_Db::FETCH_OBJ</emphasis>: Gibt Daten in einem Array von
  618. Objekten zurück. Die Standardklasse ist die in PHP eingebaute Klasse
  619. stdClass. Spalten des Ergebnisses sind als öffentliche Eigenschaften des
  620. Objekts verfügbar.
  621. </para>
  622. </listitem>
  623. </itemizedlist>
  624. <example id="zend.db.adapter.select.fetch-mode.example">
  625. <title>Nutzung von setFetchMode()</title>
  626. <programlisting language="php"><![CDATA[
  627. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  628. $result = $db->fetchAll('SELECT * FROM bugs WHERE bug_id = ?', 2);
  629. // $result ist ein Array von Objekten
  630. echo $result[0]->bug_description;
  631. ]]></programlisting>
  632. </example>
  633. </sect3>
  634. <sect3 id="zend.db.adapter.select.fetchassoc">
  635. <title>Holen eines Ergbnisssatzes als assoziatives Array</title>
  636. methodname <para>
  637. Die <methodname>fetchAssoc()</methodname> Methode gibt Daten in einem Array von
  638. assoziativen Array zurück, egal welcher Wert für den fetch-Modus gesetzt wurde.
  639. </para>
  640. <example id="zend.db.adapter.select.fetchassoc.example">
  641. <title>Nutzung von fetchAssoc()</title>
  642. <programlisting language="php"><![CDATA[
  643. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  644. $result = $db->fetchAssoc('SELECT * FROM bugs WHERE bug_id = ?', 2);
  645. // $result ist ein Array von assoziativen Arrays im Geist von fetch mode
  646. echo $result[0]['bug_description'];
  647. ]]></programlisting>
  648. </example>
  649. </sect3>
  650. <sect3 id="zend.db.adapter.select.fetchcol">
  651. <title>Holen einer einzelnen Spalte eines Ergebnisssatzes</title>
  652. <para>
  653. Die <methodname>fetchCol()</methodname> Methode gibt Daten in einem Array von
  654. Werten zurück, egal welcher Wert für den fetch-Modus gesetzt wurde. Sie gibt nur
  655. die erste Spalte der Anfrage zurück. Alle weiteren Spalten der Anfrage werden
  656. verworfen. Wenn eine andere Spalte als die Erste benötigt wird sollte
  657. <xref linkend="zend.db.statement.fetching.fetchcolumn" /> beachtet werden.
  658. </para>
  659. <example id="zend.db.adapter.select.fetchcol.example">
  660. <title>Nutzung von fetchCol()</title>
  661. <programlisting language="php"><![CDATA[
  662. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  663. $result = $db->fetchCol(
  664. 'SELECT bug_description, bug_id FROM bugs WHERE bug_id = ?', 2);
  665. // Enthält bug_description; bug_id wird nicht zurückgegeben
  666. echo $result[0];
  667. ]]></programlisting>
  668. </example>
  669. </sect3>
  670. <sect3 id="zend.db.adapter.select.fetchpairs">
  671. <title>Holen von Schlüssel-Wert Paaren eines Ergebnisssatzes</title>
  672. <para>
  673. Die <methodname>fetchPairs()</methodname> Methode gibt Daten in einem Array von
  674. Schlüssel-Wert Paaren zurück, einem assoziativen Array mit einem einzelnen Eintrag
  675. pro Zeile. Der Schlüssel dieses assoziativen Arrays wird von der ersten Spalte des
  676. SELECT Ergebnisses genommen. Der Wert wird aus der zweiten Spalte des SELECT
  677. Ergebnisses genommen. Alle weiteren Spalten des Ergebnisses werden verworfen.
  678. </para>
  679. <para>
  680. Die SELECT Anfrage sollte so gestaltet sein, dass die erste Spalte nur eindeutige
  681. Werte liefert. Wenn doppelte Werte in der ersten Spalte vorkommen, werden
  682. entsprechende Einträge in dem assoziativen Array überschrieben.
  683. </para>
  684. <example id="zend.db.adapter.select.fetchpairs.example">
  685. <title>Nutzung von fetchPairs()</title>
  686. <programlisting language="php"><![CDATA[
  687. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  688. $result = $db->fetchAssoc('SELECT bug_id, bug_status FROM bugs');
  689. echo $result[2];
  690. ]]></programlisting>
  691. </example>
  692. </sect3>
  693. <sect3 id="zend.db.adapter.select.fetchrow">
  694. <title>Holen einer einzelnen Zeile eines Ergebnisssatzes</title>
  695. <para>
  696. Die <methodname>fetchRow()</methodname> Methode gibt Daten entsprechend dem
  697. fetch-Modus zurück, jedoch nur die erste Zeile des Ergebnisssatzes.
  698. </para>
  699. <example id="zend.db.adapter.select.fetchrow.example">
  700. <title>Nutzung von fetchRow()</title>
  701. <programlisting language="php"><![CDATA[
  702. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  703. $result = $db->fetchRow('SELECT * FROM bugs WHERE bug_id = 2');
  704. // Beachte das $result ein einzelnes Objekt ist, und kein Array von Objekten
  705. echo $result->bug_description;
  706. ]]></programlisting>
  707. </example>
  708. </sect3>
  709. <sect3 id="zend.db.adapter.select.fetchone">
  710. <title>Holen eines einzelnen Scalars aus einem Ergebnisssatz</title>
  711. <para>
  712. Die <methodname>fetchOne()</methodname> Methode ist wie eine Kombination von
  713. <methodname>fetchRow()</methodname> mit <methodname>fetchCol()</methodname>, gibt
  714. also nur die erste Zeile des Ergebnisssatze zurück, und von dieser auch nur den
  715. Wert der ersten Spalte. Daher wird nur ein einziger scalarer Wert zurückgegeben,
  716. kein Array und auch kein Objekt.
  717. </para>
  718. <example id="zend.db.adapter.select.fetchone.example">
  719. <title>Nutzung von fetchOne()</title>
  720. <programlisting language="php"><![CDATA[
  721. $result = $db->fetchOne('SELECT bug_status FROM bugs WHERE bug_id = 2');
  722. // this is a single string value
  723. echo $result;
  724. ]]></programlisting>
  725. </example>
  726. </sect3>
  727. </sect2>
  728. <sect2 id="zend.db.adapter.write">
  729. <title>Schreiben von Änderungen in die Datenbank</title>
  730. <para>
  731. Die Adapterklasse kann verwendet werden um neue Daten in die Datenbank zu schreiben oder
  732. bestehende Daten in der Datenbank zu ändern. Dieser Abschnitt beschreibt Methoden für
  733. diese Operationen.
  734. </para>
  735. <sect3 id="zend.db.adapter.write.insert">
  736. <title>Einfügen von Daten</title>
  737. <para>
  738. Neue Zeilen können in die Datenbank mit der <methodname>insert()</methodname>
  739. Methode eingefügt werden. Das erste Argument ist ein String der die Tabelle
  740. benennt, und das zweite Argument ist ein assoziatives Array das den Spaltennamen
  741. Datenwerte zuordnet.
  742. </para>
  743. <example id="zend.db.adapter.write.insert.example">
  744. <title>Einfügen in eine Tabelle</title>
  745. <programlisting language="php"><![CDATA[
  746. $data = array(
  747. 'created_on' => '2007-03-22',
  748. 'bug_description' => 'Etwas falsch',
  749. 'bug_status' => 'NEW'
  750. );
  751. $db->insert('bugs', $data);
  752. ]]></programlisting>
  753. </example>
  754. <para>
  755. Spalten die nicht in dem Array definiert sind, werden nicht an die Datenbank
  756. übergeben. Daher folgen sie den selben Regeln denen eine SQL INSERT Anweisung folgt:
  757. wenn die Spalte einen Standardwert hat, so bekommt die Spalte der neuen Zeile diesen
  758. Wert. Andernfalls behält sie den Status <constant>NULL</constant>.
  759. </para>
  760. <para>
  761. Standardmäßig werden die Daten in dem Array mit Parametern eingefügt. Dies reduziert
  762. das Risiko einiger Typen von Sicherheitsproblemen. Die Werte in dem Array müssen
  763. daher nicht escaped oder quotiert übergeben werden.
  764. </para>
  765. <para>
  766. Einige Werte in dem Array könnten als SQL Expressions benötigt werden, in diesem
  767. Fall dürfen sie nicht in Anführungszeichen stehen. Standardmäßig werden alle
  768. übergebenen String-Werte als String-literale behandelt. Um anzugeben das ein Wert
  769. eine SQL Expression ist, und daher nicht quotiert werden soll, muss der Wert als ein
  770. Objekt des Typs <classname>Zend_Db_Expr</classname> übergeben werden, und nicht als
  771. einfacher String.
  772. </para>
  773. <example id="zend.db.adapter.write.insert.example2">
  774. <title>Einfügen von Expressions in eine Tabelle</title>
  775. <programlisting language="php"><![CDATA[
  776. $data = array(
  777. 'created_on' => new Zend_Db_Expr('CURDATE()'),
  778. 'bug_description' => 'Etwas falsch',
  779. 'bug_status' => 'NEW'
  780. );
  781. $db->insert('bugs', $data);
  782. ]]></programlisting>
  783. </example>
  784. </sect3>
  785. <sect3 id="zend.db.adapter.write.lastinsertid">
  786. <title>Abfragen von generierten Werten</title>
  787. <para>
  788. Einige RDBMS Marken unterstützen Auto-Incrementierung von Primärschlüsseln. Eine
  789. Tabelle die so definiert ist generiert automatisch einen Primärschlüsselwert
  790. während des INSERTs einer neuen Zeile. Der Rückgabewert der
  791. <methodname>insert()</methodname> Methode ist <emphasis>nicht</emphasis> die letzte
  792. eingefügte ID, weil die Tabelle keine Auto-Increment Spalte haben könnte. Statt
  793. dessen ist der Rückgabewert die Anzahl der betroffenen Zeilen (normalerweise 1).
  794. </para>
  795. <para>
  796. Wenn die Tabelle mit einem Auto-Increment Primärschlüssel definiert ist, kann die
  797. <methodname>lastInsertId()</methodname> Methode nach dem INSERT aufgerufen werden.
  798. Diese Methode gibt den letzten generierten Wertim Rahmen der aktuellen
  799. Datenbankverbindung zurück.
  800. </para>
  801. <example id="zend.db.adapter.write.lastinsertid.example-1">
  802. <title>Nutzung von lastInsertId() für einen Auto-Increment Schlüssel</title>
  803. <programlisting language="php"><![CDATA[
  804. $db->insert('bugs', $data);
  805. // Gib den letzten durch eine auto-inkrement Spalte erzeugten Wert zurück
  806. $id = $db->lastInsertId();
  807. ]]></programlisting>
  808. </example>
  809. <para>
  810. Einige RDBMS Marken unterstützen ein Sequenz-Objekt, welches eindeutige Werte
  811. generiert, die als Primärschlüsselwerte dienen. Um Sequenzen zu unterstützen,
  812. akzeptiert die <methodname>lastInsertId()</methodname> Method zwei optionale String
  813. Argumente. Diese Argumente benennen die Tabelle und die Spalte, in der Annahme das
  814. die Konvention beachtet wurde, dass eine Sequenz mit der Tabelle und der Spalte
  815. benannt wurde, für die sie Werte generiert plus dem Anhang "_seq". Dies basiert auf
  816. der Konvention die von PostgreSQL verwendet wird, wenn Sequenzen für SERIAL Spalten
  817. benannt werden. Zum Beispiel würde eine Tabelle "bugs" mit der
  818. Primärschlüsselspalte "bug_id" eine Sequenz als "bugs_bug_id_seq" benennen.
  819. </para>
  820. <example id="zend.db.adapter.write.lastinsertid.example-2">
  821. <title>Nutzung von lastInsertId() für eine Sequenz</title>
  822. <programlisting language="php"><![CDATA[
  823. $db->insert('bugs', $data);
  824. // Gib den letzten durch die 'bugs_bug_id_seq' Sequenz erstellten Wert zurück
  825. $id = $db->lastInsertId('bugs', 'bug_id');
  826. // Gib, alternativ, den letzten durch die 'bugs_seq' Sequenz
  827. // erstellten Wert zurück
  828. $id = $db->lastInsertId('bugs');
  829. ]]></programlisting>
  830. </example>
  831. <para>
  832. Wenn der Name des Squenz-Objekts nicht dieser Konvention folgt muss die
  833. <methodname>lastSequenceId()</methodname> Methode an Stelle verwendet werden. Diese
  834. Methode benötigt ein String Argument, welches die Sequenz wörtlich benennt.
  835. </para>
  836. <example id="zend.db.adapter.write.lastinsertid.example-3">
  837. <title>Nutzung von lastSequenceId()</title>
  838. <programlisting language="php"><![CDATA[
  839. $db->insert('bugs', $data);
  840. // Gib den letzten durch die 'bugs_id_gen' Sequenz erstellten Wert zurück.
  841. $id = $db->lastSequenceId('bugs_id_gen');
  842. ]]></programlisting>
  843. </example>
  844. <para>
  845. Bei RDBMS Marken die keine Sequenzen unterstützen, dazu gehören MySQL, Microsoft
  846. SQL Server und SQLite, werden die Argumente an die
  847. <methodname>lastInsertId()</methodname> Methode ignoriert, und der zurück gegebene
  848. Wert ist der zuletzt für eirgendeine Tabelle während einer INSERT Operation
  849. generierte Wert innerhalb der aktuellen Verbindung. Für diese RDBMS Marken gibt die
  850. <methodname>lastSequenceId()</methodname> Methode immer <constant>NULL</constant>
  851. zurück.
  852. </para>
  853. <note>
  854. <title>Weßhalb sollte man nicht "SELECT MAX(id) FROM table" verwenden?</title>
  855. <para>
  856. Manchmal gibt diese Anfrage den zuletzt eingefügten Primärschlüsselwert zurück.
  857. Trotzdem ist diese Technik in einer Umgebung in der mehrere Clients Daten in die
  858. Datenbank einfügen nicht sicher. Es ist möglich, und daher vorherbestimmt
  859. eventuell aufzutreten, das ein anderer Client in dem Augenblick zwischen dem
  860. INSERT deiner Client Anwendung und deiner Anfrage für den MAX(id) Wert, eine
  861. andere Zeile einfügt. Somit identifiziert der zurück gegebene Wert nicht die von
  862. dir eingefügte Zeile, sondern die eines anderen Clients. Man kann nie wissen
  863. wann dies passiert.
  864. </para>
  865. <para>
  866. Das Nutzen eines starken Transaktions Isolationsmodus wie "repeatable read" kann
  867. das Risiko mindern, aber einige RDBMS Marken unterstützen nicht die Transaktions
  868. Isolation die hierfür benötigt wird, oder deine Applikation könnte einen
  869. schwächeren Transaktions Isolationsmodus nutzen.
  870. </para>
  871. <para>
  872. Darüberhinaus ist das Nutzen eins Ausdrucks wie "MAX(id)+1" um einen neuen Wert
  873. für den Primärschlüssel zu generiern nict sicher, weil zwei Clients diese
  874. Anfrage gleichzeitig ausführen könnten und damit beide den gleichen Wert für
  875. ihre nächste INSERT Operation bekommen würden.
  876. </para>
  877. <para>
  878. Alle RDBMS Marken bieten einen Mechanismus um eindeutige Werte zu generieren,
  879. und um den zuletzt generierten Wert zurück zu geben. Diese Machanismen
  880. funktionieren notwendigerweise außerhalb des Gültigkeitsbereichs einer
  881. Transaktions Isolation, es besteht daher nicht die Möglichkeit das zwei Clients
  882. den selben Wert generieren und es besteht nicht die Möglichkeit das der Wert,
  883. der von einem anderen Client generiert wurde, an die Verbindung deines Clients,
  884. als letzter generierter Wert, gesendet wird.
  885. </para>
  886. </note>
  887. </sect3>
  888. <sect3 id="zend.db.adapter.write.update">
  889. <title>Aktualisieren von Daten</title>
  890. <para>
  891. Zeilen in der Datenbank können mit der <methodname>update()</methodname> Methode
  892. eines Adapters aktualisiert werden. Diese Methode benötigt drei Argumente: Das
  893. Erste ist der Name der Tabelle und das Zweite ist ein assoziatives Array das den zu
  894. Ändernden Spalten neue Werte zuordnet.
  895. </para>
  896. <para>
  897. Die Werte des Datenarrays werden als String Literale behandelt. Beachte
  898. <xref linkend="zend.db.adapter.write.insert" /> für Informationen zur Nutzung von
  899. SQL Expressions in dem Datenarray.
  900. </para>
  901. <para>
  902. Das dritte Argument ist ein String der aus einer SQL Expression besteht, die genutzt
  903. wird um Kriterien für die Auswahl der zu ändernden Zeilen zu bestimmen. Die Werte
  904. und Bezeichner in diesem Argument werden nicht escaped oder quotiert. An dieser
  905. Stelle muss darauf geachtet werden das sichergestellt ist, das dynamischer Inhalt
  906. sicher in diesen String eingefügt wird. Unter
  907. <xref linkend="zend.db.adapter.quoting" /> sind Methoden beschrieben die dabei
  908. helfen können.
  909. </para>
  910. <para>
  911. Der Rückgabewert ist die Anzahl der Betroffenen Zeilen der UPDATE Operation.
  912. </para>
  913. <example id="zend.db.adapter.write.update.example">
  914. <title>Aktualisieren von Zeilen</title>
  915. <programlisting language="php"><![CDATA[
  916. $data = array(
  917. 'updated_on' => '2007-03-23',
  918. 'bug_status' => 'FIXED'
  919. );
  920. $n = $db->update('bugs', $data, 'bug_id = 2');
  921. ]]></programlisting>
  922. </example>
  923. <para>
  924. Wenn das dritte Argument ausgelassen wird, werden alle Zeilen der Tabelle mit den
  925. Werten des Datenarrays aktualisiert.
  926. </para>
  927. <para>
  928. Wenn ein Array mit Strings als drittes Argument übergeben wird, werden diese
  929. Strings als eine Expression von Ausdrücken, getrennt von <constant>AND</constant>
  930. Operatoren, zusammengefügt.
  931. </para>
  932. <example id="zend.db.adapter.write.update.example-array">
  933. <title>Aktualisieren von Zeilen unter Nutzung eines Arrays von Expressions</title>
  934. <programlisting language="php"><![CDATA[
  935. $data = array(
  936. 'updated_on' => '2007-03-23',
  937. 'bug_status' => 'FIXED'
  938. );
  939. $where[] = "reported_by = 'goofy'";
  940. $where[] = "bug_status = 'OPEN'";
  941. $n = $db->update('bugs', $data, $where);
  942. // Der erstellte SQL Syntax ist:
  943. // UPDATE "bugs" SET "update_on" = '2007-03-23', "bug_status" = 'FIXED'
  944. // WHERE ("reported_by" = 'goofy') AND ("bug_status" = 'OPEN')
  945. ]]></programlisting>
  946. </example>
  947. </sect3>
  948. <sect3 id="zend.db.adapter.write.delete">
  949. <title>Löschen von Daten</title>
  950. <para>
  951. Daten können aus einer Datenbanktabelle mit der <methodname>delete()</methodname>
  952. Methode gelöscht werden. Diese Methode benötigt zwei Argumente: Das erste ist ein
  953. String der die Tabelle benennt.
  954. </para>
  955. <para>
  956. Das zweite Argument ist ein String der aus einer SQL Expression besteht, welche
  957. Kriterien für die zu löschenden Zeilen enthält. Die Werte und Bezeichner in diesem
  958. Argument werden nicht escaped quotiert. An dieser Stelle muss darauf geachtet werden
  959. das sichergestellt ist, das dynamischer Inhalt sicher in diesen String eingefügt
  960. wird. Unter <xref linkend="zend.db.adapter.quoting" /> sind Methoden beschrieben die
  961. dabei helfen können.
  962. </para>
  963. <para>
  964. Der Rückgabewert ist die Anzahl der Betroffenen Zeilen der DELETE Operation.
  965. </para>
  966. <example id="zend.db.adapter.write.delete.example">
  967. <title>Löschen von Zeilen</title>
  968. <programlisting language="php"><![CDATA[
  969. $n = $db->delete('bugs', 'bug_id = 3');
  970. ]]></programlisting>
  971. </example>
  972. <para>
  973. Wenn das zweite Argument ausgelassen wird, werden alle Zeilen der Tabelle gelöscht.
  974. </para>
  975. <para>
  976. Wenn ein Array mit Strings als zweites Argument übergeben wird, werden diese
  977. Strings als eine Expression von Ausdrücken, getrennt von <constant>AND</constant>
  978. Operatoren, zusammengefügt.
  979. </para>
  980. </sect3>
  981. </sect2>
  982. <sect2 id="zend.db.adapter.quoting">
  983. <title>Quotierung von Werten und Bezeichnern</title>
  984. <para>
  985. Beim Erzeugen von SQL Anfragen ist es häufig nötig PHP Variablen in die SQL Expression
  986. einzufügen. Dies ist riskant, weil der Wert eines PHP Strings bestimmte Zeichen
  987. enthalten kann, wie das Anführungszeichen, was zu ungültiger SQL Syntax führen kann. Zum
  988. Beispiel, zu beachten ist die ungerade Anzahl der Anführungszeichen in der folgenden
  989. Anfrage:
  990. <programlisting language="php"><![CDATA[
  991. $name = "O'Reilly";
  992. $sql = "SELECT * FROM bugs WHERE reported_by = '$name'";
  993. echo $sql;
  994. // SELECT * FROM bugs WHERE reported_by = 'O'Reilly'
  995. ]]></programlisting>
  996. </para>
  997. <para>
  998. Noch schlimmer ist das Risiko, dass solche Code-Fehler von einer Person absichtlich
  999. ausgenutzt werden um die Funktion der Webanwendung zu manipulieren. Wenn der Wert einer
  1000. PHP Variablen über die Nutzung von HTTP Parametern oder eines anderen Mechanismus
  1001. gesetzt werden kann, könnte eine Person die SQL Anfragen nutzen um Dinge zu tun, wozu
  1002. sie nicht gedacht sind, wie Daten ausgeben, wozu die Person keine Zugangsberechtigung
  1003. hat. Dies ist eine ernst zu nehmende und weit verbreitete Technik um die Sicherheit
  1004. einer Anwendung zu verletzen, bekannt unter dem Namen "SQL Injection" (siehe
  1005. <ulink url="http://en.wikipedia.org/wiki/SQL_Injection">http://en.wikipedia.org/wiki/SQL_Injection</ulink>).
  1006. </para>
  1007. <para>
  1008. Die <classname>Zend_Db</classname> Adapterklassen bieten bequeme Methoden, die helfen
  1009. die Verletzbarkeit durch SQL Injection Angriffe im PHP Code zu reduzieren. Die Lösung
  1010. ist bestimmte Zeichen, wie Anführungszeichen, in PHP Werten zu ersetzen bevor sie in SQL
  1011. Strings eingefügt werden. Dies schützt sowohl vor versehentlicher als auch vor
  1012. absichtlicher Manipulation von SQL Strings durch PHP Variablen, die spezielle Zeichen
  1013. enthalten.
  1014. </para>
  1015. <sect3 id="zend.db.adapter.quoting.quote">
  1016. <title>Nutzung von quote()</title>
  1017. <para>
  1018. Die <methodname>quote()</methodname> Methode benötigt ein Argument, einen skalaren
  1019. String Wert. Sie gibt den Wert mit ersetzten speziellen Zeichen, passend zu dem
  1020. eingesetzten RDBMS, und umgeben von Stringwertbegrenzern zurück. Der Standard SQL
  1021. Stringwertbegrenzer ist das einfache Anführungszeichen (<code>'</code>).
  1022. </para>
  1023. <example id="zend.db.adapter.quoting.quote.example">
  1024. <title>Nutzung von quote()</title>
  1025. <programlisting language="php"><![CDATA[
  1026. $name = $db->quote("O'Reilly");
  1027. echo $name;
  1028. // 'O\'Reilly'
  1029. $sql = "SELECT * FROM bugs WHERE reported_by = $name";
  1030. echo $sql;
  1031. // SELECT * FROM bugs WHERE reported_by = 'O\'Reilly'
  1032. ]]></programlisting>
  1033. </example>
  1034. <para>
  1035. Zu beachten ist, dass der Rückgabewert von <methodname>quote()</methodname> die
  1036. Stringwertbegrenzer enthält. Dies ist ein Unterschied zu anderen Methoden die
  1037. spezielle Zeichen ersetzen, aber keine Stringwertbegrenzer hinzufügen, wie z.B.
  1038. <ulink url="http://www.php.net/mysqli_real_escape_string">mysql_real_escape_string()</ulink>.
  1039. </para>
  1040. <para>
  1041. Es kann notwendig sein Werte in Anführungszeichen zu setzen oder nicht je nach dem
  1042. Kontext des SQL Datentyps in dem diese verwendet werden. Zum Beispiel darf, in
  1043. einigen RDBMS Typen, ein Integer Wert nicht wie in String in Anführungszeichen
  1044. gesetzt werden, wenn dieser mit einer Integer-Typ Spalte oder einem Ausdruck
  1045. verglichen wird. Anders gesagt ist das folgende in einigen SQL Implementationen ein
  1046. Fehler, wenn angenommen wird das <code>intColumn</code> einen SQL Datentyp von
  1047. <constant>INTEGER</constant> besitzt
  1048. <programlisting language="php"><![CDATA[
  1049. SELECT * FROM atable WHERE intColumn = '123'
  1050. ]]></programlisting>
  1051. </para>
  1052. <para>
  1053. Es kann das optionale zweite Argument der <methodname>quote()</methodname> Methode
  1054. verwendet werden um die Verwendung von Anführungszeichen selektiv für den
  1055. spezifizierten SQL Datentyp auszuwählen.
  1056. </para>
  1057. <example id="zend.db.adapter.quoting.quote.example-2">
  1058. <title>Verwenden von quote() mit einem SQL Typ</title>
  1059. <programlisting language="php"><![CDATA[
  1060. $value = '1234';
  1061. $sql = 'SELECT * FROM atable WHERE intColumn = '
  1062. . $db->quote($value, 'INTEGER');
  1063. ]]></programlisting>
  1064. </example>
  1065. <para>
  1066. Jede <classname>Zend_Db_Adapter</classname> Klasse hat den Namen des nummerischen
  1067. SQL Datentyps für die respektive Marke von RDBMS codiert. Man kann genauso die
  1068. Konstanten <classname>Zend_Db::INT_TYPE</classname>,
  1069. <classname>Zend_Db::BIGINT_TYPE</classname>, und
  1070. <classname>Zend_Db::FLOAT_TYPE</classname> verwenden um Code in einem mehr
  1071. RDBMS-unabhängigen Weg zu schreiben.
  1072. </para>
  1073. <para>
  1074. <classname>Zend_Db_Table</classname> definiert SQL Typen zu
  1075. <methodname>quote()</methodname> automatisch wenn SQL Abfragen erstellt werden die
  1076. einer Tabellen Schlüssel Spalte entsprechen.
  1077. </para>
  1078. </sect3>
  1079. <sect3 id="zend.db.adapter.quoting.quote-into">
  1080. <title>Nutzung von quoteInto()</title>
  1081. <para>
  1082. Die typischste Anwendung von Quotierung ist das Einfügen von PHP Variablen in eine
  1083. SQL Expression oder Anweisung. Die <methodname>quoteInto()</methodname> Methode
  1084. kann verwendet werden um dies in einem Schritt zu erledigen. Die Methode benötigt
  1085. zwei Argumente: Das erste Argument ist ein String der ein Platzhaltersymbol
  1086. (<code>?</code>) enthält, und das zweite Argument ist ein Wert oder eine PHP
  1087. Variable die den Platzhalter ersetzen soll.
  1088. </para>
  1089. <para>
  1090. Das Platzhaltersymbol ist das gleiche Symbol wie es von vielen RDBMS Marken für
  1091. Lage betreffende Parameter verwendet wird, aber die
  1092. <methodname>quoteInto()</methodname> Methode bildet nur Abfrageparameter nach. Die
  1093. Methode fügt den Wert des Strings in den SQL String ein, ersetzt dabei spezielle
  1094. Zeichen und fügt Stringwertbegrenzer ein. Echte Abfrageparameter sorgen für eine
  1095. Trennung von SQL String und Parametern wenn die Anweisung vom RDBMS Server
  1096. verarbeitet wird.
  1097. </para>
  1098. <example id="zend.db.adapter.quoting.quote-into.example">
  1099. <title>Nutzung von quoteInto()</title>
  1100. <programlisting language="php"><![CDATA[
  1101. $sql = $db->quoteInto("SELECT * FROM bugs WHERE reported_by = ?", "O'Reilly");
  1102. echo $sql;
  1103. // SELECT * FROM bugs WHERE reported_by = 'O\'Reilly'
  1104. ]]></programlisting>
  1105. </example>
  1106. <para>
  1107. Man kann den optionalen dritten Parameter von <methodname>quoteInto()</methodname>
  1108. verwenden um den SQL Datentyp zu spezifizieren. Nummerische Datentypen werden nicht
  1109. in Anführungszeichen gesetzt und andere Typen werden in Anführungszeichen gesetzt.
  1110. </para>
  1111. <example id="zend.db.adapter.quoting.quote-into.example-2">
  1112. <title>Verwenden von quoteInto() mit einem SQL Typ</title>
  1113. <programlisting language="php"><![CDATA[
  1114. $sql = $db
  1115. ->quoteInto("SELECT * FROM bugs WHERE bug_id = ?", '1234', 'INTEGER');
  1116. echo $sql;
  1117. // SELECT * FROM bugs WHERE reported_by = 1234
  1118. ]]></programlisting>
  1119. </example>
  1120. </sect3>
  1121. <sect3 id="zend.db.adapter.quoting.quote-identifier">
  1122. <title>Nutzung von quoteIdentifier()</title>
  1123. <para>
  1124. Werte könnten nicht der einzige Teil der SQL Syntax sein, der Variabel sein soll.
  1125. Wenn PHP Variablen genutzt werden um Tabellen, Spalten oder andere Bezeichner in den
  1126. SQL Anweisungen zu benennen, könnte es nötig sein das diese Strings ebenfalls
  1127. quotiert werden müssen. Standardmäßig haben SQL Bezeichner Syntaxregeln wie PHP und
  1128. die meißten anderen Programmiersprachen. Zum Beispiel dürfen Bezeichner keine
  1129. Leerzeichen, bestimmte Punktierung, spezielle Zeichen oder Internationale Zeichen
  1130. enthalten. Außerdem sind bestimmte Wörter für die SQL Syntax reserviert und dürfen
  1131. nicht als Bezeichner verwendet werden.
  1132. </para>
  1133. <para>
  1134. Dennoch hat SQL ein Feature mit Namen
  1135. <emphasis>delimited identifiers (begrenzte Bezeichner)</emphasis>, welches eine
  1136. größere Auswahl bei der Schreibweise von Bezeichnern erlaubt. Wenn ein SQL
  1137. Bezeichner mit dem richtigen Typ von´ Quotierung eingeschlossen ist, können
  1138. Schreibweisen für die Bezeichner verwendet werden, die ohne der Quotierung ungültig
  1139. wären. Begrenzte Bezeichner können Leerzeichen, Punktierung oder internationale
  1140. Zeichen enthalten. Desweiteren dürfen auch von der SQL Syntax reservierte Wörter
  1141. verwendet werden, wenn sie von Bezeichner Begrenzungszeichen eingeschlossen sind.
  1142. </para>
  1143. <para>
  1144. Die <methodname>quoteIdentifier()</methodname> Methode funktioniert wie
  1145. <methodname>quote()</methodname>, aber sie wendet die Bezeichner Begrenzungszeichen
  1146. entsprechend dem verwendeten Adapter an. Zum Beispiel nutzt Standard-SQL doppelte
  1147. Anführungszeichen (<code>"</code>) zum begrenzen von Bezeichnern und die meisten
  1148. der RDBMS Marken nutzen ebendfalls dieses Symbol. MySQL hingegen benutzt
  1149. back-quotes (<code>`</code>) als Standardzeichen. Die
  1150. <methodname>quoteIdentifier()</methodname> Methode ersetzt außerdem spezielle
  1151. Zeichen im String Argument.
  1152. </para>
  1153. <example id="zend.db.adapter.quoting.quote-identifier.example">
  1154. <title>Nutzung von quoteIdentifier()</title>
  1155. <programlisting language="php"><![CDATA[
  1156. // Wir könnten einen Tabellennamen haben, der ein in SQL reserviertes Wort ist
  1157. $tableName = $db->quoteIdentifier("order");
  1158. $sql = "SELECT * FROM $tableName";
  1159. echo $sql
  1160. // SELECT * FROM "order"
  1161. ]]></programlisting>
  1162. </example>
  1163. <para>
  1164. SQL begrenzte Bezeichner beachten die Groß- und Kleinschreibung, im Gegensatz zu
  1165. nicht quotierten Bezeichnern. Daher muss, bei Verwendung von begrenztern
  1166. Bezeichnern, die Schreibung der Bezeichner genau der Schreibung der Bezeichner im
  1167. Tabellenschema entsprechen. Einschließlich der Groß- und Kleinschreibung.
  1168. </para>
  1169. <para>
  1170. In den meisten Fällen wo SQL innerhalb der <classname>Zend_Db</classname> Klassen
  1171. generiert wird, werden standardmäßig alle Bezeichner automatisch begrenzt. Dieses
  1172. Verhalten kann mit der Option <classname>Zend_Db::AUTO_QUOTE_IDENTIFIERS</classname>
  1173. geändert werden. Dies muss beim Instanziieren des Adapters wie in
  1174. <xref linkend="zend.db.adapter.connecting.parameters.example2" /> angegeben werden.
  1175. </para>
  1176. </sect3>
  1177. </sect2>
  1178. <sect2 id="zend.db.adapter.transactions">
  1179. <title>Kontrollieren von Datenbank Transaktionen</title>
  1180. <para>
  1181. Datenbanken definieren Transaktionen als logische Einheiten von Arbeit, die als einzelne
  1182. Änderung übergeben oder rückgängig gemacht werden kann, selbst wenn sie auf
  1183. verschiedenen Tabellen operiert. Alle Anfragen an einen Datenbank werden im Kontext
  1184. einer Transaktion ausgeführt, selbst wenn der Datenbanktreiber sie implizit Verwaltet.
  1185. Es wird <emphasis>auto-commit</emphasis> Modus genannt, wenn der Datenbanktreiber eine
  1186. Transaktion für jede Anweisung erzeugt, und diese direkt nach dem Ausführen übergibt.
  1187. Standardmäßig operieren alle <classname>Zend_Db</classname> Adapterklassen im
  1188. auto-commit Modus.
  1189. </para>
  1190. <para>
  1191. Alternativ kann der Begin und das Ergebnis einer Transaktion selbst spezifiziert
  1192. werden, und damit kann kontrolliert werden wieviele SQL Anfragen in einer Gruppe
  1193. enthalten sind, die entweder übergeben oder rückgängig gemacht wird, als eine
  1194. einzelne Operation. Um eine Transaktion zu initiieren wird die
  1195. <methodname>beginTransaction()</methodname> Methode verwendet. Anschließend folgende
  1196. SQL Anweisungen werden im Kontext der selben Transaktion ausgeführt bis sie explizit
  1197. aufgelöst wird.
  1198. </para>
  1199. <para>
  1200. Um eine Transaktion aufzulösen wird entweder die <methodname>commit()</methodname> oder
  1201. die <methodname>rollBack()</methodname> Methode verwendet. Die
  1202. <methodname>commit()</methodname> Methode markiert die Änderungen die während der
  1203. Transaktionen durchgeführt wurden als übergeben, was bedeutet das die Effekte dieser
  1204. Änderungen in anderen Transaktionen angezeigt werden.
  1205. </para>
  1206. <para>
  1207. Die <methodname>rollBack()</methodname> Methode tut das Gegenteil: sie verwirft die
  1208. Änderungen die während der Transaktionen durchgeführt wurden. Die Änderungen werden
  1209. gewissermaßen ungeschehen gemacht, der Status der Daten ändert sich zurück auf jenen
  1210. wie sie vor Beginn der Transaktion waren. Allerdings hat das rückgängig machen keinen
  1211. Einfluss auf Änderungen die von anderen, gleichzeitig laufenden Transaktionen
  1212. verursacht wurden.
  1213. </para>
  1214. <para>
  1215. Nach dem Auflösen der Transaktion befindet sich der
  1216. <classname>Zend_Db_Adapter</classname> wieder im auto-commit Modus, bis
  1217. <methodname>beginTransaction()</methodname> wieder aufgerufen wird.
  1218. </para>
  1219. <example id="zend.db.adapter.transactions.example">
  1220. <title>Verwalten einer Transaktion um Konsistenz sicher zu stellen</title>
  1221. <programlisting language="php"><![CDATA[
  1222. // Eine Transaktion explizit starten
  1223. $db->beginTransaction();
  1224. try {
  1225. // Versuchen einen oder mehrere Abfragen auszuführen
  1226. $db->query(...);
  1227. $db->query(...);
  1228. $db->query(...);
  1229. // Wenn alle erfolgreich waren, übertrage die Transaktion
  1230. // und alle Änderungen werden auf einmal übermittelt
  1231. $db->commit();
  1232. } catch (Exception $e) {
  1233. // Wenn irgendeine der Abfragen fehlgeschlagen ist, wirf eine Ausnahme, wir
  1234. // wollen die komplette Transaktion zurücknehmen, alle durch die
  1235. // Transaktion gemachten Änderungen wieder entfernen, auch die erfolgreichen
  1236. // So werden alle Änderungen auf einmal übermittelt oder keine
  1237. $db->rollBack();
  1238. echo $e->getMessage();
  1239. }
  1240. ]]></programlisting>
  1241. </example>
  1242. </sect2>
  1243. <sect2 id="zend.db.adapter.list-describe">
  1244. <title>Auflistung und Beschreibung von Tabellen</title>
  1245. <para>
  1246. Die <methodname>listTables()</methodname> Methode gibt ein Array von Strings zurück,
  1247. mit den Namen aller Tabellen in der aktuellen Datenbank.
  1248. </para>
  1249. <para>
  1250. Die <methodname>describeTable()</methodname> Methode gibt ein assoziatives Array von
  1251. MetaDaten über die Tabelle zurück. Das erste Argument dieser Methode ist ein String der
  1252. den Namen der Tabelle enthält. Das zweite Argument ist optional und benennt das Schema
  1253. in dem die Tabelle besteht.
  1254. </para>
  1255. <para>
  1256. Die Schlüssel des assoziativen Arrays sind die Spaltennamen der Tabelle. Der zugehörige
  1257. Wert jeder Spalte ist ebenfalls ein assoziatives Array mit den folgenden Schlüsseln und
  1258. Werten:
  1259. </para>
  1260. <table frame="all" cellpadding="5" id="zend.db.adapter.list-describe.metadata">
  1261. <title>Metadata Felder die von describeTable() zurückgegeben werden</title>
  1262. <tgroup cols="3" align="left" colsep="1" rowsep="1">
  1263. <thead>
  1264. <row>
  1265. <entry>Schlüssel</entry>
  1266. <entry>Typ</entry>
  1267. <entry>Beschreibung</entry>
  1268. </row>
  1269. </thead>
  1270. <tbody>
  1271. <row>
  1272. <entry>SCHEMA_NAME</entry>
  1273. <entry>(string)</entry>
  1274. <entry>Name des Datenbankschemas in welchem diese Tabelle existiert.</entry>
  1275. </row>
  1276. <row>
  1277. <entry>TABLE_NAME</entry>
  1278. <entry>(string)</entry>
  1279. <entry>Name der Tabelle zu welcher diese Spalte gehört.</entry>
  1280. </row>
  1281. <row>
  1282. <entry>COLUMN_NAME</entry>
  1283. <entry>(string)</entry>
  1284. <entry>Name der Spalte.</entry>
  1285. </row>
  1286. <row>
  1287. <entry>COLUMN_POSITION</entry>
  1288. <entry>(integer)</entry>
  1289. <entry>Ordinale Position der Spalte in der Tabelle.</entry>
  1290. </row>
  1291. <row>
  1292. <entry>DATA_TYPE</entry>
  1293. <entry>(string)</entry>
  1294. <entry>RDBMS Name des Datentyps der Spalte.</entry>
  1295. </row>
  1296. <row>
  1297. <entry>DEFAULT</entry>
  1298. <entry>(string)</entry>
  1299. <entry>Standardwert der Spalte, wenn angegeben.</entry>
  1300. </row>
  1301. <row>
  1302. <entry>NULLABLE</entry>
  1303. <entry>(boolean)</entry>
  1304. <entry>
  1305. <constant>TRUE</constant> wenn die Spalte SQL NULL akzeptiert,
  1306. <constant>FALSE</constant> wenn die Spalte eine NOT NULL Bedingung hat.
  1307. </entry>
  1308. </row>
  1309. <row>
  1310. <entry>LENGTH</entry>
  1311. <entry>(integer)</entry>
  1312. <entry>Länge oder Größe der Spalte wie vom RDBMS angegeben.</entry>
  1313. </row>
  1314. <row>
  1315. <entry>SCALE</entry>
  1316. <entry>(integer)</entry>
  1317. <entry>Scalar vom Typ SQL NUMERIC oder DECIMAL.</entry>
  1318. </row>
  1319. <row>
  1320. <entry>PRECISION</entry>
  1321. <entry>(integer)</entry>
  1322. <entry>Präzision des Typs SQL NUMERIC oder DECIMAL.</entry>
  1323. </row>
  1324. <row>
  1325. <entry>UNSIGNED</entry>
  1326. <entry>(boolean)</entry>
  1327. <entry>
  1328. <constant>TRUE</constant> wenn ein Integer-basierender Typ als UNSIGNED
  1329. angegeben wird.
  1330. </entry>
  1331. </row>
  1332. <row>
  1333. <entry>PRIMARY</entry>
  1334. <entry>(boolean)</entry>
  1335. <entry>
  1336. <constant>TRUE</constant> wenn die Spalte Teil des Primärschlüsssels der Tabelle
  1337. ist.
  1338. </entry>
  1339. </row>
  1340. <row>
  1341. <entry>PRIMARY_POSITION</entry>
  1342. <entry>(integer)</entry>
  1343. <entry>
  1344. Ordinale Position (1-basierend) der Spalte des Primärschlüssels.
  1345. </entry>
  1346. </row>
  1347. <row>
  1348. <entry>IDENTITY</entry>
  1349. <entry>(boolean)</entry>
  1350. <entry>
  1351. <constant>TRUE</constant> wenn die Spalte einen auto-increment Wert nutzt.
  1352. </entry>
  1353. </row>
  1354. </tbody>
  1355. </tgroup>
  1356. </table>
  1357. <note>
  1358. <title>Wie das IDENTITY Metadata Feld zu speziellen RDBMS zuzuordnen ist</title>
  1359. <para>
  1360. Das IDENTITY Metadata Feld wurd gewählt als ein 'idiomatischer' Ausdruck um eine
  1361. Relation von Ersatzschlüsseln zu repräsentieren. Dieses Feld ist üblicherweise durch
  1362. die folgenden Werte bekannt:
  1363. </para>
  1364. <itemizedlist>
  1365. <listitem>
  1366. <para>
  1367. <constant>IDENTITY</constant> - DB2, MSSQL
  1368. </para>
  1369. </listitem>
  1370. <listitem>
  1371. <para>
  1372. <constant>AUTO_INCREMENT</constant> - MySQL
  1373. </para>
  1374. </listitem>
  1375. <listitem>
  1376. <para>
  1377. <constant>SERIAL</constant> - PostgreSQL
  1378. </para>
  1379. </listitem>
  1380. <listitem>
  1381. <para>
  1382. <constant>SEQUENCE</constant> - Oracle
  1383. </para>
  1384. </listitem>
  1385. </itemizedlist>
  1386. </note>
  1387. <para>
  1388. Wenn keine Tabelle mit dem Tabellennamen und dem optional angegebenen Schemanamen
  1389. existiert, gibt <methodname>describeTable()</methodname> ein leeres Array zurück.
  1390. </para>
  1391. </sect2>
  1392. <sect2 id="zend.db.adapter.closing">
  1393. <title>Schließen einer Verbindung</title>
  1394. <para>
  1395. Normalerweise ist es nicht nötig eine Datenbankverbindung zu schließen. PHP räumt
  1396. automatisch alle Ressourcen am Ende einer Anfrage auf und die Datenbankerweiterungen
  1397. sind so designed das sie Verbindungen beenden wenn Referenzen zu ihren Objekten
  1398. aufgeräumt werden.
  1399. </para>
  1400. <para>
  1401. Trotzdem könnte es sinnvoll sein, wenn ein lang andauerndes PHP Script verwendet wird,
  1402. das viele Datenbankverbindungen hat, diese zu schließen um zu vermeiden das die
  1403. Kapazität des RDBMS Servers überschritten wird. Die
  1404. <methodname>closeConnection()</methodname> Methode der Adapterklasse kann verwendet
  1405. werden um die zugrundeliegende Datenbankverbindung explizit zu schließen.
  1406. </para>
  1407. <para>
  1408. Seit Release 1.7.2, kann man prüfen ob man mit der
  1409. <methodname>isConnected()</methodname> prüfen ob man aktuell mit dem RDBMS Server
  1410. verbunden ist. Das bedeutet das eine Verbindungs Ressource initialisiert und nicht
  1411. geschlossen wurde. Diese Funktion ist aktuell nicht in der Lage zu prüfen ob zum
  1412. Beispiel die Server Seite die Verbindung geschlossen hat. Das wird intern verwendet um
  1413. die Verbindung zu schließen. Das erlaubt es die Verbindung ohne Fehler mehrere Male zu
  1414. schließen. Das war bereits vor 1.7.2 der Fall für PDO Adapter, aber nicht für die
  1415. anderen.
  1416. </para>
  1417. <example id="zend.db.adapter.closing.example">
  1418. <title>Schließen einer Datenbankverbindung</title>
  1419. <programlisting language="php"><![CDATA[
  1420. $db->closeConnection();
  1421. ]]></programlisting>
  1422. </example>
  1423. <note>
  1424. <title>Unterstützt Zend_Db persistente Verbindungen?</title>
  1425. <para>
  1426. Die Nutzung von persistenten Verbindungen wird weder von
  1427. <classname>Zend_Db</classname> unterstützt, noch gewünscht.
  1428. </para>
  1429. <para>
  1430. Die Benutzung von persistenten Verbindungen kann überschüssige und untätige
  1431. Verbindungen auf dem RDBMS Server verursachen, welche mehr Probleme bringen als
  1432. Performancegewin, welcher möglicherweise angestrebt wird, durch das reduzieren des
  1433. Overheads beim Starten von Verbindungen.
  1434. </para>
  1435. <para>
  1436. Datenbankverbindungen haben einen Status. Natürlich existieren einige Objekte auf
  1437. dem Server im Gültigkeitsbereich einer Session. Beispiele dafür sind locks, user
  1438. variablen, temporary tables und Informationen über die zuletzt ausgeführte Anfrage,
  1439. sowie betroffene Zeilen und zuletzt generierte ID Werte. Wenn persistente
  1440. Verbindungen genutzt werden könnte die Anwendung Zugriff auf ungültige oder
  1441. privilegierte Daten erlangen, die in einem vorigen PHP Request erzeugt wurden.
  1442. </para>
  1443. </note>
  1444. </sect2>
  1445. <sect2 id="zend.db.adapter.other-statements">
  1446. <title>Ausführen anderer Datenbank Anweisungen</title>
  1447. <para>
  1448. Es könnte Fälle geben in denen direkter Zugriff auf das Verbindungsobjekt benötigt wird,
  1449. wie es von der PHP Erweiterung bereitgestellt wird. Einige der Erweiterungen könnten
  1450. Features anbieten, welche nicht von Methoden der
  1451. <classname>Zend_Db_Adapter_Abstract</classname> Klasse auftauchen..
  1452. </para>
  1453. <para>
  1454. Zum Beispiel werden alle SQL Anweisungen von <classname>Zend_Db</classname> vorbereitet
  1455. und dann ausgeführt. Trotzdem gibt es einige Features welche nicht kompatibel mit
  1456. vorbereiteten Anweisungen sind. DDL Anweisungen wie CREATE und ALTER können in MySQL
  1457. nicht vorbereitet werden. Auch können SQL Anweisungen keinen Nutzen aus dem
  1458. <ulink url="http://dev.mysql.com/doc/refman/5.1/en/query-cache-how.html">MySQL Query
  1459. Cache</ulink> ziehen, bei einer geringeren MySQL Version als 5.1.17.
  1460. </para>
  1461. <para>
  1462. Die meisten PHP Datenbankerweiterungen bieten eine Methode um SQL Anweisung auszuführen
  1463. ohne diese vorzubereiten. Zum Beispiel bietet PDO die Methode
  1464. <methodname>exec()</methodname>. Das Verbindungsobjekt der PHP Erweiterung kann kann
  1465. mit der Methode <methodname>getConnection()</methodname> direkt verwendet werden.
  1466. </para>
  1467. <example id="zend.db.adapter.other-statements.example">
  1468. <title>Ausführen eines nicht-prepared Statements mit einem PDO Adapter</title>
  1469. <programlisting language="php"><![CDATA[
  1470. $result = $db->getConnection()->exec('DROP TABLE bugs');
  1471. ]]></programlisting>
  1472. </example>
  1473. <para>
  1474. So ähnlich können auch andere Methoden oder Eigenschaften der speziellen PHP
  1475. Datenbankerweiterung genutzt werden. Zu beachten dabei ist jedoch, dass dadurch
  1476. möglicherweise die Anwendung auf das angegebene Interface, bereitgestellt von einer
  1477. Erweiterung für ein bestimmtes RDBMS, beschränkt wird.
  1478. </para>
  1479. <para>
  1480. In zukünftigen Versionen von <classname>Zend_Db</classname> werden Möglichkeiten gegeben
  1481. sein, um Methoden Startpunkte hinzuzufügen, für Funktionalitäten die den unterstützten
  1482. PHP Datenbankerweiterungen gemein sind. Dies wird die Rückwärtskompatibilität nicht
  1483. beeinträchtigen.
  1484. </para>
  1485. </sect2>
  1486. <sect2 id="zend.db.adapter.server-version">
  1487. <title>Erhalten der Server Version</title>
  1488. <para>
  1489. Seit Release 1.7.2 kann man die Version des Servers in einem PHP artigen Stil erhalten
  1490. damit man es mit <methodname>version_compare()</methodname> verwenden kann. Wenn die
  1491. Information nicht vorhanden ist erhält man <constant>NULL</constant> zurück.
  1492. </para>
  1493. <example id="zend.db.adapter.server-version.example">
  1494. <title>Prüfen der Server Version bevor eine Abfrage gestartet wird</title>
  1495. <programlisting language="php"><![CDATA[
  1496. $version = $db->getServerVersion();
  1497. if (!is_null($version)) {
  1498. if (version_compare($version, '5.0.0', '>=')) {
  1499. // mach was
  1500. } else {
  1501. // mach was anderes
  1502. }
  1503. } else {
  1504. // Server Version ist unmöglich zu lesen
  1505. }
  1506. ]]></programlisting>
  1507. </example>
  1508. </sect2>
  1509. <sect2 id="zend.db.adapter.adapter-notes">
  1510. <title>Anmerkungen zu bestimmten Adaptern</title>
  1511. <para>
  1512. Dieser Abschnitt beschreibt Unterschiede zwischen den verschieden Adapterklassen auf die
  1513. man achtgeben sollte.
  1514. </para>
  1515. <sect3 id="zend.db.adapter.adapter-notes.ibm-db2">
  1516. <title>IBM DB2</title>
  1517. <itemizedlist>
  1518. <listitem>
  1519. <para>
  1520. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1521. dem Namen 'Db2' angegeben.
  1522. </para>
  1523. </listitem>
  1524. <listitem>
  1525. <para>
  1526. Dieser Adapter nutzt die PHP Erweiterung ibm_db2.
  1527. </para>
  1528. </listitem>
  1529. <listitem>
  1530. <para>
  1531. IBM DB2 unterstützt sowohl Sequenzen als auch auto-increment Schlüssel.
  1532. Daher sind die Argumente für <methodname>lastInsertId()</methodname>
  1533. optional. Werden keine Argumente angegeben, gibt der Adapter den letzten
  1534. Wert der für den auto-increment Key generiert wurde zurück. Werden
  1535. Argumente angegeben, gibt der Adapter den letzten Wert der für die Sequenz
  1536. mit dem Namen, entsprechend der Konvention,
  1537. '<emphasis>table</emphasis>_<emphasis>column</emphasis>_seq' generiert
  1538. wurde zurück.
  1539. </para>
  1540. </listitem>
  1541. </itemizedlist>
  1542. </sect3>
  1543. <sect3 id="zend.db.adapter.adapter-notes.mysqli">
  1544. <title>MySQLi</title>
  1545. <itemizedlist>
  1546. <listitem>
  1547. <para>
  1548. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1549. dem Namen 'Mysqli' angegeben.
  1550. </para>
  1551. </listitem>
  1552. <listitem>
  1553. <para>
  1554. Dieser Adapter nutzt die PHP Erweiterung mysqli.
  1555. </para>
  1556. </listitem>
  1557. <listitem>
  1558. <para>
  1559. MySQL unterstützt keine Sequenzen, daher ignoriert
  1560. <methodname>lastInsertId()</methodname> Argumente und gibt immer den
  1561. letzten Wert der für den auto-increment Schlüssel generiert wurde zurück.
  1562. Die <methodname>lastSequenceId()</methodname> Methode gibt
  1563. <constant>NULL</constant> zurück.
  1564. </para>
  1565. </listitem>
  1566. </itemizedlist>
  1567. </sect3>
  1568. <sect3 id="zend.db.adapter.adapter-notes.oracle">
  1569. <title>Oracle</title>
  1570. <itemizedlist>
  1571. <listitem>
  1572. <para>
  1573. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1574. dem Namen 'Oracle' angegeben.
  1575. </para>
  1576. </listitem>
  1577. <listitem>
  1578. <para>
  1579. Dieser Adapter nutzt die PHP Erweiterung oci8.
  1580. </para>
  1581. </listitem>
  1582. <listitem>
  1583. <para>
  1584. Oracle unterstützt keine auto-increment Schlüssel, daher sollte der Name
  1585. einer Sequenz an <methodname>lastInsertId()</methodname> oder
  1586. <methodname>lastSequenceId()</methodname> übergeben werden.
  1587. </para>
  1588. </listitem>
  1589. <listitem>
  1590. <para>
  1591. Die Oracle Erweiterung unterstützt keine positionierten Parameter. Es müssen
  1592. benannte Parameter verwendet werden.
  1593. </para>
  1594. </listitem>
  1595. <listitem>
  1596. <para>
  1597. Aktuell wird die <classname>Zend_Db::CASE_FOLDING</classname> Option vom
  1598. Oracle Adapter nicht unterstützt. Um diese Option mit Oracle zu nutzen muss
  1599. der PDO OCI Adapter verwendet werden.
  1600. </para>
  1601. </listitem>
  1602. <listitem>
  1603. <para>
  1604. Standardmäßig werden LOB Felder als OCI-Log Objekte zurückgegeben. Man kann
  1605. Sie für alle Anfragen als String empfangen indem die Treiberoption
  1606. <code>'lob_as_string'</code> verwendet wird, oder für spezielle Anfragen
  1607. durch Verwendung von <methodname>setLobAsString(boolean)</methodname> auf
  1608. dem Adapter oder dem Statement.
  1609. </para>
  1610. </listitem>
  1611. </itemizedlist>
  1612. </sect3>
  1613. <sect3 id="zend.db.adapter.adapter-notes.pdo-mssql">
  1614. <title>PDO Microsoft SQL Server</title>
  1615. <itemizedlist>
  1616. <listitem>
  1617. <para>
  1618. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1619. dem Namen 'Pdo_Mssql' angegeben.
  1620. </para>
  1621. </listitem>
  1622. <listitem>
  1623. <para>
  1624. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_mssql.
  1625. </para>
  1626. </listitem>
  1627. <listitem>
  1628. <para>
  1629. Microsoft SQL Server unterstützt keine Sequenzen, daher ignoriert
  1630. <methodname>lastInsertId()</methodname> Argumente und gibt immer den
  1631. letzten Wert der für den auto-increment Schlüssel generiert wurde zurück.
  1632. Die <methodname>lastSequenceId()</methodname> Methode gibt
  1633. <constant>NULL</constant> zurück.
  1634. </para>
  1635. </listitem>
  1636. <listitem>
  1637. <para>
  1638. Wenn man mit Unicode Strings in einer anderen Codierung als UCS-2 (wie
  1639. UTF-8) arbeitet, kann es sein das man eine Konvertierung im eigenen
  1640. Anwendungscode durchführen, oder die Daten in einer Binären Spalte speichern
  1641. muß. Referieren Sie bitte auf
  1642. <ulink url="http://support.microsoft.com/kb/232580">Microsoft's Knowledge
  1643. Base</ulink> für weitere Informationen.
  1644. </para>
  1645. </listitem>
  1646. <listitem>
  1647. <para>
  1648. <classname>Zend_Db_Adapter_Pdo_Mssql</classname> setzt
  1649. <constant>QUOTED_IDENTIFIER ON</constant> direkt nach dem Verbinden zu
  1650. einer SQL Server Datenbank. Dadurch verwendet der Treiber das Standard SQL
  1651. Bezeichner Begrenzungssymbol (<code>"</code>) an Stelle der proprietären
  1652. Eckige-Klammer Syntax die der SQL Server standradmäßig nutzt.
  1653. </para>
  1654. </listitem>
  1655. <listitem>
  1656. <para>
  1657. Es kann <code>pdoType</code> als ein Schlüssel im Optionsarray gesetzt
  1658. werden. Der Wert kann "mssql" (der Standard), "dblib", "freetds", oder
  1659. "sybase" sein. Diese Option beeinflusst den DNS Prefix, welchen der Adapter
  1660. beim Konstruieren des DNS Strings benutzt. Sowohl "freetds" als auch
  1661. "sybase" implementieren einen Prefix von "sybase:", welcher für den
  1662. <ulink url="http://www.freetds.org/">FreeTDS</ulink> Satz von Libraries
  1663. verwendet wird. Siehe auch
  1664. <ulink url="http://www.php.net/manual/de/ref.pdo-dblib.connection.php">http://www.php.net/manual/de/ref.pdo-dblib.connection.php</ulink>
  1665. für weitere Informationen über die DNS Prefixe die von diesem Treiber
  1666. verwendet werden.
  1667. </para>
  1668. </listitem>
  1669. </itemizedlist>
  1670. </sect3>
  1671. <sect3 id="zend.db.adapter.adapter-notes.pdo-ibm">
  1672. <title>PDO für IBM DB2 und Informix Dynamic Server (IDS)</title>
  1673. <itemizedlist>
  1674. <listitem>
  1675. <para>
  1676. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1677. dem Namen 'Pdo_Ibm' spezifiziert.
  1678. </para>
  1679. </listitem>
  1680. <listitem>
  1681. <para>
  1682. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_ibm.
  1683. </para>
  1684. </listitem>
  1685. <listitem>
  1686. <para>
  1687. Es muß mindestens die PDO_IBM Erweiterung mit der Version 1.2.2 verwendet
  1688. werden. Wenn eine ältere Version verwendet wird, muß die PDO_IBM Erweiterung
  1689. über PECL hochgerüstet werden.
  1690. </para>
  1691. </listitem>
  1692. </itemizedlist>
  1693. </sect3>
  1694. <sect3 id="zend.db.adapter.adapter-notes.pdo-mysql">
  1695. <title>PDO MySQL</title>
  1696. <itemizedlist>
  1697. <listitem>
  1698. <para>
  1699. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1700. dem Namen 'Pdo_Mysql' angegeben.
  1701. </para>
  1702. </listitem>
  1703. <listitem>
  1704. <para>
  1705. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_mysql.
  1706. </para>
  1707. </listitem>
  1708. <listitem>
  1709. <para>
  1710. MySQL unterstützt keine Sequenzen, daher ignoriert
  1711. <methodname>lastInsertId()</methodname> Argumente und gibt immer den
  1712. letzten Wert der für den auto-increment Schlüssel generiert wurde zurück.
  1713. Die <methodname>lastSequenceId()</methodname> Methode gibt
  1714. <constant>NULL</constant> zurück.
  1715. </para>
  1716. </listitem>
  1717. </itemizedlist>
  1718. </sect3>
  1719. <sect3 id="zend.db.adapter.adapter-notes.pdo-oci">
  1720. <title>PDO Oracle</title>
  1721. <itemizedlist>
  1722. <listitem>
  1723. <para>
  1724. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1725. dem Namen 'Pdo_Oci' angegeben.
  1726. </para>
  1727. </listitem>
  1728. <listitem>
  1729. <para>
  1730. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_oci.
  1731. </para>
  1732. </listitem>
  1733. <listitem>
  1734. <para>
  1735. Oracle unterstützt keine auto-increment Schlüssel, daher sollte der Name
  1736. einer Sequenz an <methodname>lastInsertId()</methodname> oder
  1737. <methodname>lastSequenceId()</methodname> übergeben werden.
  1738. </para>
  1739. </listitem>
  1740. </itemizedlist>
  1741. </sect3>
  1742. <sect3 id="zend.db.adapter.adapter-notes.pdo-pgsql">
  1743. <title>PDO PostgreSQL</title>
  1744. <itemizedlist>
  1745. <listitem>
  1746. <para>
  1747. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1748. dem Namen 'Pdo_Pgsql' angegeben.
  1749. </para>
  1750. </listitem>
  1751. <listitem>
  1752. <para>
  1753. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_pgsql.
  1754. </para>
  1755. </listitem>
  1756. <listitem>
  1757. <para>
  1758. PostgreSQL unterstützt sowohl Sequenzen als auch auto-increment Schlüssel.
  1759. Daher sind die Argumente für <methodname>lastInsertId()</methodname>
  1760. optional. Werden keine Argumente angegeben, gibt der Adapter den letzten
  1761. Wert der für den auto-increment Key generiert wurde zurück. Werden
  1762. Argumente angegeben, gibt der Adapter den letzten Wert der für die Sequenz
  1763. mit dem Namen, entsprechend der Konvention,
  1764. '<emphasis>table</emphasis>_<emphasis>column</emphasis>_seq' generiert
  1765. wurde zurück.
  1766. </para>
  1767. </listitem>
  1768. </itemizedlist>
  1769. </sect3>
  1770. <sect3 id="zend.db.adapter.adapter-notes.pdo-sqlite">
  1771. <title>PDO SQLite</title>
  1772. <itemizedlist>
  1773. <listitem>
  1774. <para>
  1775. Dieser Adapter wird in der <methodname>factory()</methodname> Methode mit
  1776. dem Namen 'Pdo_Sqlite' angegeben.
  1777. </para>
  1778. </listitem>
  1779. <listitem>
  1780. <para>
  1781. Dieser Adapter nutzt die PHP Erweiterungen pdo und pdo_sqlite.
  1782. </para>
  1783. </listitem>
  1784. <listitem>
  1785. <para>
  1786. SQLite unterstützt keine Sequenzen, daher ignoriert
  1787. <methodname>lastInsertId()</methodname> Argumente und gibt immer den
  1788. letzten Wert der für den auto-increment Schlüssel generiert wurde zurück.
  1789. Die <methodname>lastSequenceId()</methodname> Methode gibt
  1790. <constant>NULL</constant> zurück.
  1791. </para>
  1792. </listitem>
  1793. <listitem>
  1794. <para>
  1795. Um mit einer SQLite2 Datenbank zu Verbinden muss
  1796. <code>'sqlite2'=>true</code> in dem Array von Parametern beim Erzeugen einer
  1797. Instanz des Pdo_Sqlite Adapters angegeben werden.
  1798. </para>
  1799. </listitem>
  1800. <listitem>
  1801. <para>
  1802. Um mit einer in-memory SQLite Datenbank zu verbinden muss
  1803. <code>'dbname'=&gt;':memory:'</code> in dem Array von Parametern beim
  1804. Erzeugen einer Instanz des Pdo_Sqlite Adapters angegeben werden.
  1805. </para>
  1806. </listitem>
  1807. <listitem>
  1808. <para>
  1809. Ältere Versionen des SQLite Treibers in PHP scheinen die PRAGMA Kommandos
  1810. nicht zu unterstützen, die benötigt werden um sicherzustellen, dass kurze
  1811. Spaltennamen in Ergebnissätzen verwendet werden. Wenn in den Ergebnissätzen
  1812. Schlüssel der Art "tabellenname.spaltenname" bei Nutzung von JOIN Abfragen
  1813. auftreten, sollte die aktuellste PHP Version installiert werden.
  1814. </para>
  1815. </listitem>
  1816. </itemizedlist>
  1817. </sect3>
  1818. <sect3 id="zend.db.adapter.adapter-notes.firebird">
  1819. <title>Firebird/Interbase</title>
  1820. <itemizedlist>
  1821. <listitem>
  1822. <para>
  1823. Dieser Adapter verwendet die PHP Erweiterung php_interbase.
  1824. </para>
  1825. </listitem>
  1826. <listitem>
  1827. <para>
  1828. Firebird/interbase unterstützt keine auto-increment Schlüssel, deswegen
  1829. sollte der Name einer Sequenz bei <methodname>lastInsertId()</methodname>
  1830. oder <methodname>lastSequenceId()</methodname> spezifiziert werden.
  1831. </para>
  1832. </listitem>
  1833. <listitem>
  1834. <para>
  1835. Aktuell wird die <classname>Zend_Db::CASE_FOLDING</classname> Option vom
  1836. Firebird/interbase Adapter nicht unterstützt. Nicht gequotete Identifizierer
  1837. werden automatisch in Großschreibweise zurückgegeben.
  1838. </para>
  1839. </listitem>
  1840. <listitem>
  1841. <para>Der Name des Adapters ist ZendX_Db_Adapter_Firebird.</para>
  1842. <para>
  1843. Beachte das der Parameter adapterNamespace mit dem Wert ZendX_Db_Adapter
  1844. zu verwenden ist.
  1845. </para>
  1846. <para>
  1847. Wir empfehlen die gds32.dll (oder Ihr Linux Äquivalent) welche mit PHP
  1848. ausgeliefert wird, auf die gleiche Version wie am Server hochzurüsten.
  1849. Für Firebird ist das Äquivalent zu gds32.dll die fbclient.dll.
  1850. </para>
  1851. <para>
  1852. Standardmäßig werden alle Identifikatoren (Tabellennamen, Felder) in
  1853. Großschreibweise zurückgegeben.
  1854. </para>
  1855. </listitem>
  1856. </itemizedlist>
  1857. </sect3>
  1858. </sect2>
  1859. </sect1>
  1860. <!--
  1861. vim:se ts=4 sw=4 et:
  1862. -->