Niano Niano
17Feb/093

Symfony 1.2 + Propel 1.3 + Oracle (Parte 2)

Ahora que ya tenemos el módulo PDO_OCI funcionando, podemos intentar hacer una prueba en Symfony 1.2 con Propel 1.3. Después de dar muchas vueltas, he llegado a la conclusión de que el formato para databases.yml es el siguiente:

all:

propel:

class: sfPropelDatabase

param:

classname: PropelPDO

phptype: oracle

dsn: oci:dbname=//%IP_DEL_SERVIDOR%:%PUERTO_DEL_SERVIDOR%/%BASE_DE_DATOS%

username: %USUARIO%

password: %CONTRASEÑA%

encoding: utf8

persistent: true

pooling: true

(No consigo que el maldito WordPress indente correctamente el código anterior así que recuerda que la jerarquía es: all >> propel >> param >> resto)

El formato de propel.ini sería el siguiente:

propel.database            = oracle

propel.database.driver     = oracle

propel.database.url        = oci:dbname=//%IP_DEL_SERVIDOR%:%PUERTO_DEL_SERVIDOR%/%BASE_DE_DATOS%

propel.database.creole.url = ${propel.database.url}

propel.database.user       = %USUARIO%

propel.database.password   = %CONTRASEÑA%

propel.database.encoding   = utf8

Lo último que necesitas para que la ingeniería inversa funcione es un parseador de estructura de base de datos para bases de datos de Oracle. Propel 1.3 no trae uno, así que puedes usar el que un servidor ha preparado convenientemente: Oracle Schema Parser (PHP5 script) (Bórrale la extensión "doc" y déjalo en un directorio "lib/plugins/sfPropelPlugin/lib/vendor/propel-generator/classes/propel/engine/database/reverse/oracle" nuevo que tienes que crear en la instalación de Symfony).

Con esto y un bizcocho, ya deberías ser capaz de ejecutar la tarea "propel:build-schema" :)

Comparte este post:
  • Print
  • del.icio.us
  • Facebook

¿Te gustó este artículo?

¡Suscríbete a nuestro feed RSS!

Comentarios (3) Trackbacks (0)
  1. Muy interesante, muy interesante… voy a empezar a jugar con Symfony 1.2 y Oracle, y parte de la info del pdo_oci yo también la he sufrido :|

    Un saludo

    Isidro

  2. Hola Isidro!

    Tengo que avisarte de que te faltará el parseador de schemas de Oracle ya que no viene en el paquete de propel.

    Estoy coordinándome con la gente de Propel para que publiquen en su repositorio los cambios que he tenido que realizar sobre mi instalación de Symfony y propel para que todo funcione correctamente.

    Me complace decirte que en los bancos de prueba en los que estoy probándolo todo, mis clases funcionan de maravilla :)

    Espero que en los próximos días se pueda añadir a la versión de Propel 1.3 mi contribución con un sistema de ingeniería inversa para Oracle completamente funcional.

  3. estuve investigando sobre el tema de Symfony + Oracle
    y encontré ke en el fichero propel.ini debía modificar estas líneas:

    propel.database = oracle
    propel.database.createUrl = oracle://despacho_mti:pass@CADI.UCI.CU/
    propel.database.url = oracle://despacho_mti:pass@CADI.UCI.CU/

    Donde,
    despacho_Mti: es el nombre del esquema en la base de datos
    pass: la contraseña
    CADI.UCI.CU : la variable declarada en /usr/lib/oracle/network/admin/tnsname.ora

    también modificar en databases.yml la línea:

    dsn: oracle://despacho_mti:despacho@CADI.UCI.CU/

    y ya está, ahora se puede generar el schema
    >symfony propel-build schema xml

    PD: tener en cuenta editar el schema antes de generar el modelo, en mi caso solo puse esta línea:

    pero si tienes alguna secuencia en la base de datos, hay ke buskar en el schema.xml los campos ke llevan la secuencia y agregarle la propiedad autoIncrement = “true”

    a mi me funcionó…. suerte


Deja un comentario


Aún no hay trackbacks.