lunes, noviembre 22, 2010

Como conectar desde PHP a SQL Server 2005 Express con PDO (Symfony 1.4) en Windows

Por fin lo he conseguido, tenía el problema de conectar Symfony 1.4 a una base de datos SQL Server, leyendo por ahí vi que conectar a SQL Server 2008 era imposible pero sí era factible a la versión 2005, aquí van un par de tutoriales que no he usado porque no me convencía hacer tantos cambios:

También he mirado la documentación de Propel 1.5 sobre MSSQL pero no me ha ayudado y la de Symfony para lo mismo que sí me ha servido un poco. Al final lo que he hecho ha sido seguir mi intuición respecto a las pistas que se pueden conseguir buscando en foros, blogs, etc. Ahí va un resumen:
  1. Instalar Propel 1.5 en Symfony 1.4 ya que incluye algunas mejoras que pueden ser interesantes y al parecer funciona mejor con SQL Server, para ello tan fácil como usar el plugin sfPropelPlugin15. En el manual pone que hagamos symfony plugin:publish-assets antes de cambiar el archivo ProjectConfiguration.class.php pero en mi caso daba un error y al hacerlo en el orden inverso ha funcionado perfectamente.
  2. Descargar las librerías de Microsoft para conectar PHP con SQL Server (SQL Server Driver for PHP 2.0), es importante que sea la versión 2 porque es la que incluye los drivers para PDO.
  3. Copiar los archivos del driver en la carpeta correspondiente de PHP, en mi caso como uso XAMPP para Windows es en c:\xampp\php\ext.
  4. Incluir la línea extension=php_pdo_sqlsrv_53_ts_vc6.dll en el archivo php.ini, si tu versión de php ha sido compilada con Visual C++ 9 necesitas incluir la línea extension=php_pdo_sqlsrv_53_ts_vc9.dll, si no sabes qué versión tienes miras el phpinfo y verás al principio una fila que es Compiler. 
  5. Editar los archivos de conexión a la base de datos:
    • databases.yml:
      dev:
        propel:
          param:
            classname:  DebugPDO
            debug:
              realmemoryusage: true
              details:
                time:       { enabled: true }
                slow:       { enabled: true, threshold: 0.1 }
                mem:        { enabled: true }
                mempeak:    { enabled: true }
                memdelta:   { enabled: true }

      test:
        propel:
          param:
            classname:  DebugPDO

      all:
        propel:
          class:       sfPropelDatabase
          param:
            phptype:   sqlsrv
            classname: MssqlPropelPDO
      #     no tengo claro si usar MssqlPropelPDO o MssqlDebugPDO
      #     classname: MssqlDebugPDO
            dsn:       sqlsrv:server=(local)\sqlexpress ; Database=trinity_sqlserver
            username:  sa
            password:  bezoya
            encoding:  null
            pooling:   true
    • propel.ini:
      propel.database             = sqlsrv
      propel.database.driver      = sqlsrv
      propel.database.url         = sqlsrv:server=(local)\sqlexpress ; Database=nombredebasededatos
      propel.database.user        = usuario
      propel.database.password    = clave
    • Para hacer una conexión normal, sin Symfony ni Propel de por medio:
      $user = 'usuario';
      $pass = 'clave';
      try {
          $dbh = new PDO('sqlsrv:server=(local)\sqlexpress ; Database=
      nombredebasededatos', $user, $pass);
          $dbh->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
          foreach($dbh->query('SELECT * from test') as $row) {
              print_r($row);
              echo "
      ";
          }
          $dbh = null;
      } catch (PDOException $e) {
         print "Error!: " . $e->getMessage() . "
      ";
         echo "
      ".$dbh->getAttribute(PDO_ATTR_DRIVER_NAME);
         die();
      }
Y eso es todo, de momento solo he probado a crear la base de datos con el comando symfony propel:insert-sql y funciona correctamente.

No hay comentarios: