Zend_Db_Adapter.xml 92 KB

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