#DATABASE_URL=mysql://db_user:db_password@127.0.0.1:3306/db_name
Exemple :
DATABASE_URL="mysql://root:@127.0.0.1:3307/webstudent?serverVersion=mariadb-10.10.2"
Cette configuration permet de se connecter à une base de données mariadb nommée webstudent, située sur le poste local. Le compte de connexion est root, sans mot de passe.
Si vous n'avez pas encore créé la base de données sous mariadb ou mysql, la console permet de créer la base de données en exécutant la commande ci-dessous :
> php bin/console doctrine:database:create
{{sfndbcreation.png}}
===== Créer une entité = classe métier =====
Dans symfony, les classes métiers se nomment des entités. Elles peuvent être créées avec la console :
> php bin/console make:entity
Le système nous invite alors à saisir l'ensemble des propriétés de l'entité. Pour chaque propriété, nous devons préciser son type, si cette propriété sera ''nullable'' en bdd ou pas.
Dans l'exemple ci-dessous, nous créons l'entité ''Etudiant'' avec la propriété ''nom'' de type ''string'' de 50 caractères. Vous créerez les propriétés nom, prenom, dateNaiss (type date), ville.
{{sfnentitycreation.png}}
Un fichier nommé Etudiant.php a alors été créé dans le dossier .../src/Entity. Il s'agit d'une classe métier classique avec ses propriétés. Les getters et les setters ont été générés automatiquement. Une propriété supplémentaire id de type int a été ajoutée. Elle est utilisée pour faire le mapping de la clé primaire de la table qui sera un numérique auto-incrémenté.
===== Créer la table en base de données =====
Il est alors possible de créer la table correspondant à l'entité.
> php bin/console make:migration
Cette instruction créé à chaque fois un fichier dans le dossier src/migration avec les instructions sql à exécuter.
{{sfnmigration.png}}
Pour exécuter les instructions sql, lancer la commande suivante :
> php bin/console doctrine:migrations:migrate
{{sfnmigrate.png}}
On voit alors l'instruction sql exécutée.
Vérifiez en base l'existence de la table. A chaque propriété de l'entité correspond un champ de la table. Celle ci a pour clé primaire Id.
===== Persister un objet en base =====
Il s'agit ici de créer un objet et de rendre ses données persistantes en base de données.
Pour cela, nous allons créer une nouvelle url qui exécutera une méthode du contrôleur créant un objet et insérant un enregistrement en base. Le contrôleur redirigera vers une page de consultation de l'enregistrement créé.
==== Ajout de la nouvelle route ====
Dans le fichier des routes, ajouter :
etudiantAjouter:
path: /etudiant/ajouter
controller: App\Controller\EtudiantController::ajouter
==== Modification du contrôleur ====
Ajout de la méthode ajouterEtudiant dans EtudiantController
public function ajouter(ManagerRegistry $doctrine){
// récupère le manager d'entités
$entityManager = $doctrine->getManager();
// instanciation d'un objet Etudiant
$etudiant = new Etudiant();
$etudiant->setNom('Potter');
$etudiant->setPrenom('Harry');
$etudiant->setDateNaiss(new \DateTime(date('1980-07-31')));
$etudiant->setVille('Surrey');
// Indique à Doctrine de persister l'objet
$entityManager->persist($etudiant);
// Exécue l'instruction sql permettant de persister lobjet, ici un INSERT INTO
$entityManager->flush();
// renvoie vers la vue de consultation de l'étudiant en passant l'objet etudiant en paramètre
return $this->render('etudiant/consulter.html.twig', [
'etudiant' => $etudiant,]);
}
une erreur apparaitra car la classe métier (l'entité) Etudiant n'est pas connue de EtudiantController.
Il faut donc l'importer en ajoutant la ligne ci-dessous au niveau des use (imports) ainsi que le manager d'entités.
use App\Entity\Etudiant;
use Doctrine\Persistence\ManagerRegistry;
==== Création de la vue ====
Dans le dossier templates/etudiant, créer le fichier ci-dessous, nommé consulter.html.twig
PAGE DE CONSULTATION D'UN ETUDIANT
Id : {{etudiant.id}}
Nom : {{etudiant.nom}}
{% set photo = 'img/etudiant/'~ etudiant.id ~'.jpg' %}
Prénom : {{etudiant.prenom}}
Date de naissance : {{etudiant.dateNaiss|date("d/m/Y")}}
rue : {{etudiant.numrue}} {{etudiant.rue}}
code postal : {{etudiant.copos}}
ville : {{etudiant.ville}}
Surnom : {{etudiant.surnom}}
Note : dans la vue ci-dessus,, des propriétés supplémentaires ont été ajoutées.
Ajoutez les dans votre entité étudiant et faites le mapping avec la base de données.
==== Tests ====
http://localhost/webstudent/public/etudiant/ajouter
{{sfnconsultetud.png}}
Vérifier la présence de l'enregistrement en base.
{{sfnpersistetud.png}}
===== Consulter un étudiant =====
public function consulterEtudiant(ManagerRegistry $doctrine, int $id){
$etudiant= $doctrine->getRepository(Etudiant::class)->find($id);
if (!$etudiant) {
throw $this->createNotFoundException(
'Aucun etudiant trouvé avec le numéro '.$id
);
}
//return new Response('Etudiant : '.$etudiant->getNom());
return $this->render('etudiant/consulter.html.twig', [
'etudiant' => $etudiant,]);
}
La méthode prend en paramètre l'id de l'étudiant permettant la recherche en bdd de l'étudiant selon son id.
Il faut donc indiquer dans l'url l'id de l'étudiant.
Dans le fichier de routes, il faut donc ajouter le paramètre :
etudiantConsulter:
path: /etudiant/consulter/{id}
controller: App\Controller\EtudiantController::consulterEtudiant
===== Lister les étudiants =====
EtudiantController, méthode permettant de lister les étudiants
public function listerEtudiant(ManagerRegistry $doctrine){
$repository = $doctrine->getRepository(Etudiant::class);
$etudiants= $repository->findAll();
return $this->render('etudiant/lister.html.twig', [
'pEtudiants' => $etudiants,]);
}
Vue Twig listant les étudiants
{% block title %}Welcome!{% endblock %}
{% block stylesheets %}{% endblock %}
{% block body %}{% endblock %}
{% block javascripts %}{% endblock %}
LISTE DES ETUDIANTS
{% for e in pEtudiants %}
{{ e.nom }}
{{ e.prenom }}
{{ e.dateNaiss|date('d/m/Y') }}
{{ e.ville}}
{% else %}
Aucun etudiant n'a été trouvé.
{% endfor %}