Zend_Application-AvailableResources-Multidb.xml 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 20017 -->
  3. <!-- Reviewed: no -->
  4. <sect2 id="zend.application.available-resources.multidb">
  5. <title>Zend_Application_Resource_Multidb</title>
  6. <para>
  7. <classname>Zend_Application_Resource_Multidb</classname> puede ser utulizado para
  8. instanciar múltiples conexiones a distintas bases de datos. Se pueden usar las mismas
  9. opciones que con el
  10. <link linkend="zend.application.available-resources.db">recurso complemento Db</link>.
  11. Sin embargo, para especificar una conexión por defecto, se puede usar la directiva
  12. 'default'.
  13. </para>
  14. <example id="zend.application.available-resources.multidb.configexample">
  15. <title>Configurando múltiples conexiones</title>
  16. <para>
  17. Abajo se muestra un extracto de archivo <acronym>INI</acronym> de ejemplo donde se
  18. muestra como configurar dos conexiones.
  19. </para>
  20. <programlisting language="ini"><![CDATA[
  21. [production]
  22. resources.multidb.db1.adapter = "pdo_mysql"
  23. resources.multidb.db1.host = "localhost"
  24. resources.multidb.db1.username = "webuser"
  25. resources.multidb.db1.password = "miClaveDificil"
  26. resources.multidb.db1.dbname = "db1"
  27. resources.multidb.db2.adapter = "pdo_pgsql"
  28. resources.multidb.db2.host = "example.com"
  29. resources.multidb.db2.username = "dba"
  30. resources.multidb.db2.password = "otraClaveDificil"
  31. resources.multidb.db2.dbname = "db2"
  32. resources.multidb.db2.default = true
  33. ]]></programlisting>
  34. </example>
  35. <example id="zend.application.available-resources.multidb.retrieveSpecificDb">
  36. <title>Obteniendo un adaptador de base de datos en particular</title>
  37. <para>
  38. Al usar este recurso complemento, por lo general se desea obtener el adaptador
  39. de una base de datos en particular. Esto puede ser realizado usando el método
  40. <methodname>getDb()</methodname> provisto por el recurso. El método
  41. <methodname>getDb()</methodname> devuelve una instancia de una clase que extiende
  42. <classname>Zend_Db_Adapter_Abstract</classname>. Si no ha especificado una base
  43. de datos por defecto, saltará una excepción si este método es llamado sin pasarle
  44. un parámetro
  45. </para>
  46. <programlisting language="php"><![CDATA[
  47. $resource = $bootstrap->getPluginResource('multidb');
  48. $db1 = $resource->getDb('db1');
  49. $db2 = $resource->getDb('db2');
  50. $defaultDb = $resource->getDb();
  51. ]]></programlisting>
  52. </example>
  53. <example id="zend.application.available-resources.multidb.retrieveDefaultDb">
  54. <title>Obteniendo el adaptador de base de datos por defecto</title>
  55. <para>
  56. Adicionalmente, se puede obtener el adaptador por defecto usando el método
  57. <methodname>getDefaultDb()</methodname>. Si no ha especificado un adaptador por
  58. defecto, el primer adaptador configurado será devuelto. A menos que especifique
  59. <constant>FALSE</constant> como primer parámetro, <constant>NULL</constant> será
  60. devuelto cuando no se haya configurado ningún adaptador por defecto.
  61. </para>
  62. <para>
  63. Abajo se muestra un ejemplo que asume que el recurso complemento MultiDb se ha
  64. configurado con el ejemplo <acronym>INI</acronym> mostrado anteriormente.
  65. </para>
  66. <programlisting language="php"><![CDATA[
  67. $resource = $bootstrap->getPluginResource('multidb');
  68. $db2 = $resource->getDefaultDb();
  69. // Misma configuración, pero ahora con la db por defecto:
  70. $db1 = $resource->getDefaultDb();
  71. $null = $resource->getDefaultDb(false); // null
  72. ]]></programlisting>
  73. </example>
  74. </sect2>