Zend_Db_Adapter.xml 99 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21358 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.adapter">
  5. <title>Zend_Db_Adapter</title>
  6. <para>
  7. <classname>Zend_Db</classname> et ses autres sous classes proposent une interface de
  8. connexion aux bases de données avec Zend Framework. <classname>Zend_Db_Adapter</classname>
  9. est la classe de base que vous utilisez pour vous connecter aux bases de données (SGBDs). Il
  10. y a différentes classes d'adaptateur par SGBD.
  11. </para>
  12. <para>
  13. Les classes <code>Adapters</code> de <classname>Zend_Db</classname> créent un pont
  14. entre les extensions <acronym>PHP</acronym> et une interface commune. Ceci vous aide à écrire des applications
  15. déployables avec de multiples SGBDs, demandant peu d'efforts.
  16. </para>
  17. <para>
  18. L'interface de la classe d'adaptateur est semblable à celle de l'extension <ulink
  19. url="http://www.php.net/pdo">PHP Data Objects</ulink>. <classname>Zend_Db</classname>
  20. propose des classes d'adaptateurs vers les drivers <acronym>PDO</acronym> pour les SGBDs suivants&#160;:
  21. </para>
  22. <itemizedlist>
  23. <listitem>
  24. <para>
  25. IBM DB2 et Informix Dynamic Server (IDS), en utilisant l'extension <acronym>PHP</acronym> <ulink
  26. url="http://www.php.net/pdo-ibm">pdo_ibm</ulink>.
  27. </para>
  28. </listitem>
  29. <listitem>
  30. <para>
  31. MySQL, utilisant l'extension <acronym>PHP</acronym> <ulink
  32. url="http://www.php.net/pdo-mysql">pdo_mysql</ulink>.
  33. </para>
  34. </listitem>
  35. <listitem>
  36. <para>
  37. Microsoft <acronym>SQL</acronym> Server, utilisant l'extension <acronym>PHP</acronym> <ulink
  38. url="http://www.php.net/pdo-dblib">pdo_dblib</ulink>.
  39. </para>
  40. </listitem>
  41. <listitem>
  42. <para>
  43. Oracle, utilisant l'extension <acronym>PHP</acronym> <ulink
  44. url="http://www.php.net/pdo-oci">pdo_oci</ulink>.
  45. </para>
  46. </listitem>
  47. <listitem>
  48. <para>
  49. PostgreSQL, grâce à l'extension <acronym>PHP</acronym> <ulink
  50. url="http://www.php.net/pdo-pgsql">pdo_pgsql</ulink>.
  51. </para>
  52. </listitem>
  53. <listitem>
  54. <para>
  55. SQLite, avec l'extension <acronym>PHP</acronym> <ulink
  56. url="http://www.php.net/pdo-sqlite">pdo_sqlite</ulink>.
  57. </para>
  58. </listitem>
  59. </itemizedlist>
  60. <para>
  61. De plus, <classname>Zend_Db</classname> fournit aussi des classes se connectant avec
  62. les extensions <acronym>PHP</acronym> propres aux SGBDs (hors <acronym>PDO</acronym> donc), pour les SGBDs suivants&#160;:
  63. </para>
  64. <itemizedlist>
  65. <listitem>
  66. <para>
  67. MySQL, utilisant l'extension <acronym>PHP</acronym> <ulink
  68. url="http://www.php.net/mysqli">mysqli</ulink>.
  69. </para>
  70. </listitem>
  71. <listitem>
  72. <para>
  73. Oracle, utilisant l'extension <acronym>PHP</acronym> <ulink
  74. url="http://www.php.net/oci8">oci8</ulink>.
  75. </para>
  76. </listitem>
  77. <listitem>
  78. <para>
  79. IBM DB2, utilisant l'extension <acronym>PHP</acronym> <ulink
  80. url="http://www.php.net/ibm_db2">ibm_db2</ulink>.
  81. </para>
  82. </listitem>
  83. <listitem>
  84. <para>
  85. Firebird (Interbase), utilisant l'extension <acronym>PHP</acronym> <ulink
  86. url="http://www.php.net/ibase">php_interbase</ulink>
  87. </para>
  88. </listitem>
  89. </itemizedlist>
  90. <note>
  91. <para>
  92. Chaque <classname>Zend_Db_Adapter</classname> utilise une extension <acronym>PHP</acronym>. Vous
  93. devez donc les avoir activées pour utiliser les classes en question. Par exemple, si
  94. vous voulez utiliser une classe <classname>Zend_Db_Adapter</classname> basée sur <acronym>PDO</acronym>,
  95. vous devrez alors avoir l'extension <acronym>PDO</acronym> d'installée, ainsi que l'extension représentant
  96. le driver spécifique à votre SGBD.
  97. </para>
  98. </note>
  99. <sect2 id="zend.db.adapter.connecting">
  100. <title>Se connecter à un SGBD en utilisant un adaptateur</title>
  101. <para>
  102. Cette section décrit comment créer une instance d'un adaptateur
  103. <classname>Zend_Db</classname> de base de données.
  104. </para>
  105. <sect3 id="zend.db.adapter.connecting.constructor">
  106. <title>Utilisation du constructeur du Zend_Db Adapter</title>
  107. <para>
  108. Vous pouvez créer une instance d'un adaptateur en utilisant son constructeur.
  109. Celui-ci accepte un paramètre représentant un tableau d'options.
  110. </para>
  111. <example id="zend.db.adapter.connecting.constructor.example">
  112. <title>Utiliser le constructeur de l'adaptateur</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>Utiliser la fabrique (Factory) de Zend_Db</title>
  125. <para>
  126. Alternativement, il est possible d'utiliser la méthode statique
  127. <methodname>Zend_Db::factory()</methodname>. Celle-ci charge dynamiquement la classe
  128. d'adaptateur correspondant en utilisant <link
  129. linkend="zend.loader.load.class">Zend_Loader::loadClass()</link>.
  130. </para>
  131. <para>
  132. Le premier argument est une chaîne désignant l'adaptateur souhaité. Par
  133. exemple, "<classname>Pdo_Mysql</classname>" va correspondre à la classe
  134. <classname>Zend_Db_Adapter_Pdo_Mysql</classname>. Le second paramètre est un tableau
  135. d'options. C'est le même que celui que vous auriez passé au constructeur de la
  136. classe directement.
  137. </para>
  138. <example id="zend.db.adapter.connecting.factory.example">
  139. <title>Utilisation de la méthode statique de fabrique de Zend_Db</title>
  140. <programlisting language="php"><![CDATA[
  141. // Nous n'avons pas besoin de la ligne suivante car Zend_Db_Adapter_Pdo_Mysql
  142. // sera automatiquement chargé par la fabrique Zend_Db.
  143. // require_once 'Zend/Db/Adapter/Pdo/Mysql.php';
  144. // Charge automatiquement la classe Zend_Db_Adapter_Pdo_Mysql
  145. // et en créer une instance.
  146. $db = Zend_Db::factory('Pdo_Mysql', array(
  147. 'host' => '127.0.0.1',
  148. 'username' => 'webuser',
  149. 'password' => 'xxxxxxxx',
  150. 'dbname' => 'test'
  151. ));
  152. ]]></programlisting>
  153. </example>
  154. <para>
  155. Si vous créez votre propre classe d'adaptateur qui étend
  156. <classname>Zend_Db_Adapter_Abstract</classname> et que celle-ci ne respecte pas la
  157. syntaxe du préfixe package "<classname>Zend_Db_Adapter</classname>", utilisez alors
  158. la clé "<code>adapterNamespace</code>" dans le tableau de configuration passé à la
  159. méthode <methodname>factory()</methodname> afin de charger votre adaptateur.
  160. </para>
  161. <example id="zend.db.adapter.connecting.factory.example2">
  162. <title>Utilisation de la fabrique avec une classe personnalisée</title>
  163. <programlisting language="php"><![CDATA[
  164. // Charge automatiquement la classe MyProject_Db_Adapter_Pdo_Mysql
  165. // et l'instantie.
  166. $db = Zend_Db::factory('Pdo_Mysql', array(
  167. 'host' => '127.0.0.1',
  168. 'username' => 'webuser',
  169. 'password' => 'xxxxxxxx',
  170. 'dbname' => 'test',
  171. 'adapterNamespace' => 'MyProject_Db_Adapter'
  172. ));
  173. ]]></programlisting>
  174. </example>
  175. </sect3>
  176. <sect3 id="zend.db.adapter.connecting.factory-config">
  177. <title>Utiliser Zend_Config avec la fabrique Zend_Db</title>
  178. <para>
  179. Optionnellement, vous pouvez passer un objet de type <link
  180. linkend="zend.config">Zend_Config</link> en tant qu'argument de la méthode
  181. <methodname>factory()</methodname>, concernant la configuration.
  182. </para>
  183. <para>
  184. Il est alors nécessaire que l'objet de configuration contienne une propriété
  185. <code>adapter</code>, qui représente une chaîne de caractères décrivant l'adaptateur
  186. à utiliser. De plus, l'objet peut aussi contenir une propriété nommée
  187. <code>params</code>, avec toutes les sous propriétés requises pour la configuration
  188. de l'adaptateur.
  189. </para>
  190. <example id="zend.db.adapter.connecting.factory.example1">
  191. <title>Utilisation de la fabrique avec un objet de type Zend_Config</title>
  192. <para>
  193. Dans l'exemple qui va suivre, l'objet <classname>Zend_Config</classname>
  194. est crée à partir d'un tableau. Il eut été possible de le créer à partir de
  195. fichiers externes, grâce à <link
  196. linkend="zend.config.adapters.ini">Zend_Config_Ini</link> ou <link
  197. linkend="zend.config.adapters.xml">Zend_Config_Xml</link>.
  198. </para>
  199. <programlisting language="php"><![CDATA[
  200. $config = new Zend_Config(
  201. array(
  202. 'database' => array(
  203. 'adapter' => 'Mysqli',
  204. 'params' => array(
  205. 'host' => '127.0.0.1',
  206. 'dbname' => 'test',
  207. 'username' => 'webuser',
  208. 'password' => 'secret',
  209. )
  210. )
  211. )
  212. );
  213. $db = Zend_Db::factory($config->database);
  214. ]]></programlisting>
  215. </example>
  216. <para>
  217. Le second paramètre de la méthode <methodname>factory()</methodname> doit être un tableau
  218. associatif décrivant les paramètres de l'adaptateur à utiliser. Cet argument est
  219. optionnel, si un objet de type <classname>Zend_Config</classname> est utilisé en
  220. premier paramètre, alors il est supposé contenir les paramètres, et le second
  221. paramètre de <methodname>factory()</methodname> est alors ignoré.
  222. </para>
  223. </sect3>
  224. <sect3 id="zend.db.adapter.connecting.parameters">
  225. <title>Paramètres de l'adaptateur (Adapter)</title>
  226. <para>
  227. La liste ci dessous explique les différents paramètres acceptés par les
  228. classes d'adaptateur <classname>Zend_Db</classname>.
  229. </para>
  230. <itemizedlist>
  231. <listitem>
  232. <para>
  233. <emphasis>host</emphasis>&#160;: le nom de l'hôte hébergeant le SGBD. Vous
  234. pouvez aussi spécifier une adresse IP. Si le SGBD se situe sur la même
  235. machine que l'application <acronym>PHP</acronym>, "localhost" ou "127.0.0.1" devraient alors
  236. être utilisés.
  237. </para>
  238. </listitem>
  239. <listitem>
  240. <para>
  241. <emphasis>username </emphasis>&#160;: nom d'utilisateur du compte de
  242. connexion au SGBD.
  243. </para>
  244. </listitem>
  245. <listitem>
  246. <para>
  247. <emphasis>password</emphasis>&#160;: mot de passe de l'utilisateur du
  248. compte de connexion au SGBD.
  249. </para>
  250. </listitem>
  251. <listitem>
  252. <para>
  253. <emphasis>dbname</emphasis>&#160;: nom de la base de données située dans le
  254. SGBD.
  255. </para>
  256. </listitem>
  257. <listitem>
  258. <para>
  259. <emphasis>port</emphasis>&#160;: Certains SGBDs acceptent que l'on spécifie
  260. un port pour d'y connecter. Indiquez le alors ici.
  261. </para>
  262. </listitem>
  263. <listitem>
  264. <para>
  265. <emphasis>charset</emphasis>&#160;: encodage utilisé pour la connexion.
  266. </para>
  267. </listitem>
  268. <listitem>
  269. <para>
  270. <emphasis>options</emphasis>&#160;: Ce paramètre est un tableau associatif
  271. d'options génériques à toutes les classes
  272. <classname>Zend_Db_Adapter</classname>.
  273. </para>
  274. </listitem>
  275. <listitem>
  276. <para>
  277. <emphasis>driver_options</emphasis>&#160;: Ce paramètre est un tableau
  278. associatif d'options spécifiques à une extension de SGBD spécifique.
  279. Typiquement, il est possible avec ce paramètre de passer des options
  280. (attributs) au driver <acronym>PDO</acronym>.
  281. </para>
  282. </listitem>
  283. <listitem>
  284. <para>
  285. <emphasis>adapterNamespace</emphasis>&#160;: fournit le commencement du nom
  286. de la classe d'adaptateur, à utiliser la place de
  287. "<classname>Zend_Db_Adapter</classname>". Utilisez ceci si vous désirez que
  288. <methodname>factory()</methodname> charge une classe non Zend.
  289. </para>
  290. </listitem>
  291. </itemizedlist>
  292. <example id="zend.db.adapter.connecting.parameters.example1">
  293. <title>Passer l'option de gestion de la casse à la fabrique</title>
  294. <para>
  295. Vous pouvez spécifier cette option avec la constante
  296. <classname>Zend_Db::CASE_FOLDING</classname>. Ceci correspond à l'attribut
  297. <constant>ATTR_CASE</constant> dans les drivers <acronym>PDO</acronym> et IBM DB2, ce qui ajuste la casse
  298. des clés dans les jeux de résultats. Les valeurs possibles possibles sont
  299. <classname>Zend_Db::CASE_NATURAL</classname> (défaut),
  300. <classname>Zend_Db::CASE_UPPER</classname>, et
  301. <classname>Zend_Db::CASE_LOWER</classname>.
  302. </para>
  303. <programlisting language="php"><![CDATA[
  304. $options = array(
  305. Zend_Db::CASE_FOLDING => Zend_Db::CASE_UPPER
  306. );
  307. $params = array(
  308. 'host' => '127.0.0.1',
  309. 'username' => 'webuser',
  310. 'password' => 'xxxxxxxx',
  311. 'dbname' => 'test',
  312. 'options' => $options
  313. );
  314. $db = Zend_Db::factory('Db2', $params);
  315. ]]></programlisting>
  316. </example>
  317. <example id="zend.db.adapter.connecting.parameters.example2">
  318. <title>Passer l'option d'auto-échappement à la fabrique</title>
  319. <para>
  320. Vous pouvez spécifier cette option avec le paramètre
  321. <classname>Zend_Db::AUTO_QUOTE_IDENTIFIERS</classname>. Si la valeur passée est
  322. <constant>TRUE</constant> (par défaut), alors les identifiants tels que les noms de
  323. tables, de colonnes, ou encore les alias <acronym>SQL</acronym>, sont échappés (délimités) dans la
  324. syntaxe de la requête <acronym>SQL</acronym> générée par l'objet d'adaptateur. Ceci rend
  325. l'utilisation de mots <acronym>SQL</acronym> contenant des identifiant spéciaux plus simple. Dans
  326. le cas de <constant>FALSE</constant>, vous devrez vous-même délimiter ces identifiant
  327. avec la méthode <methodname>quoteIdentifier()</methodname>.
  328. </para>
  329. <programlisting language="php"><![CDATA[
  330. $options = array(
  331. Zend_Db::AUTO_QUOTE_IDENTIFIERS => false
  332. );
  333. $params = array(
  334. 'host' => '127.0.0.1',
  335. 'username' => 'webuser',
  336. 'password' => 'xxxxxxxx',
  337. 'dbname' => 'test',
  338. 'options' => $options
  339. );
  340. $db = Zend_Db::factory('Pdo_Mysql', $params);
  341. ]]></programlisting>
  342. </example>
  343. <example id="zend.db.adapter.connecting.parameters.example3">
  344. <title>Passer des options de driver PDO à la fabrique</title>
  345. <programlisting language="php"><![CDATA[
  346. $pdoParams = array(
  347. PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true
  348. );
  349. $params = array(
  350. 'host' => '127.0.0.1',
  351. 'username' => 'webuser',
  352. 'password' => 'xxxxxxxx',
  353. 'dbname' => 'test',
  354. 'driver_options' => $pdoParams
  355. );
  356. $db = Zend_Db::factory('Pdo_Mysql', $params);
  357. echo $db->getConnection()
  358. ->getAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY);
  359. ]]></programlisting>
  360. </example>
  361. <example id="zend.db.adapter.connecting.parameters.example4">
  362. <title>Passer des options de sérialisation à la fabrique</title>
  363. <programlisting language="php"><![CDATA[
  364. $options = array(
  365. Zend_Db::ALLOW_SERIALIZATION => false
  366. );
  367. $params = array(
  368. 'host' => '127.0.0.1',
  369. 'username' => 'webuser',
  370. 'password' => 'xxxxxxxx',
  371. 'dbname' => 'test',
  372. 'options' => $options
  373. );
  374. $db = Zend_Db::factory('Pdo_Mysql', $params);
  375. ]]></programlisting>
  376. </example>
  377. </sect3>
  378. <sect3 id="zend.db.adapter.connecting.getconnection">
  379. <title>Gestion des connexions dites paresseuses</title>
  380. <para>
  381. La création d'une instance d'une classe d'adaptateur ne crée pas physiquement
  382. une connexion au SGBD. L'adaptateur sauvegarde les paramètres et se connectera
  383. physiquement à la demande, la première fois que vous aurez besoin d'exécuter une
  384. requête. Ceci permet d'assurer que la création de l'instance elle-même est rapide,
  385. et ne coûte rien en performances. Vous pouvez donc créer une instance de
  386. l'adaptateur, même si vous ne savez pas si vous allez l'utiliser. Ainsi, si vos
  387. paramètres sont incorrects, il faudra attendre la tentative de connexion au SGBD
  388. pour le vérifier réellement.
  389. </para>
  390. <para>
  391. Si vous voulez forcer l'adaptateur à se connecter au SGBD, utilisez sa méthode
  392. <methodname>getConnection()</methodname>. Elle retournera alors un objet représentant la
  393. connexion, en fonction de l'extension <acronym>PHP</acronym> utilisée, ou une exception si la connexion
  394. n'a pas été réalisée. Par exemple, si votre adaptateur utilise <acronym>PDO</acronym>, le retour sera
  395. un objet <acronym>PDO</acronym>. La connexion physique au SGBD est alors réalisée.
  396. </para>
  397. <para>
  398. Afin de vérifier si les paramètres de connexion au SGBD sont corrects,
  399. surveillez les exceptions envoyées par la méthode
  400. <methodname>getConnection()</methodname>.
  401. </para>
  402. <para>
  403. De plus, un adaptateur peut être sérialisé pour être stocké, par exemple, dans
  404. une variable de session. Ceci peut être utile non seulement pour l'adaptateur
  405. lui-même, mais aussi pour les autres objets qui l'agrègent, comme un objet
  406. <classname>Zend_Db_Select</classname>. Par défaut, les adaptateurs sont autorisés à
  407. être sérialisés, si vous ne le voulez pas, vous devez passer l'option
  408. <classname>Zend_Db::ALLOW_SERIALIZATION=false</classname>, regardez l'exemple
  409. ci-dessus. Afin de respecter le principe de connexions paresseuses, l'adaptateur ne
  410. se reconnectera pas après la désérialisation. Vous devez appeler vous-même
  411. <methodname>getConnection()</methodname>. Vous pouvez permettre à l'adaptateur de se reconnecter
  412. automatiquement en utilisant l'option d'adaptateur
  413. <classname>Zend_Db::AUTO_RECONNECT_ON_UNSERIALIZE=true</classname>.
  414. </para>
  415. <example id="zend.db.adapter.connecting.getconnection.example">
  416. <title>Gérer les exceptions de connexion</title>
  417. <programlisting language="php"><![CDATA[
  418. try {
  419. $db = Zend_Db::factory('Pdo_Mysql', $parameters);
  420. $db->getConnection();
  421. } catch (Zend_Db_Adapter_Exception $e) {
  422. // probablement mauvais identifiants,
  423. // ou alors le SGBD n'est pas joignable
  424. } catch (Zend_Exception $e) {
  425. // probablement que factory() n'a pas réussi à charger
  426. // la classe de l'adaptateur demandé
  427. }
  428. ]]></programlisting>
  429. </example>
  430. </sect3>
  431. </sect2>
  432. <sect2 id="zend.db.adapter.example-database">
  433. <title>La base de données d'exemple</title>
  434. <para>
  435. Dans cette documentation concernant <classname>Zend_Db</classname>, nous utilisons
  436. un exemple simple de tables pour illustrer nos exemples. Ces tables peuvent servir à
  437. stocker des informations sur la gestion des bugs dans une application. La base de
  438. données contient quatre tables&#160;:
  439. </para>
  440. <itemizedlist>
  441. <listitem>
  442. <para>
  443. <emphasis>accounts</emphasis> correspond aux informations sur les
  444. utilisateurs qui gèrent les bugs.
  445. </para>
  446. </listitem>
  447. <listitem>
  448. <para>
  449. <emphasis>products</emphasis> enregistre les produits pour lesquels des
  450. bugs vont être relevés.
  451. </para>
  452. </listitem>
  453. <listitem>
  454. <para>
  455. <emphasis>bugs</emphasis> est la table qui contient les bugs, à savoir
  456. leur état actuel, la personne ayant relevé le bug, la personne en charge de le
  457. corriger, et la personne chargée de vérifier le correctif.
  458. </para>
  459. </listitem>
  460. <listitem>
  461. <para>
  462. <emphasis>bugs_products</emphasis> enregistre les relations entre les
  463. bugs, et les produits. C'est une relation plusieurs à plusieurs car un même bug
  464. peut faire partie de plusieurs produits, et un produit peut évidemment posséder
  465. plusieurs bugs.
  466. </para>
  467. </listitem>
  468. </itemizedlist>
  469. <para>
  470. Le pseudo-code <acronym>SQL</acronym> suivant représente les tables de notre base de données
  471. d'exemple. Ces tables sont utilisées aussi pour les tests unitaires automatisés de
  472. <classname>Zend_Db</classname>.
  473. </para>
  474. <programlisting language="sql"><![CDATA[
  475. CREATE TABLE accounts (
  476. account_name VARCHAR(100) NOT NULL PRIMARY KEY
  477. );
  478. CREATE TABLE products (
  479. product_id INTEGER NOT NULL PRIMARY KEY,
  480. product_name VARCHAR(100)
  481. );
  482. CREATE TABLE bugs (
  483. bug_id INTEGER NOT NULL PRIMARY KEY,
  484. bug_description VARCHAR(100),
  485. bug_status VARCHAR(20),
  486. reported_by VARCHAR(100) REFERENCES accounts(account_name),
  487. assigned_to VARCHAR(100) REFERENCES accounts(account_name),
  488. verified_by VARCHAR(100) REFERENCES accounts(account_name)
  489. );
  490. CREATE TABLE bugs_products (
  491. bug_id INTEGER NOT NULL REFERENCES bugs,
  492. product_id INTEGER NOT NULL REFERENCES products,
  493. PRIMARY KEY (bug_id, product_id)
  494. );
  495. ]]></programlisting>
  496. <para>
  497. Notez aussi que la table <code>bugs</code> contient plusieurs référence (clés
  498. étrangères) vers la table <code>accounts</code>. Chacune de ces clés peut référencer un
  499. enregistrement différent de la table <code>accounts</code>, pour un bug donné.
  500. </para>
  501. <para>Le diagramme qui suit illustre le modèle physique des données.</para>
  502. <para>
  503. <inlinegraphic align="center"
  504. fileref="figures/zend.db.adapter.example-database.png" format="PNG" scale="100"
  505. valign="middle" width="387" />
  506. </para>
  507. </sect2>
  508. <sect2 id="zend.db.adapter.select">
  509. <title>Lecture de résultats de requête</title>
  510. <para>
  511. Cette section décrit des méthodes de la classe d'adaptateur permettant l'obtention
  512. de résultats suivants une requête SELECT.
  513. </para>
  514. <sect3 id="zend.db.adapter.select.fetchall">
  515. <title>Récupérer tous les résultats</title>
  516. <para>
  517. Vous pouvez à la fois exécuter une requête SELECT et récupérer tous ses
  518. résultats en une seule manipulation, grâce à la méthode
  519. <methodname>fetchAll()</methodname>.
  520. </para>
  521. <para>
  522. Le premier paramètre de cette méthode est une chaîne représentant la requête
  523. SELECT à exécuter. Aussi, ce premier paramètre peut être un objet <link
  524. linkend="zend.db.select">Zend_Db_Select</link>, qui sera alors converti en une
  525. chaîne automatiquement.
  526. </para>
  527. <para>
  528. Le second paramètre de de <methodname>fetchAll()</methodname> est un tableau de
  529. substitutions des éventuels jokers présents dans la syntaxe <acronym>SQL</acronym>.
  530. </para>
  531. <example id="zend.db.adapter.select.fetchall.example">
  532. <title>Utiliser fetchAll()</title>
  533. <programlisting language="php"><![CDATA[
  534. $sql = 'SELECT * FROM bugs WHERE bug_id = ?';
  535. $result = $db->fetchAll($sql, 2);
  536. ]]></programlisting>
  537. </example>
  538. </sect3>
  539. <sect3 id="zend.db.adapter.select.fetch-mode">
  540. <title>Changer le mode de récupération (Fetch Mode)</title>
  541. <para>
  542. Par défaut, <methodname>fetchAll()</methodname> retourne un tableau d'enregistrements.
  543. Chaque enregistrement étant un tableau associatif dont les clés sont les noms des
  544. colonnes <acronym>SQL</acronym> désirées, ou leurs alias.
  545. </para>
  546. <para>
  547. Vous pouvez spécifier un mode de récupération de résultats différent, ceci par
  548. la méthode <methodname>setFetchMode()</methodname>. Les modes supportés sont identifiés par des
  549. constantes&#160;:
  550. </para>
  551. <itemizedlist>
  552. <listitem>
  553. <para>
  554. <emphasis>Zend_Db::FETCH_ASSOC</emphasis>&#160;: Retourne un tableau
  555. d'enregistrements. Chaque enregistrement étant un tableau associatif dont
  556. les clés sont les noms des colonnes <acronym>SQL</acronym> désirées, ou leurs alias. Il s'agit
  557. du mode par défaut utilisé par les classes Zend_Db_Adapter.
  558. </para>
  559. <para>
  560. Notez que si votre résultat comporte plusieurs colonnes avec le même
  561. nom, par exemple lors d'une jointure, il ne peut y avoir qu'un clé avec un
  562. nom définit dans le tableau de résultat. Vous devriez toujours utiliser des
  563. alias avec le mode FETCH_ASSOC.
  564. </para>
  565. <para>
  566. Les noms des clés des tableaux correspondants aux noms des colonnes
  567. <acronym>SQL</acronym> telles que retournées par le SGBD, vous pouvez spécifier la casse pour
  568. ces noms, grâce à l'option <classname>Zend_Db::CASE_FOLDING</classname>.
  569. Spécifiez ceci lors de l'instanciation de votre adaptateur. Voyez <xref
  570. linkend="zend.db.adapter.connecting.parameters.example1" />.
  571. </para>
  572. </listitem>
  573. <listitem>
  574. <para>
  575. <emphasis>Zend_Db::FETCH_NUM</emphasis>&#160;: Retourne les enregistrements
  576. dans un tableau de tableaux. Les tableaux nichés sont indexés par des
  577. entiers correspondants à la position du champ dans la syntaxe <acronym>SQL</acronym>
  578. SELECT.
  579. </para>
  580. </listitem>
  581. <listitem>
  582. <para>
  583. <emphasis>Zend_Db::FETCH_BOTH</emphasis>&#160;: Retourne les enregistrements
  584. dans un tableau de tableaux. Les tableaux nichés sont indexés à la fois
  585. numériquement et lexicalement. C'est un mode qui réunit FETCH_ASSOC et
  586. FETCH_NUM. Ainsi, vous avez deux fois plus d'enregistrements, chacun d'entre
  587. eux étant doublé.
  588. </para>
  589. </listitem>
  590. <listitem>
  591. <para>
  592. <emphasis>Zend_Db::FETCH_COLUMN</emphasis>: Retourne les
  593. enregistrements dans un tableau de valeurs. Les valeurs correspondent à une
  594. des colonnes utilisées dans la requête <acronym>SQL</acronym> SELECT. Par défaut, il s'agit de
  595. la colonne à l'index 0.
  596. </para>
  597. </listitem>
  598. <listitem>
  599. <para>
  600. <emphasis>Zend_Db::FETCH_OBJ</emphasis>&#160;: Retourne les enregistrements
  601. dans un tableau d'objets. La classe de ces objets par défaut est la classe
  602. intégrée à <acronym>PHP</acronym> : <code>stdClass</code>. Les colonnes des enregistrements
  603. sont représentées par les propriétés publiques des objets.
  604. </para>
  605. </listitem>
  606. </itemizedlist>
  607. <example id="zend.db.adapter.select.fetch-mode.example">
  608. <title>Utiliser setFetchMode()</title>
  609. <programlisting language="php"><![CDATA[
  610. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  611. $result = $db->fetchAll('SELECT * FROM bugs WHERE bug_id = ?', 2);
  612. // $result est un tableau d'objets
  613. echo $result[0]->bug_description;
  614. ]]></programlisting>
  615. </example>
  616. </sect3>
  617. <sect3 id="zend.db.adapter.select.fetchassoc">
  618. <title>Récupérer un enregistrement comme tableau associatif</title>
  619. <para>
  620. La méthode <methodname>fetchAssoc()</methodname> retourne des enregistrements sous
  621. forme de tableau de tableaux associatifs, quelque soit la valeur de "fetch mode"
  622. en utilisant la première colonne comme index.
  623. </para>
  624. <example id="zend.db.adapter.select.fetchassoc.example">
  625. <title>Utiliser f<methodname>etchAssoc()</methodname></title>
  626. <programlisting language="php"><![CDATA[
  627. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  628. $result = $db->fetchAssoc('SELECT bug_id, bug_description, bug_status FROM bugs');
  629. // $result est un tableau de tableaux associatifs
  630. echo $result[2]['bug_description']; // Description du bug #2
  631. echo $result[1]['bug_description']; // Description du bug #1
  632. ]]></programlisting>
  633. </example>
  634. </sect3>
  635. <sect3 id="zend.db.adapter.select.fetchcol">
  636. <title>Récupérer une seule colonne d'un enregistrement</title>
  637. <para>
  638. La méthode <methodname>fetchCol()</methodname> retourne les enregistrements dans un
  639. tableau de valeurs. Les valeurs correspondent à une des colonnes utilisées dans la
  640. requête <acronym>SQL</acronym> SELECT, par défaut : la première. Toute autre colonne sera ignorée. Si
  641. vous avez besoin de retourner une autre colonne, voyez <xref
  642. linkend="zend.db.statement.fetching.fetchcolumn" />. Cette méthode est indépendante
  643. de la valeur de "fetch mode".
  644. </para>
  645. <example id="zend.db.adapter.select.fetchcol.example">
  646. <title>Utiliser fetchCol()</title>
  647. <programlisting language="php"><![CDATA[
  648. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  649. $sql = 'SELECT bug_description, bug_id FROM bugs WHERE bug_id = ?';
  650. $result = $db->fetchCol($sql, 2);
  651. // Contient bug_description ; bug_id n'est pas retourné
  652. echo $result[0];
  653. ]]></programlisting>
  654. </example>
  655. </sect3>
  656. <sect3 id="zend.db.adapter.select.fetchpairs">
  657. <title>Récupérer des paires Clé-Valeur d'enregistrements</title>
  658. <para>
  659. La méthode <methodname>fetchPairs()</methodname> retourne un tableau de paires
  660. clés/valeurs. La clé est le résultat de la première colonne sélectionnée dans la
  661. requête, la valeur est le résultat de la deuxième colonne sélectionnée dans la
  662. requête. Il est donc inutile de sélectionner plus de deux colonnes avec cette
  663. méthode. De même, vous devez sélectionner exactement deux colonnes avec cette
  664. méthode, pas moins. Si des clés ont des doublons, alors ils seront écrasés.
  665. </para>
  666. <para>
  667. Vous devriez réfléchir votre requête SELECT de manière à ce que la première
  668. colonne sélectionnée, correspondant à la clé du tableau de résultat, soit unique
  669. (une clé primaire par exemple). Cette méthode est indépendante de "fetch mode"
  670. éventuellement précédemment défini.
  671. </para>
  672. <example id="zend.db.adapter.select.fetchpairs.example">
  673. <title>Utilisation de fetchPairs()</title>
  674. <programlisting language="php"><![CDATA[
  675. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  676. $result = $db->fetchPairs('SELECT bug_id, bug_status FROM bugs');
  677. echo $result[2]; // le bug_status correspondant au bug_id numéro 2
  678. ]]></programlisting>
  679. </example>
  680. </sect3>
  681. <sect3 id="zend.db.adapter.select.fetchrow">
  682. <title>Récupérer un seul enregistrement complet</title>
  683. <para>
  684. La méthode <methodname>fetchRow()</methodname> retourne un et un seul enregistrement (le
  685. premier si plusieurs correspondent), en fonction de "fetch mode" que vous aurez
  686. précédemment défini. Cette méthode ressemble donc à <methodname>fetchAll()</methodname> si ce
  687. n'est qu'elle ne retournera jamais plus d'un seul enregistrement. Arrangez vous donc
  688. pour que votre SELECT possède une clause WHERE sur une clé primaire.
  689. </para>
  690. <example id="zend.db.adapter.select.fetchrow.example">
  691. <title>Utiliser fetchRow()</title>
  692. <programlisting language="php"><![CDATA[
  693. $db->setFetchMode(Zend_Db::FETCH_OBJ);
  694. $result = $db->fetchRow('SELECT * FROM bugs WHERE bug_id = 2');
  695. // Ce résultat sera un objet, car le fetch mode en a décidé ainsi
  696. echo $result->bug_description;
  697. ]]></programlisting>
  698. </example>
  699. </sect3>
  700. <sect3 id="zend.db.adapter.select.fetchone">
  701. <title>Récupérer une colonne d'un enregistrement</title>
  702. <para>
  703. La méthode <methodname>fetchOne()</methodname> est une combinaison des méthodes
  704. <methodname>fetchRow()</methodname> et <methodname>fetchCol()</methodname>, ainsi elle ne retourne que la
  705. première colonne, du premier enregistrement retourné. La valeur de retour est donc
  706. une chaîne de caractères. Toute requête retournant plusieurs colonnes et/ou
  707. plusieurs résultats est donc inutile avec cette méthode.
  708. </para>
  709. <example id="zend.db.adapter.select.fetchone.example">
  710. <title>Utiliser fetchOne()</title>
  711. <programlisting language="php"><![CDATA[
  712. $result = $db->fetchOne('SELECT bug_status FROM bugs WHERE bug_id = 2');
  713. // ceci est une chaine
  714. echo $result;
  715. ]]></programlisting>
  716. </example>
  717. </sect3>
  718. </sect2>
  719. <sect2 id="zend.db.adapter.write">
  720. <title>Effectuer des changements dans la base de données</title>
  721. <para>
  722. Il est bien entendu possible d'utiliser la classe d'adaptateur pour effectuer des
  723. changements dans vos données. Cette section décrit les manières de procéder.
  724. </para>
  725. <sect3 id="zend.db.adapter.write.insert">
  726. <title>Insérer des données</title>
  727. <para>
  728. Vous pouvez ajouter de nouveaux enregistrements dans une table, grâce à la
  729. méthode <methodname>insert()</methodname>. Son premier paramètre est une chaîne qui représente
  730. le nom de la table ciblée, le second paramètre est un tableau associatif liant les
  731. noms des colonnes de la table, aux valeurs souhaitées.
  732. </para>
  733. <example id="zend.db.adapter.write.insert.example">
  734. <title>Insertion dans une table</title>
  735. <programlisting language="php"><![CDATA[
  736. $data = array(
  737. 'created_on' => '2007-03-22',
  738. 'bug_description' => 'Something wrong',
  739. 'bug_status' => 'NEW'
  740. );
  741. $db->insert('bugs', $data);
  742. ]]></programlisting>
  743. </example>
  744. <para>
  745. Les colonnes non citées dans le tableau associatif sont laissées telles
  746. quelles. Ainsi, si le SGBD possède une valeur DEFAULT pour les colonnes concernées,
  747. celle-ci sera utilisée, autrement, NULL sera utilisé.
  748. </para>
  749. <para>
  750. Par défaut, les valeurs insérées avec cette méthode sont automatiquement
  751. échappées. Ceci pour des raisons de sécurité, vous n'avez donc pas besoin de vous
  752. occuper de ce point là.
  753. </para>
  754. <para>
  755. Si vous avez besoin d'écrire de la syntaxe <acronym>SQL</acronym>, comme des mots réservés, des
  756. noms de fonctions <acronym>SQL</acronym>, vous voulez que ceux-ci ne soient pas échappés, et ne soient
  757. pas traités comme de vulgaires chaînes de caractères, mais plutôt comme des
  758. expressions. Pour ceci, vous devriez passer ces valeurs dans votre tableau de
  759. données, en tant qu'objets de type <classname>Zend_Db_Expr</classname> au lieu de
  760. chaînes de caractères banales.
  761. </para>
  762. <example id="zend.db.adapter.write.insert.example2">
  763. <title>Insérer des expressions dans une table</title>
  764. <programlisting language="php"><![CDATA[
  765. $data = array(
  766. 'created_on' => new Zend_Db_Expr('CURDATE()'),
  767. 'bug_description' => 'Something wrong',
  768. 'bug_status' => 'NEW'
  769. );
  770. $db->insert('bugs', $data);
  771. ]]></programlisting>
  772. </example>
  773. </sect3>
  774. <sect3 id="zend.db.adapter.write.lastinsertid">
  775. <title>Récupérer une valeur générée</title>
  776. <para>
  777. Certains SGBDs supportent les clé primaires auto-incrémentées. Une table qui
  778. utilise un tel procédé génère la valeur de la clé automatiquement lors d'une
  779. insertion (INSERT). La valeur de retour de la méthode <methodname>insert()</methodname>
  780. <emphasis>n'est pas</emphasis> le dernier ID inséré car la table peut ne pas avoir
  781. de clé auto-incrémentée. La valeur de retour est le nombres d'enregistrements
  782. affectés (théoriquement 1).
  783. </para>
  784. <para>
  785. Si votre table a été définie avec une clé auto-incrémentée, alors vous pouvez
  786. appeler la méthode <methodname>lastInsertId()</methodname> après une opération d'insertion.
  787. Cette méthode retourne la valeur auto-incrémentée, générée dans le cadre de la
  788. connexion au SGBD.
  789. </para>
  790. <example id="zend.db.adapter.write.lastinsertid.example-1">
  791. <title>Utiliser lastInsertId() pour les clés auto-incrémentées</title>
  792. <programlisting language="php"><![CDATA[
  793. $db->insert('bugs', $data);
  794. // retourne la dernière valeur générée par la clé auto-incrémentée
  795. $id = $db->lastInsertId();
  796. ]]></programlisting>
  797. </example>
  798. <para>
  799. Certains SGBD supporte un objet de séquence, qui sert à générer des valeurs
  800. uniques qui vont servir pour les clé primaires. Pour supporter ce procédé, la
  801. méthode <methodname>lastInsertId()</methodname> accepte deux paramètres optionnels (chaînes de
  802. caractères). Ces paramètres nomment la table et la colonne en supposant que vous
  803. ayez respecté la convention qui définit que la séquence est nommée en utilisant le
  804. nom de la table et des colonnes utilisées, avec le suffixe "_seq". Ces conventions
  805. sont celles de PostgreSQL pour les colonnes de type SERIAL. Par exemple, une table
  806. "bugs" avec une clé primaire "bug_id" utilisera une séquence nommée
  807. "bugs_bug_id_seq".
  808. </para>
  809. <example id="zend.db.adapter.write.lastinsertid.example-2">
  810. <title>Utiliser lastInsertId() avec une séquence</title>
  811. <programlisting language="php"><![CDATA[
  812. $db->insert('bugs', $data);
  813. // retourne la dernière valeur générée par la séquence 'bugs_bug_id_seq'.
  814. $id = $db->lastInsertId('bugs', 'bug_id');
  815. // ceci retourne la dernière valeur générée par la séquence 'bugs_seq'.
  816. $id = $db->lastInsertId('bugs');
  817. ]]></programlisting>
  818. </example>
  819. <para>
  820. Si le nom de votre objet de séquence ne suit pas ces conventions de nommage,
  821. utilisez alors <methodname>lastSequenceId()</methodname>. Cette méthode prend un paramètre qui
  822. nomme la séquence explicitement.
  823. </para>
  824. <example id="zend.db.adapter.write.lastinsertid.example-3">
  825. <title>Utilisation de lastSequenceId()</title>
  826. <programlisting language="php"><![CDATA[
  827. $db->insert('bugs', $data);
  828. // retourne la dernière valeur générée par la séquence 'bugs_id_gen'.
  829. $id = $db->lastSequenceId('bugs_id_gen');
  830. ]]></programlisting>
  831. </example>
  832. <para>
  833. Pour les SGBDs ne supportant pas les séquences, comme MySQL, Microsoft <acronym>SQL</acronym>
  834. Server, et SQLite, les arguments passés à la méthode <methodname>lastInsertId()</methodname>
  835. sont ignorés. La valeur retournée est la dernière valeur générée pour la dernière
  836. requête INSERT, quelque soit la table concernée (pour cette connexion). Aussi, pour
  837. ces SGBDs, la méthode <methodname>lastSequenceId()</methodname> retournera toujours
  838. <constant>NULL</constant>.
  839. </para>
  840. <note>
  841. <title>Pourquoi ne pas utiliser "SELECT MAX(id) FROM table"?</title>
  842. <para>
  843. Quelques fois, cette requête retourne la valeur la plus récente de clé
  844. primaire insérée dans la table en question. Cependant, cette technique n'est pas
  845. pertinente dans un environnement où beaucoup de clients insèrent beaucoup de
  846. données dans une même table. Il est donc possible qu'un client insère une donnée
  847. entre le moment où la dernière insertion est effectuée, et l'appel de MAX(id),
  848. aboutissant ainsi à un résultat erroné. Il est très difficile de se rendre
  849. compte d'un tel comportement.
  850. </para>
  851. <para>
  852. Utiliser un mode d'isolation transactionnelle très élevé, comme
  853. "repeatable read" peut mitiger plus ou moins les risques, mais certains SGBDs ne
  854. supportent pas ce mode de transactions.
  855. </para>
  856. <para>
  857. De plus, utiliser une requête du type "MAX(id)+1" pour générer une
  858. nouvelle valeur de clé primaire n'est pas sécurisé non plus, car deux client
  859. peuvent se connecter simultanément et créer des effets indésirables.
  860. </para>
  861. <para>
  862. Tous les SGBDs fournissent un mécanisme de génération de valeurs uniques,
  863. et une méthode pour les récupérer. Ces mécanismes travaillent en dehors du mode
  864. transactionnel, et empêchent ainsi deux clients de générer la même valeur, ou de
  865. "se marcher dessus".
  866. </para>
  867. </note>
  868. </sect3>
  869. <sect3 id="zend.db.adapter.write.update">
  870. <title>Mettre à jour des données</title>
  871. <para>
  872. Vous pouvez mettre à jour des données dans une table en utilisant la méthode
  873. <methodname>update()</methodname> de l'adaptateur. Cette méthode accepte trois arguments&#160;:
  874. le premier est le nom de la table, le deuxième est un tableau faisant correspondre
  875. les noms des colonnes <acronym>SQL</acronym> à leurs valeurs désirées.
  876. </para>
  877. <para>
  878. Les valeurs dans ce tableau sont traitées comme des chaînes. Voyez <xref
  879. linkend="zend.db.adapter.write.insert" /> pour plus d'informations sur la gestion
  880. des expressions <acronym>SQL</acronym> dans ce tableau.
  881. </para>
  882. <para>
  883. Le troisième argument est une chaîne contenant l'expression <acronym>SQL</acronym> utilisée comme
  884. critère pour la mise à jour des données dans la table. Les valeurs et les arguments
  885. dans ce paramètre ne sont pas échappés pour vous. Vous devez donc vous assurer de
  886. l'éventuel bon échappement des caractères. Voyez <xref
  887. linkend="zend.db.adapter.quoting" /> pour plus d'informations.
  888. </para>
  889. <para>
  890. La valeur de retour de cette méthode est le nombre d'enregistrements affectés
  891. par l'opération de mise à jour (UPDATE).
  892. </para>
  893. <example id="zend.db.adapter.write.update.example">
  894. <title>Mettre à jour des enregistrements</title>
  895. <programlisting language="php"><![CDATA[
  896. $data = array(
  897. 'updated_on' => '2007-03-23',
  898. 'bug_status' => 'FIXED'
  899. );
  900. $n = $db->update('bugs', $data, 'bug_id = 2');
  901. ]]></programlisting>
  902. </example>
  903. <para>
  904. Si vous oubliez le troisième paramètre, alors tous les enregistrements de la
  905. table sont mis à jour avec les valeurs spécifiées dans le tableau de données.
  906. </para>
  907. <para>
  908. Si vous spécifiez un tableau de chaîne en tant que troisième paramètre, alors
  909. ces chaînes sont jointes entre elles avec une opération <constant>AND</constant>.
  910. </para>
  911. <para>
  912. Si vous fournissez un tableau de tableaux en tant que troisième argument, les
  913. valeurs seront automatiquement échappées dans les clés. Elles seront ensuite
  914. jointes ensemble, séparées par des opérateurs <constant>AND</constant>.
  915. </para>
  916. <example id="zend.db.adapter.write.update.example-array">
  917. <title>Mettre à jour des enregistrements avec un tableau de données</title>
  918. <programlisting language="php"><![CDATA[
  919. $data = array(
  920. 'updated_on' => '2007-03-23',
  921. 'bug_status' => 'FIXED'
  922. );
  923. $where[] = "reported_by = 'goofy'";
  924. $where[] = "bug_status = 'OPEN'";
  925. $n = $db->update('bugs', $data, $where);
  926. // la requête SQL executée est :
  927. // UPDATE "bugs" SET "update_on" = '2007-03-23', "bug_status" = 'FIXED'
  928. // WHERE ("reported_by" = 'goofy') AND ("bug_status" = 'OPEN')
  929. ]]></programlisting>
  930. </example>
  931. <example id="zend.db.adapter.write.update.example-arrayofarrays">
  932. <title>UMettre à jour des enregistrements avec un tableau de tableaux</title>
  933. <programlisting language="php"><![CDATA[
  934. $data = array(
  935. 'updated_on' => '2007-03-23',
  936. 'bug_status' => 'FIXED'
  937. );
  938. $where['reported_by = ?'] = 'goofy';
  939. $where['bug_status = ?'] = 'OPEN';
  940. $n = $db->update('bugs', $data, $where);
  941. // la requête SQL executée est :
  942. // UPDATE "bugs" SET "update_on" = '2007-03-23', "bug_status" = 'FIXED'
  943. // WHERE ("reported_by" = 'goofy') AND ("bug_status" = 'OPEN')
  944. ]]></programlisting>
  945. </example>
  946. </sect3>
  947. <sect3 id="zend.db.adapter.write.delete">
  948. <title>Supprimer des enregistrements</title>
  949. <para>
  950. Il est possible de supprimer des enregistrements dans une table. La méthode
  951. <methodname>delete()</methodname> est faite pour cela. Elle accepte deux paramètres, le premier
  952. est une chaîne désignant la table.
  953. </para>
  954. <para>
  955. Le second paramètre est une chaîne contenant l'expression <acronym>SQL</acronym> utilisée comme
  956. critère pour effacer les enregistrements. Les valeurs de cette expression de sont
  957. pas échappées automatiquement, vous devez donc vous en occuper le cas échéant. Voyez
  958. <xref linkend="zend.db.adapter.quoting" /> pour les méthodes concernant
  959. l'échappement.
  960. </para>
  961. <para>
  962. La valeur retournée par la méthode <methodname>delete()</methodname> est le nombre
  963. d'enregistrements affectés (effacés).
  964. </para>
  965. <example id="zend.db.adapter.write.delete.example">
  966. <title>Supprimer des enregistrements</title>
  967. <programlisting language="php"><![CDATA[
  968. $n = $db->delete('bugs', 'bug_id = 3');
  969. ]]></programlisting>
  970. </example>
  971. <para>
  972. Si vous ne spécifiez pas le second paramètres, tous les enregistrements de la
  973. table seront alors supprimés.
  974. </para>
  975. <para>
  976. Si le second paramètre est un tableau de chaînes, alors celles ci seront
  977. jointe en une expression <acronym>SQL</acronym>, séparées par l'opérateur
  978. <constant>AND</constant>.
  979. </para>
  980. <para>
  981. Si vous fournissez un tableau de tableaux en tant que troisième argument, les
  982. valeurs seront automatiquement échappées dans les clés. Elles seront ensuite
  983. jointes ensemble, séparées par des opérateurs <constant>AND</constant>.
  984. </para>
  985. </sect3>
  986. </sect2>
  987. <sect2 id="zend.db.adapter.quoting">
  988. <title>Échapper des valeurs ou des identifiants</title>
  989. <para>
  990. Lorsque vous envoyez des requêtes SQL au SGBD, il est souvent nécessaire d'y
  991. inclure des paramètres dynamiques, PHP. Ceci est risqué car si un des paramètres
  992. contient certains caractères, comme l'apostrophe ('), alors la requête résultante risque
  993. d'être mal formée. Par exemple, notez le caractère indésirable dans la requête
  994. suivante&#160;:
  995. <programlisting language="php"><![CDATA[
  996. $name = "O'Reilly";
  997. $sql = "SELECT * FROM bugs WHERE reported_by = '$name'";
  998. echo $sql;
  999. // SELECT * FROM bugs WHERE reported_by = 'O'Reilly'
  1000. ]]></programlisting>
  1001. </para>
  1002. <para>
  1003. Pire encore est le cas où de telles erreurs <acronym>SQL</acronym> peuvent être utilisées
  1004. délibérément par une personne afin de manipuler la logique de votre requête. Si une
  1005. personne peut manipuler un paramètre de votre requête, par exemple via un paramètre <acronym>HTTP</acronym>
  1006. ou une autre méthode, alors il peut y avoir une fuite de données, voire même une
  1007. corruption totale de votre base de données. Cette technique très préoccupante de
  1008. violation de la sécurité d'un SGBD, est appelée "injection <acronym>SQL</acronym>" (voyez <ulink
  1009. url="http://en.wikipedia.org/wiki/SQL_Injection">http://en.wikipedia.org/wiki/SQL_Injection</ulink>).
  1010. </para>
  1011. <para>
  1012. La classe Zend_Db Adapter possède des méthodes adaptées pour vous aider à faire
  1013. face à de telles vulnérabilités. La solution proposée est l'échappement de tels
  1014. caractères (comme la "quote" = ') dans les valeurs <acronym>PHP</acronym> avant leur passage dans la chaîne
  1015. de requête. Ceci vous protège de l'insertion malveillante ou involontaires, de
  1016. caractères spéciaux dans les variables <acronym>PHP</acronym> faisant partie d'une requête <acronym>SQL</acronym>.
  1017. </para>
  1018. <sect3 id="zend.db.adapter.quoting.quote">
  1019. <title>Utilisation de quote()</title>
  1020. <para>
  1021. La méthode <methodname>quote()</methodname> accepte un seul paramètre, une chaîne de
  1022. caractère. Elle retourne une chaîne dont les caractères spéciaux ont été échappés
  1023. d'une manière convenable en fonction du SGBD sous-jacent. De plus, la chaîne
  1024. échappée est entourée d'apostrophes ("<code>'</code>").C'est la valeur standard de
  1025. délimitations des chaînes en <acronym>SQL</acronym>.
  1026. </para>
  1027. <example id="zend.db.adapter.quoting.quote.example">
  1028. <title>Utiliser quote()</title>
  1029. <programlisting language="php"><![CDATA[
  1030. $name = $db->quote("O'Reilly");
  1031. echo $name;
  1032. // 'O\'Reilly'
  1033. $sql = "SELECT * FROM bugs WHERE reported_by = $name";
  1034. echo $sql;
  1035. // SELECT * FROM bugs WHERE reported_by = 'O\'Reilly'
  1036. ]]></programlisting>
  1037. </example>
  1038. <para>
  1039. Notez que la valeur de retour contient les apostrophes de délimitation autour
  1040. de la chaîne. Ceci est différent de certaines fonctions qui se contentent juste
  1041. d'échapper les caractères spéciaux, telle que <ulink
  1042. url="http://www.php.net/mysqli_real_escape_string">mysql_real_escape_string()</ulink>.
  1043. </para>
  1044. <para>
  1045. Certaines valeurs en revanche n'ont pas besoin d'être délimitées. Certains
  1046. SGBDs n'acceptent pas que les valeurs correspondant à des champs de type entier,
  1047. soient délimitées. Autrement dit, l'exemple suivant est erroné dans certaines
  1048. implémentations de SQL. Nous supposons <code>intColumn</code> ayant un type SQL
  1049. <constant>INTEGER</constant>&#160;: <programlisting language="php"><![CDATA[
  1050. SELECT * FROM atable WHERE intColumn = '123'
  1051. ]]></programlisting></para>
  1052. <para>
  1053. Le second paramètre optionnel de <methodname>quote()</methodname> permet de spécifier un
  1054. type <acronym>SQL</acronym>.
  1055. </para>
  1056. <example id="zend.db.adapter.quoting.quote.example-2">
  1057. <title>Utiliser quote() avec un type SQL</title>
  1058. <programlisting language="php"><![CDATA[
  1059. $value = '1234';
  1060. $sql = 'SELECT * FROM atable WHERE intColumn = '
  1061. . $db->quote($value, 'INTEGER');
  1062. ]]></programlisting>
  1063. </example>
  1064. <para>
  1065. De plus, chaque classe Zend_Db_Adapter possèdent des constantes représentant
  1066. les différents type <acronym>SQL</acronym> des SGBDs respectifs qu'elles représentent. Ainsi, les
  1067. constantes <classname>Zend_Db::INT_TYPE</classname>,
  1068. <classname>Zend_Db::BIGINT_TYPE</classname>, et
  1069. <classname>Zend_Db::FLOAT_TYPE</classname> peuvent vous permettre d'écrire un code
  1070. portable entre différents SGBDs.
  1071. </para>
  1072. <para>
  1073. Zend_Db_Table fournit les types <acronym>SQL</acronym> à <methodname>quote()</methodname> automatiquement en
  1074. fonction des colonnes utilisées par la table référencée.
  1075. </para>
  1076. </sect3>
  1077. <sect3 id="zend.db.adapter.quoting.quote-into">
  1078. <title>Utilisation de quoteInto()</title>
  1079. <para>
  1080. Une autre manière est d'échapper une expression <acronym>SQL</acronym> contenant une variable
  1081. <acronym>PHP</acronym>. Vous pouvez utiliser <methodname>quoteInto()</methodname> pour cela. Cette méthode accepte
  1082. trois arguments. Le premier est la chaîne représentant l'expression <acronym>SQL</acronym> dont les
  1083. paramètres variables sont remplacés par un joker(<code>?</code>), et le second
  1084. argument est la variable <acronym>PHP</acronym> à utiliser pour le remplacement du joker.
  1085. </para>
  1086. <para>
  1087. Le joker est le même symbole que celui utilisé par beaucoup de SGBDs pour la
  1088. substitution de paramètre dans une requête préparée.<methodname>quoteInto()</methodname> ne fait
  1089. qu'émuler ce comportement&#160;: la méthode ne fait que remplacer le joker par la
  1090. valeur <acronym>PHP</acronym>, en lui appliquant la méthode <code>quote</code>. De vrais paramètres de
  1091. requêtes préparées conservent une réelle isolation entre la requête et ses
  1092. paramètres.
  1093. </para>
  1094. <example id="zend.db.adapter.quoting.quote-into.example">
  1095. <title>Utiliser quoteInto()</title>
  1096. <programlisting language="php"><![CDATA[
  1097. $sql = $db->quoteInto("SELECT * FROM bugs WHERE reported_by = ?",
  1098. "O'Reilly");
  1099. echo $sql;
  1100. // SELECT * FROM bugs WHERE reported_by = 'O\'Reilly'
  1101. ]]></programlisting>
  1102. </example>
  1103. <para>
  1104. Le troisième paramètre optionnel s'utilise comme avec la méthode
  1105. <code>quote</code>. Il sert à spécifier un type <acronym>SQL</acronym>, les types numériques ne sont
  1106. pas délimités.
  1107. </para>
  1108. <example id="zend.db.adapter.quoting.quote-into.example-2">
  1109. <title>Utiliser quoteInto() avec un type SQL</title>
  1110. <programlisting language="php"><![CDATA[
  1111. $sql = $db->quoteInto("SELECT * FROM bugs WHERE bug_id = ?",
  1112. '1234',
  1113. 'INTEGER');
  1114. echo $sql;
  1115. // SELECT * FROM bugs WHERE reported_by = 1234
  1116. ]]></programlisting>
  1117. </example>
  1118. </sect3>
  1119. <sect3 id="zend.db.adapter.quoting.quote-identifier">
  1120. <title>Utilisation de quoteIdentifier()</title>
  1121. <para>
  1122. Les valeurs ne sont pas les seuls données qui peuvent être dynamiques dans une
  1123. requête <acronym>SQL</acronym>,et donc passées par des variables <acronym>PHP</acronym>. Les noms des tables, des
  1124. colonnes, ou tout autre identifiant <acronym>SQL</acronym> spécial de la requête peuvent aussi être
  1125. dynamiques. En général, les identifiant spéciaux d'une requête ont une syntaxe
  1126. identique à celle des variables <acronym>PHP</acronym>&#160;: pas d'espaces dans les noms, certains
  1127. autres caractères interdits, la ponctuation est interdite, etc... Aussi, les
  1128. identifiants ne peuvent valoir certaines valeurs de mots réservés&#160;: une table
  1129. ne peut s'appeler "FROM". Il se peut donc que vous ayez besoin aussi d'échapper des
  1130. paramètres voués à être substitués à des identifiant dans la requête <acronym>SQL</acronym>, et non
  1131. plus à des valeurs.
  1132. </para>
  1133. <para>
  1134. Le langage <acronym>SQL</acronym> possède une caractéristique appelée <emphasis>identifiant
  1135. délimités</emphasis>. Si vous entourez un identifiant <acronym>SQL</acronym> dans un type spécial de
  1136. délimiteurs, alors vous pouvez écrire des requêtes qui auraient été invalides
  1137. autrement. Ainsi, vous pouvez inclure des espaces, de la ponctuation ou des
  1138. caractères internationaux dans vos identifiant, et aussi utiliser des mots
  1139. réservés.
  1140. </para>
  1141. <para>
  1142. La méthode <methodname>quoteIdentifier()</methodname> fonctionne comme
  1143. <methodname>quote()</methodname>, mais elle utilise un caractère de délimitation spécial, en
  1144. fonction du SGBD sous-jacent. Par exemple, le standard <acronym>SQL</acronym> spécifie des doubles
  1145. quotes (<code>"</code>) et beaucoup de SGBDs utilisent ceci. MySQL utilise les
  1146. apostrophes inverses (back-quotes) (<code>`</code>) par défaut. Les caractères
  1147. spéciaux sont aussi échappés.
  1148. </para>
  1149. <example id="zend.db.adapter.quoting.quote-identifier.example">
  1150. <title>Utiliser quoteIdentifier()</title>
  1151. <programlisting language="php"><![CDATA[
  1152. // nous possédons une table ayant un nom correspondant
  1153. // à un mot reservé en SQL
  1154. $tableName = $db->quoteIdentifier("order");
  1155. $sql = "SELECT * FROM $tableName";
  1156. echo $sql
  1157. // SELECT * FROM "order"
  1158. ]]></programlisting>
  1159. </example>
  1160. <para>
  1161. Les identifiant <acronym>SQL</acronym> délimités sont sensibles à la casse. Vous devriez toujours
  1162. utiliser la casse telle qu'elle est utilisée dans votre base de données (nom des
  1163. tables, des colonnes ...).
  1164. </para>
  1165. <para>
  1166. Dans les cas où le <acronym>SQL</acronym> est généré à l'intérieur des classes
  1167. <classname>Zend_Db</classname>, alors les identifiant <acronym>SQL</acronym> seront automatiquement
  1168. échappés. Vous pouvez changer ce comportement avec l'option
  1169. <classname>Zend_Db::AUTO_QUOTE_IDENTIFIERS</classname>.Spécifiez la lors de
  1170. l'instanciation de l'adaptateur. Voyez <xref
  1171. linkend="zend.db.adapter.connecting.parameters.example2" />.
  1172. </para>
  1173. </sect3>
  1174. </sect2>
  1175. <sect2 id="zend.db.adapter.transactions">
  1176. <title>Gérer les transactions dans une base de données</title>
  1177. <para>
  1178. Les bases de données définissent les transactions comme étant des unités logiques
  1179. de travail qui peuvent êtres validées ("commit") ou annulées ("rollback") en tant qu'une
  1180. seule opération, même sur de multiples tables. Toutes les requêtes aux bases de données
  1181. sont considérées comme faisant partie d'une transaction, même si le driver de base de
  1182. données fait ceci implicitement. Ceci s'appelle le mode
  1183. <emphasis>auto-commit</emphasis>, dans lequel le driver de base de données créer une
  1184. transaction pour chaque requête exécutée et la valide. Par défaut toutes les classes
  1185. <classname>Zend_Db_Adapter</classname> fonctionnent en mode auto-commit.
  1186. </para>
  1187. <para>
  1188. Vous pouvez manuellement spécifier lorsque vous voulez démarrer une transaction.
  1189. Vous contrôler ainsi combien de requêtes doivent y être exécutées, et valider ou annuler
  1190. ce groupe de requêtes. Utilisez <methodname>beginTransaction()</methodname> pour démarrer une
  1191. transaction. Toutes les requêtes suivantes seront alors exécutées dans cette transaction
  1192. avant que vous ne l'annuliez, ou validiez.
  1193. </para>
  1194. <para>
  1195. Pour terminer une transaction, utilisez les méthodes <methodname>commit()</methodname> ou
  1196. <methodname>rollBack()</methodname>. <methodname>commit()</methodname> validera et appliquera les changements de
  1197. la transaction au SGBD, ils deviendront alors visibles dans les autres
  1198. transactions.
  1199. </para>
  1200. <para>
  1201. <methodname>rollBack()</methodname> fait le contraire&#160;: elle annule les changements qu'ont
  1202. générés les requêtes dans la transaction. L'annulation n'a aucun effet sur les
  1203. changements qui ont été opérés par d'autres transactions parallèles.
  1204. </para>
  1205. <para>
  1206. Après qu'une transaction soit terminées, <classname>Zend_Db_Adapter</classname>
  1207. retourne en mode auto-commit jusqu'à un nouvel appel à
  1208. <methodname>beginTransaction()</methodname>.
  1209. </para>
  1210. <example id="zend.db.adapter.transactions.example">
  1211. <title>Manipuler les transactions pour assurer l'intégrité de la logique</title>
  1212. <programlisting language="php"><![CDATA[
  1213. // Démarre explicitement une transaction.
  1214. $db->beginTransaction();
  1215. try {
  1216. // Essaye d'executer une ou plusieurs requêtes :
  1217. $db->query(...);
  1218. $db->query(...);
  1219. $db->query(...);
  1220. // Si toutes ont réussi, valide les changements en une seule passe.
  1221. $db->commit();
  1222. } catch (Exception $e) {
  1223. // Si une des requête s'est mal déroulée, alors nous voulons
  1224. // annuler les changements de toutes les requêtes faisant partie
  1225. // de la transaction, même celles qui se sont bien déroulées.
  1226. // Tous les changements sont annulés d'un seul coup.
  1227. $db->rollBack();
  1228. echo $e->getMessage();
  1229. }
  1230. ]]></programlisting>
  1231. </example>
  1232. </sect2>
  1233. <sect2 id="zend.db.adapter.list-describe">
  1234. <title>Lister et décrire les tables</title>
  1235. <para>
  1236. La méthode <methodname>listTables()</methodname> retourne un tableau de chaînes décrivant les
  1237. tables de la base de données courante.
  1238. </para>
  1239. <para>
  1240. La méthode <methodname>describeTable()</methodname> retourne un tableau associatif de
  1241. métadonnées sur une table. Spécifiez en le nom en paramètre. Le second paramètre est
  1242. optionnel et définit la base de données à utiliser, comme par exemple si aucune n'a été
  1243. sélectionnée précédemment.
  1244. </para>
  1245. <para>
  1246. Les clés de ce tableau représentent les noms des colonnes, les valeurs sont un
  1247. tableau avec les clés suivantes&#160;:
  1248. </para>
  1249. <table cellpadding="5" frame="all" id="zend.db.adapter.list-describe.metadata">
  1250. <title>Champs de métadonnées retournés par describeTable()</title>
  1251. <tgroup align="left" cols="3" colsep="1" rowsep="1">
  1252. <thead>
  1253. <row>
  1254. <entry>clé</entry>
  1255. <entry>type</entry>
  1256. <entry>description</entry>
  1257. </row>
  1258. </thead>
  1259. <tbody>
  1260. <row>
  1261. <entry><constant>SCHEMA_NAME</constant></entry>
  1262. <entry>(chaîne)</entry>
  1263. <entry>Nom de la base de données dans laquelle la table existe.</entry>
  1264. </row>
  1265. <row>
  1266. <entry><constant>TABLE_NAME</constant></entry>
  1267. <entry>(chaîne)</entry>
  1268. <entry>Nom de la table dans laquelle la colonne existe.</entry>
  1269. </row>
  1270. <row>
  1271. <entry><constant>COLUMN_NAME</constant></entry>
  1272. <entry>(chaîne)</entry>
  1273. <entry>Nom de la colonne.</entry>
  1274. </row>
  1275. <row>
  1276. <entry><constant>COLUMN_POSITION</constant></entry>
  1277. <entry>(entier)</entry>
  1278. <entry>Position de la colonne dans la table.</entry>
  1279. </row>
  1280. <row>
  1281. <entry><constant>DATA_TYPE</constant></entry>
  1282. <entry>(chaîne)</entry>
  1283. <entry>Nom du type de données tel que renvoyé par le <acronym>SGBD</acronym>.</entry>
  1284. </row>
  1285. <row>
  1286. <entry><constant>DEFAULT</constant></entry>
  1287. <entry>(chaîne)</entry>
  1288. <entry>Valeur par défaut de la colonne, si une existe.</entry>
  1289. </row>
  1290. <row>
  1291. <entry><constant>NULLABLE</constant></entry>
  1292. <entry>(booléen)</entry>
  1293. <entry><constant>TRUE</constant> si la colonne accepte la valeur <acronym>SQL</acronym>
  1294. '<constant>NULL</constant>', <constant>FALSE</constant> sinon.</entry>
  1295. </row>
  1296. <row>
  1297. <entry><constant>LENGTH</constant></entry>
  1298. <entry>(entier)</entry>
  1299. <entry>Longueur ou taille de la colonne telle que reportée par le
  1300. <acronym>SGBD</acronym>.</entry>
  1301. </row>
  1302. <row>
  1303. <entry><constant>SCALE</constant></entry>
  1304. <entry>(entier)</entry>
  1305. <entry>Échelle du type <acronym>SQL</acronym> <constant>NUMERIC</constant> ou <constant>DECIMAL</constant>.</entry>
  1306. </row>
  1307. <row>
  1308. <entry><constant>PRECISION</constant></entry>
  1309. <entry>(entier)</entry>
  1310. <entry>Précision du type <acronym>SQL</acronym> <constant>NUMERIC</constant> ou <constant>DECIMAL</constant>.</entry>
  1311. </row>
  1312. <row>
  1313. <entry><constant>UNSIGNED</constant></entry>
  1314. <entry>(booléen)</entry>
  1315. <entry><constant>TRUE</constant> si le type est un entier non signé, défini par
  1316. <constant>UNSIGNED</constant>.</entry>
  1317. </row>
  1318. <row>
  1319. <entry><constant>PRIMARY</constant></entry>
  1320. <entry>(booléen)</entry>
  1321. <entry><constant>TRUE</constant> si la colonne fait partie d'une clé
  1322. primaire.</entry>
  1323. </row>
  1324. <row>
  1325. <entry><constant>PRIMARY_POSITION</constant></entry>
  1326. <entry>(entier)</entry>
  1327. <entry>Position de la colonne dans la clé primaire.</entry>
  1328. </row>
  1329. <row>
  1330. <entry><constant>IDENTITY</constant></entry>
  1331. <entry>(booléen)</entry>
  1332. <entry><constant>TRUE</constant> si la colonne utilise une valeur
  1333. auto-générée.</entry>
  1334. </row>
  1335. </tbody>
  1336. </tgroup>
  1337. </table>
  1338. <note>
  1339. <title>A quoi correspond le champs de métadonnées "IDENTITY" en fonction du SGBD
  1340. ?</title>
  1341. <para>
  1342. Le champs de métadonnées "IDENTITY" a été choisi en tant que terme idiomatique
  1343. pour représenter une relation de substitution de clés. Ce champ est généralement
  1344. connu par les valeurs suivantes&#160;:
  1345. </para>
  1346. <itemizedlist>
  1347. <listitem>
  1348. <para><constant>IDENTITY</constant> - DB2, MSSQL</para>
  1349. </listitem>
  1350. <listitem>
  1351. <para><constant>AUTO_INCREMENT</constant> - MySQL</para>
  1352. </listitem>
  1353. <listitem>
  1354. <para><constant>SERIAL</constant> - PostgreSQL</para>
  1355. </listitem>
  1356. <listitem>
  1357. <para><constant>SEQUENCE</constant> - Oracle</para>
  1358. </listitem>
  1359. </itemizedlist>
  1360. </note>
  1361. <para>
  1362. Si aucune table ne correspond à votre demande, alors <methodname>describeTable()</methodname>
  1363. retourne un tableau vide.
  1364. </para>
  1365. </sect2>
  1366. <sect2 id="zend.db.adapter.closing">
  1367. <title>Fermer une connexion</title>
  1368. <para>
  1369. Normalement, il n'est pas nécessaire de fermer explicitement sa connexion. <acronym>PHP</acronym>
  1370. nettoie automatiquement les ressources laissées ouvertes en fin de traitement. Les
  1371. extensions des SGBDs ferment alors les connexions respectives pour les ressources
  1372. détruites par <acronym>PHP</acronym>.
  1373. </para>
  1374. <para>
  1375. Cependant, il se peut que vous trouviez utile de fermer la connexion manuellement.
  1376. Vous pouvez alors utiliser la méthode de l'adaptateur <methodname>closeConnection()</methodname>
  1377. afin de fermer explicitement la connexion vers le SGBD.
  1378. </para>
  1379. <para>
  1380. A partir de la version 1.7.2, vous pouvez vérifier si vous êtes actuellement
  1381. connecté au serveur SGBD grâce à la méthode <methodname>isConnected()</methodname>. Ceci correspond
  1382. à une ressource de connexion qui a été initiée et qui n'est pas close. Cette fonction ne
  1383. permet pas actuellement de tester la fermeture de la connexion au niveau du SGBD par
  1384. exemple. Cette fonction est utilisée en interne pour fermer la connexion. Elle vous
  1385. permet entre autres de fermer plusieurs fois une connexion sans erreurs. C'était déjà le
  1386. cas avant la version 1.7.2 pour les adaptateurs de type <acronym>PDO</acronym> mais pas pour les
  1387. autres.
  1388. </para>
  1389. <example id="zend.db.adapter.closing.example">
  1390. <title>Fermer une connexion à un SGBD</title>
  1391. <programlisting language="php"><![CDATA[
  1392. $db->closeConnection();
  1393. ]]></programlisting>
  1394. </example>
  1395. <note>
  1396. <title>Zend_Db supporte-t-il les connexions persistantes&#160;?</title>
  1397. <para>
  1398. Oui, la persistance est supportée grace à l'addition de l'option
  1399. <code>persistent</code> quand il est à une valeur true dans la configuration
  1400. (pas celle du driver) d'un adaptateur de <classname>Zend_Db</classname>.
  1401. </para>
  1402. <example id="zend.db.adapter.connecting.persistence.example">
  1403. <title>Utiliser l'option de persistance avec l'adaptateur Oracle</title>
  1404. <programlisting language="php"><![CDATA[
  1405. $db = Zend_Db::factory('Oracle', array(
  1406. 'host' => '127.0.0.1',
  1407. 'username' => 'webuser',
  1408. 'password' => 'xxxxxxxx',
  1409. 'dbname' => 'test',
  1410. 'persistent' => true
  1411. ));
  1412. ]]></programlisting>
  1413. </example>
  1414. <para>
  1415. Notez cependant qu'utiliser des connexions persistantes peut mener à un trop grand
  1416. nombre de connexions en attente (idle), ce qui causera plus de problème que cela
  1417. n'est sensé en résoudre.
  1418. </para>
  1419. <para>
  1420. Les connexions aux bases de données possède un état. Dans cet état sont
  1421. mémorisés des objets propres au SGBD. Par exemples des verrous, des variables
  1422. utilisateur, des tables temporaires, des informations sur les requêtes récentes, les
  1423. derniers enregistrements affectés, les dernières valeurs auto-générées, etc. Avec
  1424. des connexions persistantes, il se peut que vous accédiez à des données ne faisant
  1425. pas partie de votre session de travail avec le SGBD, ce qui peut s'avérer
  1426. dangereux.
  1427. </para>
  1428. <para>
  1429. Actuellement, seuls les adpatateurs Oracle, DB2 et <acronym>PDO</acronym> (si spécifiés par <acronym>PHP</acronym>)
  1430. supportent la persistance avec Zend_Db.
  1431. </para>
  1432. </note>
  1433. </sect2>
  1434. <sect2 id="zend.db.adapter.other-statements">
  1435. <title>Exécuter des requêtes sur le driver directement</title>
  1436. <para>
  1437. Il peut y avoir des cas où vous souhaitez accéder directement à la connexion 'bas
  1438. niveau', sous <classname>Zend_Db_Adapter</classname>.
  1439. </para>
  1440. <para>
  1441. Par exemple, toute requête effectuée par <classname>Zend_Db</classname> est
  1442. préparée, et exécutée. Cependant, certaines caractéristiques des bases de données ne
  1443. sont pas compatibles avec les requêtes préparées. Par exemple, des requêtes du type
  1444. CREATE ou ALTER ne peuvent pas être préparées sous MySQL. De même, les requêtes
  1445. préparées ne bénéficient pas du <ulink
  1446. url="http://dev.mysql.com/doc/refman/5.1/en/query-cache-how.html"> cache de
  1447. requêtes</ulink>, avant MySQL 5.1.17.
  1448. </para>
  1449. <para>
  1450. La plupart des extensions <acronym>PHP</acronym> pour les bases de données proposent une méthode
  1451. permettant d'envoyer une requête directe, sans préparation. Par exemple, <acronym>PDO</acronym> propose
  1452. pour ceci la méthode <methodname>exec()</methodname>. Vous pouvez récupérer l'objet de connexion
  1453. "bas niveau" grâce à la méthode de l'adaptateur <methodname>getConnection()</methodname>.
  1454. </para>
  1455. <example id="zend.db.adapter.other-statements.example">
  1456. <title>Envoyer une requête directe dans un adaptateur PDO</title>
  1457. <programlisting language="php"><![CDATA[
  1458. $result = $db->getConnection()->exec('DROP TABLE bugs');
  1459. ]]></programlisting>
  1460. </example>
  1461. <para>
  1462. De la même manière, vous pouvez accéder à toutes les propriétés ou méthodes de
  1463. l'objet "bas niveau", utilisé par <classname>Zend_Db</classname>. Attention toutefois en
  1464. utilisant ce procédé, vous risquez de rendre votre application dépendante du SGBD
  1465. qu'elle utilise, en manipulant des méthodes propres à l'extension utilisée.
  1466. </para>
  1467. <para>
  1468. Dans de futures versions de <classname>Zend_Db</classname>, il sera possible
  1469. d'ajouter des méthodes pour des fonctionnalités communes aux extensions de bases de
  1470. données de <acronym>PHP</acronym>. Ceci ne rompra pas la compatibilité.
  1471. </para>
  1472. </sect2>
  1473. <sect2 id="zend.db.adapter.server-version">
  1474. <title>Récupérer la version du serveur SGBD</title>
  1475. <para>
  1476. A partir de la version 1.7.2, vous pouvez récupérer la version du serveur avec le
  1477. style de syntaxe <acronym>PHP</acronym> ce qui permet d'utiliser <methodname>version_compare()</methodname>. Si cette
  1478. information n'est pas disponible, vous recevrez un <constant>NULL</constant>.
  1479. </para>
  1480. <example id="zend.db.adapter.server-version.example">
  1481. <title>Vérifier la version du serveur avant de lancer une requête</title>
  1482. <programlisting language="php"><![CDATA[
  1483. $version = $db->getServerVersion();
  1484. if (!is_null($version)) {
  1485. if (version_compare($version, '5.0.0', '>=')) {
  1486. // faire quelquechose
  1487. } else {
  1488. // faire autre chose
  1489. }
  1490. } else {
  1491. // impossible de lire la version du serveur
  1492. }
  1493. ]]></programlisting>
  1494. </example>
  1495. </sect2>
  1496. <sect2 id="zend.db.adapter.adapter-notes">
  1497. <title>Notes sur des adaptateur spécifiques</title>
  1498. <para>
  1499. Cette section liste des différences entre les adaptateurs, que vous devriez
  1500. considérer.
  1501. </para>
  1502. <sect3 id="zend.db.adapter.adapter-notes.ibm-db2">
  1503. <title>IBM DB2</title>
  1504. <itemizedlist>
  1505. <listitem>
  1506. <para>Passez le paramètre 'Db2' à la méthode <methodname>factory()</methodname>.</para>
  1507. </listitem>
  1508. <listitem>
  1509. <para>Cet adaptateur utilise l'extension <acronym>PHP</acronym> ibm_db2.</para>
  1510. </listitem>
  1511. <listitem>
  1512. <para>
  1513. IBM DB2 supporte les séquences et les clés auto-incrémentées. Les
  1514. arguments de <methodname>lastInsertId()</methodname> sont donc optionnels. Si vous ne
  1515. passez pas de paramètres, alors l'adaptateur retourne la dernière valeur de
  1516. clé auto- incrémentée. Sinon, il retourne la dernière valeur de la séquence
  1517. passée en paramètre, en se référant à la convention
  1518. '<emphasis>table</emphasis>_<emphasis>colonne</emphasis>_seq'.
  1519. </para>
  1520. </listitem>
  1521. </itemizedlist>
  1522. </sect3>
  1523. <sect3 id="zend.db.adapter.adapter-notes.mysqli">
  1524. <title>MySQLi</title>
  1525. <itemizedlist>
  1526. <listitem>
  1527. <para>
  1528. Passez le paramètre 'Mysqli' à la méthode
  1529. <methodname>factory()</methodname>.
  1530. </para>
  1531. </listitem>
  1532. <listitem>
  1533. <para>Cet adaptateur utilise l'extension <acronym>PHP</acronym> mysqli.</para>
  1534. </listitem>
  1535. <listitem>
  1536. <para>
  1537. MySQL ne supporte pas les séquences, donc <methodname>lastInsertId()</methodname>
  1538. ignore tout paramètre qu'on lui passe. Elle retourne toujours la valeur de
  1539. la dernière clé auto-incrémentée. <methodname>lastSequenceId()</methodname>, elle,
  1540. retourne toujours <constant>NULL</constant>.
  1541. </para>
  1542. </listitem>
  1543. </itemizedlist>
  1544. </sect3>
  1545. <sect3 id="zend.db.adapter.adapter-notes.oracle">
  1546. <title>Oracle</title>
  1547. <itemizedlist>
  1548. <listitem>
  1549. <para>
  1550. Passez le paramètre 'Oracle' à la méthode
  1551. <methodname>factory()</methodname>.
  1552. </para>
  1553. </listitem>
  1554. <listitem>
  1555. <para>Cet adaptateur utilise l'extension <acronym>PHP</acronym> oci8.</para>
  1556. </listitem>
  1557. <listitem>
  1558. <para>
  1559. Oracle ne supporte pas les clé auto-incrémentées, donc vous devriez
  1560. spécifier un paramètre de séquence à <methodname>lastInsertId()</methodname> ou
  1561. <methodname>lastSequenceId()</methodname>.
  1562. </para>
  1563. </listitem>
  1564. <listitem>
  1565. <para>
  1566. L'extension Oracle ne supporte pas les paramètres positionnés (?).
  1567. Vous devez utiliser des paramètres nommés (:name).
  1568. </para>
  1569. </listitem>
  1570. <listitem>
  1571. <para>
  1572. Actuellement l'option <classname>Zend_Db::CASE_FOLDING</classname>
  1573. n'est pas supportée par l'adaptateur Oracle. Pour l'utiliser, vous devez
  1574. utiliser l'adaptateur basé sur <acronym>PDO</acronym> et OCI.
  1575. </para>
  1576. </listitem>
  1577. <listitem>
  1578. <para>
  1579. Par défaut les champs LOB ("Large Objet Binaire") sont retournés sous
  1580. la forme d'objets OCI-Lob. Vous pouvez les récupérer sous forme de chaînes
  1581. pour toutes les requêtes en utilisant l'option de driver
  1582. <code>'lob_as_string'</code> ou pour une requête en particulier en utilisant
  1583. la méthode <methodname>setLobAsString(boolean)</methodname> de l'adaptateur ou de
  1584. l'objet statement.
  1585. </para>
  1586. </listitem>
  1587. </itemizedlist>
  1588. </sect3>
  1589. <sect3 id="zend.db.adapter.adapter-notes.sqlsrv">
  1590. <title>Microsoft SQL Server</title>
  1591. <itemizedlist>
  1592. <listitem>
  1593. <para>
  1594. Specify this Adapter to the <methodname>factory()</methodname> method with
  1595. the name 'Sqlsrv'.
  1596. </para>
  1597. </listitem>
  1598. <listitem>
  1599. <para>
  1600. This Adapter uses the <acronym>PHP</acronym> extension sqlsrv
  1601. </para>
  1602. </listitem>
  1603. <listitem>
  1604. <para>
  1605. Microsoft <acronym>SQL</acronym> Server does not support sequences, so
  1606. <methodname>lastInsertId()</methodname> ignores primary key argument and
  1607. returns the last value generated for an auto-increment key if a table name
  1608. is specified or a last insert query returned id. The
  1609. <methodname>lastSequenceId()</methodname> method returns
  1610. <constant>NULL</constant>.
  1611. </para>
  1612. </listitem>
  1613. <listitem>
  1614. <para>
  1615. <classname>Zend_Db_Adapter_Sqlsrv</classname> sets
  1616. <constant>QUOTED_IDENTIFIER ON</constant> immediately after connecting to
  1617. a <acronym>SQL</acronym> Server database. This makes the driver use the
  1618. standard <acronym>SQL</acronym> identifier delimiter symbol
  1619. (<emphasis>"</emphasis>) instead of the proprietary square-brackets
  1620. syntax <acronym>SQL</acronym> Server uses for delimiting identifiers.
  1621. </para>
  1622. </listitem>
  1623. <listitem>
  1624. <para>
  1625. You can specify <property>driver_options</property> as a key in the options
  1626. array. The value can be a anything from here <ulink
  1627. url="http://msdn.microsoft.com/en-us/library/cc296161(SQL.90).aspx">http://msdn.microsoft.com/en-us/library/cc296161(SQL.90).aspx</ulink>.
  1628. </para>
  1629. </listitem>
  1630. <listitem>
  1631. <para>
  1632. You can use <methodname>setTransactionIsolationLevel()</methodname> to set
  1633. isolation level for current connection. The value can be
  1634. <constant>SQLSRV_TXN_READ_UNCOMMITTED</constant>,
  1635. <constant>SQLSRV_TXN_READ_COMMITTED</constant>,
  1636. <constant>SQLSRV_TXN_REPEATABLE_READ</constant>,
  1637. <constant>SQLSRV_TXN_SNAPSHOT</constant> or
  1638. <constant>SQLSRV_TXN_SERIALIZABLE</constant>.
  1639. </para>
  1640. </listitem>
  1641. <listitem>
  1642. <para>
  1643. As of Zend Framework 1.9, the minimal supported build of the
  1644. <acronym>PHP</acronym> <acronym>SQL</acronym> Server extension from
  1645. Microsoft is 1.0.1924.0. and the <acronym>MSSQL</acronym> Server Native
  1646. Client version 9.00.3042.00.
  1647. </para>
  1648. </listitem>
  1649. </itemizedlist>
  1650. </sect3>
  1651. <sect3 id="zend.db.adapter.adapter-notes.pdo-ibm">
  1652. <title>PDO pour IBM DB2 et Informix Dynamic Server (IDS)</title>
  1653. <itemizedlist>
  1654. <listitem>
  1655. <para>
  1656. Passez le paramètre 'Pdo_Ibm' à la méthode
  1657. <methodname>factory()</methodname>.
  1658. </para>
  1659. </listitem>
  1660. <listitem>
  1661. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_ibm.</para>
  1662. </listitem>
  1663. <listitem>
  1664. <para>
  1665. Vous devez possédez l'extension PDO_IBM en version 1.2.2 minimum. Si
  1666. ce n'est pas le cas, vous devrez la mettre à jour via <acronym>PECL</acronym>.
  1667. </para>
  1668. </listitem>
  1669. </itemizedlist>
  1670. </sect3>
  1671. <sect3 id="zend.db.adapter.adapter-notes.pdo-mssql">
  1672. <title>PDO Microsoft SQL Server</title>
  1673. <itemizedlist>
  1674. <listitem>
  1675. <para>
  1676. Passez le paramètre 'Pdo_Mssql' à la méthode
  1677. <methodname>factory()</methodname>.
  1678. </para>
  1679. </listitem>
  1680. <listitem>
  1681. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_dblib.</para>
  1682. </listitem>
  1683. <listitem>
  1684. <para>
  1685. Microsoft <acronym>SQL</acronym> Server ne supporte pas les séquences, ainsi
  1686. <methodname>lastInsertId()</methodname> ignore les paramètres qu'on lui passe et
  1687. retourne toujours la valeur de la dernière clé auto-incrémentée.
  1688. <methodname>lastSequenceId()</methodname> retourne toujours <constant>NULL</constant>.
  1689. </para>
  1690. </listitem>
  1691. <listitem>
  1692. <para>
  1693. Si vous travaillez avec des chaînes Unicode avec un encodage autre que
  1694. UCS-2 (comme UTF-8), vous devrez peut-être réaliser une conversion dans
  1695. votre code d'application ou stocker les données dans un champs binaire.
  1696. Reportez vous à la <ulink url="http://support.microsoft.com/kb/232580"> base
  1697. de connaissance Microsoft</ulink> pour plus d'informations.
  1698. </para>
  1699. </listitem>
  1700. <listitem>
  1701. <para>
  1702. Zend_Db_Adapter_Pdo_Mssql met <constant>QUOTED_IDENTIFIER</constant> à ON dès
  1703. que la connexion a été effectuée. Le driver utilise donc le délimiteur
  1704. d'identifiant <acronym>SQL</acronym> <code>"</code> au lieu de son délimiteur habituel.
  1705. </para>
  1706. </listitem>
  1707. <listitem>
  1708. <para>
  1709. Vous pouvez spécifier la clé <code>pdoType</code> dans le tableau
  1710. d'options de construction de l'adaptateur. La valeur peut être "mssql"
  1711. (défaut), "dblib", "freetds", ou "sybase". Cette option affecte la syntaxe
  1712. du préfixe DSN que l'adaptateur utilisera. "freetds" et "sybase" impliquent
  1713. un préfixe "sybase:", qui est utilisé par les librairies <ulink
  1714. url="http://www.freetds.org/">FreeTDS</ulink>.Voyez aussi <ulink
  1715. url="http://www.php.net/manual/en/ref.pdo-dblib.connection.php">
  1716. http://www.php.net/manual/en/ref.pdo-dblib.connection.php</ulink> pour plus
  1717. d'informations sur les DSN pour ce driver.
  1718. </para>
  1719. </listitem>
  1720. </itemizedlist>
  1721. </sect3>
  1722. <sect3 id="zend.db.adapter.adapter-notes.pdo-mysql">
  1723. <title>PDO MySQL</title>
  1724. <itemizedlist>
  1725. <listitem>
  1726. <para>
  1727. Passez le paramètre 'Pdo_Mysql' à la méthode
  1728. <methodname>factory()</methodname>.
  1729. </para>
  1730. </listitem>
  1731. <listitem>
  1732. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_mysql.</para>
  1733. </listitem>
  1734. <listitem>
  1735. <para>
  1736. MySQL ne supporte pas les séquences, ainsi <methodname>lastInsertId()</methodname>
  1737. ignore les paramètres qu'on lui passe et retourne toujours la valeur de la
  1738. dernière clé auto-incrémentée. <methodname>lastSequenceId()</methodname> retourne
  1739. toujours <constant>NULL</constant>.
  1740. </para>
  1741. </listitem>
  1742. </itemizedlist>
  1743. </sect3>
  1744. <sect3 id="zend.db.adapter.adapter-notes.pdo-oci">
  1745. <title>PDO Oracle</title>
  1746. <itemizedlist>
  1747. <listitem>
  1748. <para>
  1749. Passez le paramètre 'Pdo_Oci' à la méthode
  1750. <methodname>factory()</methodname>.
  1751. </para>
  1752. </listitem>
  1753. <listitem>
  1754. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_oci.</para>
  1755. </listitem>
  1756. <listitem>
  1757. <para>
  1758. Oracle ne supporte pas les clé auto-incrémentées, donc vous devriez
  1759. spécifier un paramètre de séquence à <methodname>lastInsertId()</methodname> ou
  1760. <methodname>lastSequenceId()</methodname>.
  1761. </para>
  1762. </listitem>
  1763. </itemizedlist>
  1764. </sect3>
  1765. <sect3 id="zend.db.adapter.adapter-notes.pdo-pgsql">
  1766. <title>PDO PostgreSQL</title>
  1767. <itemizedlist>
  1768. <listitem>
  1769. <para>
  1770. Passez le paramètre 'PDO_Pgsql' à la méthode
  1771. <methodname>factory()</methodname>.
  1772. </para>
  1773. </listitem>
  1774. <listitem>
  1775. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_pgsql.</para>
  1776. </listitem>
  1777. <listitem>
  1778. <para>
  1779. PostgreSQL supporte les séquences et les clés auto-incrémentées. Les
  1780. arguments de <methodname>lastInsertId()</methodname> sont donc optionnels. Si vous ne
  1781. passez pas de paramètres, alors l'adaptateur retourne la dernière valeur de
  1782. clé auto- incrémentée. Sinon, il retourne la dernière valeur de la séquence
  1783. passée en paramètre, en se référant à la convention
  1784. '<emphasis>table</emphasis>_<emphasis>colonne</emphasis>_seq'.
  1785. </para>
  1786. </listitem>
  1787. </itemizedlist>
  1788. </sect3>
  1789. <sect3 id="zend.db.adapter.adapter-notes.pdo-sqlite">
  1790. <title>PDO SQLite</title>
  1791. <itemizedlist>
  1792. <listitem>
  1793. <para>
  1794. Passez le paramètre 'PDO_Sqlite' à la méthode
  1795. <methodname>factory()</methodname>.
  1796. </para>
  1797. </listitem>
  1798. <listitem>
  1799. <para>Cet adaptateur utilise les extensions <acronym>PHP</acronym> pdo et pdo_sqlite.</para>
  1800. </listitem>
  1801. <listitem>
  1802. <para>
  1803. SQLite ne supporte pas les séquences, ainsi
  1804. <methodname>lastInsertId()</methodname> ignore les paramètres qu'on lui passe et
  1805. retourne toujours la valeur de la dernière clé auto-incrémentée.
  1806. <methodname>lastSequenceId()</methodname> retourne toujours <constant>NULL</constant>.
  1807. </para>
  1808. </listitem>
  1809. <listitem>
  1810. <para>
  1811. Pour vous connecter à une base de données SQLite2, spécifiez le
  1812. paramètre <code>'sqlite2'=&gt;true</code> dans le tableau d'options passé à
  1813. l'adaptateur, lors de la création de l'instance de Pdo_Sqlite
  1814. Adapter.
  1815. </para>
  1816. </listitem>
  1817. <listitem>
  1818. <para>
  1819. Pour vous connecter à une base de données SQLite en mémoire, spécifiez
  1820. le paramètre <code>'dsnprefix'=&gt;':memory:'</code> dans le tableau
  1821. d'options passé à l'adaptateur, lors de la création de l'instance de
  1822. Pdo_Sqlite Adapter.
  1823. </para>
  1824. </listitem>
  1825. <listitem>
  1826. <para>
  1827. Les anciennes versions du driver SQLite pour <acronym>PHP</acronym> ne semblent pas
  1828. supporter les commandes PRAGMA nécessaires pour s'assurer que les colonnes
  1829. ayant un nom court soient utilisées dans les résultats. Si vous avez des
  1830. problèmes, tels que vos enregistrements sont retournés avec une forme
  1831. "nomtable.nomcolonne" lors de vos jointures, vous devriez alors mettre à
  1832. jour votre version de <acronym>PHP</acronym>.
  1833. </para>
  1834. </listitem>
  1835. </itemizedlist>
  1836. </sect3>
  1837. <sect3 id="zend.db.adapter.adapter-notes.firebird">
  1838. <title>Firebird (Interbase)</title>
  1839. <itemizedlist>
  1840. <listitem>
  1841. <para>Cet adaptateur utilise l'extension <acronym>PHP</acronym> php_interbase.</para>
  1842. </listitem>
  1843. <listitem>
  1844. <para>
  1845. Firebird (Interbase) ne supporte pas les clé auto-incrémentées, donc
  1846. vous devez spécifier un paramètre de séquence à <methodname>lastInsertId()</methodname>
  1847. ou <methodname>lastSequenceId()</methodname>.
  1848. </para>
  1849. </listitem>
  1850. <listitem>
  1851. <para>
  1852. Pour l'instant l'option <classname>Zend_Db::CASE_FOLDING</classname>
  1853. n'est pas supportée par l'adaptateur Firebird (Interbase). Tout identificateur
  1854. non échappé sera automatiquement retourné en majuscules.
  1855. </para>
  1856. </listitem>
  1857. <listitem>
  1858. <para>Le nom de l'adaptateur est ZendX_Db_Adapter_Firebird.</para>
  1859. <para>
  1860. Rappelez vous qu'il est nécessaire d'utiliser le paramètre
  1861. 'adapterNamespace' avec la valeur ZendX_Db_Adapter.
  1862. </para>
  1863. <para>
  1864. Nous recommandons de mettre à jour gds32.dll (ou l'équivalent linux)
  1865. embarqué avec <acronym>PHP</acronym>, à la même version que celle du serveur. Pour Firebird
  1866. l'équivalent à <filename>gds32.dll</filename> est
  1867. <filename>fbclient.dll</filename>.
  1868. </para>
  1869. <para>
  1870. Par défaut tous les identifiants (nomde tables, de cahmps) sont retournés en
  1871. majuscules.
  1872. </para>
  1873. </listitem>
  1874. </itemizedlist>
  1875. </sect3>
  1876. </sect2>
  1877. </sect1>