Diferència entre revisions de la pàgina «A2- Framework de capes per a DDBB (20h)»

De wikiserver
Dreceres ràpides: navegació, cerca
(Es crea la pàgina amb «=Doctrine= Una de les tasques més comunes i desafiadores per a qualsevol aplicació implica la persistència i la lectura d'informació cap a i des d'una base de dades. …».)
 
Línia 7: Línia 7:
  
 
== Configuracio de Doctrine i la Base de Dades==
 
== Configuracio de Doctrine i la Base de Dades==
 +
Ès necessari configurar la informació per accedir a la base de dades. Per convenció, aquesta informació es configura en l'arxiu '''app/config/parameters.yml''':
 +
<source lang="yml">
 +
# app/config/parameters.yml
 +
parameters:
 +
    database_driver:  pdo_mysql
 +
    database_host:    localhost
 +
    database_name:    test_project
 +
    database_user:    root
 +
    database_password: password
 +
</source>
  
<source lang="yml">
+
Ara que doctrine ja coneix l'usuari, la contrasenya i la Base de Dades a utilitzar, pots crear-la amb la següent comanda:
 +
$ php app/console doctrine:database:create
 +
 
 +
== Creant una classe Entity ==
 +
 
 +
Imagina que estàs desenvolupant una aplicació en la qual vas a mostrar productes. Oblidant-te de Doctrine i de les bases de dades, segurament estàs pensant a utilitzar un objecte '''Product''' per representar als productes. Crea aquesta classe dins del directori Entity del bundle AcmeStoreBundle:
  
 +
<source lang="php">
 +
// src/Acme/StoreBundle/Entity/Product.php
 +
namespace Acme\StoreBundle\Entity;
 +
 +
class Product
 +
{
 +
    protected $name;
 +
 +
    protected $price;
 +
 +
    protected $description;
 +
}
 
</source>
 
</source>
  
 +
És una classe molt senzilla que només s'utilitza per emmagatzemar dades. Encara que es tracta d'una classe molt bàsica, compleix el seu objectiu de representar als productes de la teva aplicació. No obstant això, '''aquesta classe no es pot guardar''' en una base de dades — '''és només una classe PHP simple'''.
  
 +
Podràs generar les classes de tipus entitat més fàcilment amb la següent comanda. Una vegada executat, Doctrine et farà diverses preguntes per generar l'entitat de forma interactiva:
 +
$ php app/console doctrine:generate:entity
  
 +
=== Mapeig d'objectes PHP a tables de BD ===
  
<source lang="yml">
+
En comptes de treballar amb files i taules, Doctrine et permet guardar i obtenir objectes sencers a partir de la informació de la base de dades. El truc perquè això funcioni consisteix en mapear una classe PHP a una taula de la base de dades i després, mapear les propietats de la classe PHP a les columnes d'aquesta taula:
 +
 
 +
php-bd.png
 +
 
 +
 
 +
<source lang="php">
  
 
</source>
 
</source>

Revisió del 13:48, 9 març 2015

Doctrine

Una de les tasques més comunes i desafiadores per a qualsevol aplicació implica la persistència i la lectura d'informació cap a i des d'una base de dades. Encara que el framework Symfony no integra cap ORM per defecte, l'edició estàndard de Symfony, que és la distribució més utilitzada, ve integrada amb Doctrine, una biblioteca, l'únic objectiu de la qual és donar eines poderoses per fer-ho fàcil.

La llibreria Doctrine proporciona eines per simplificar l'accés i maneig de la informació de la base de dades.

La millor manera per explicar el framework doctrine és mitjançant exmples. Per aixó, es configura l'accés a la base de dades amb doctrine i s'exemplificarà amb la creació d'un objecte anomenat Product.

Configuracio de Doctrine i la Base de Dades

Ès necessari configurar la informació per accedir a la base de dades. Per convenció, aquesta informació es configura en l'arxiu app/config/parameters.yml:

# app/config/parameters.yml
parameters:
    database_driver:   pdo_mysql
    database_host:     localhost
    database_name:     test_project
    database_user:     root
    database_password: password

Ara que doctrine ja coneix l'usuari, la contrasenya i la Base de Dades a utilitzar, pots crear-la amb la següent comanda:

$ php app/console doctrine:database:create

Creant una classe Entity

Imagina que estàs desenvolupant una aplicació en la qual vas a mostrar productes. Oblidant-te de Doctrine i de les bases de dades, segurament estàs pensant a utilitzar un objecte Product per representar als productes. Crea aquesta classe dins del directori Entity del bundle AcmeStoreBundle:

// src/Acme/StoreBundle/Entity/Product.php
namespace Acme\StoreBundle\Entity;
 
class Product
{
    protected $name;
 
    protected $price;
 
    protected $description;
}

És una classe molt senzilla que només s'utilitza per emmagatzemar dades. Encara que es tracta d'una classe molt bàsica, compleix el seu objectiu de representar als productes de la teva aplicació. No obstant això, aquesta classe no es pot guardar en una base de dades — és només una classe PHP simple.

Podràs generar les classes de tipus entitat més fàcilment amb la següent comanda. Una vegada executat, Doctrine et farà diverses preguntes per generar l'entitat de forma interactiva:

$ php app/console doctrine:generate:entity

Mapeig d'objectes PHP a tables de BD

En comptes de treballar amb files i taules, Doctrine et permet guardar i obtenir objectes sencers a partir de la informació de la base de dades. El truc perquè això funcioni consisteix en mapear una classe PHP a una taula de la base de dades i després, mapear les propietats de la classe PHP a les columnes d'aquesta taula:

php-bd.png