TD : Accès aux bases de données en PHP

Rappels de cours :

Application

L'objectif est de créer une application Web permettant de générer le script SQL (pour MariaDb) à partir d'un script Mocodo.

Exemple de script Mocodo :

typeDroit: id, nom
 
Periode: id, dateD, dateF
Droit, 1N Exploitation, 1N typeDroit, 1N Periode: valeur
Exploitation: id, nom, SAU
 
Commune: id, cp, ville
DF, 11 Exploitation, 0N Commune

Exemple de Script à générer :

CREATE TABLE commune (
  PRIMARY KEY (id),
  id MEDIUMINT NOT NULL AUTO_INCREMENT,
  cp    VARCHAR(42),
  ville VARCHAR(42)
);

CREATE TABLE droit (
  PRIMARY KEY (idPeriode, idTypeDroit, idExploitation),
  idPeriode   MEDIUMINT NOT NULL,
  idTypeDroit   MEDIUMINT NOT NULL,
  idExploitation   MEDIUMINT NOT NULL,
  valeur VARCHAR(42)
);

CREATE TABLE exploitation (
  PRIMARY KEY (id),
  id MEDIUMINT NOT NULL AUTO_INCREMENT,
  nom  VARCHAR(42),
  sau  VARCHAR(42),
  idCommune MEDIUMINT NOT NULL
);

CREATE TABLE periode (
  PRIMARY KEY (id),
  id MEDIUMINT NOT NULL AUTO_INCREMENT,
  dateD Date,
  dateF Date
);

CREATE TABLE typeDroit (
  PRIMARY KEY (id),
  id MEDIUMINT NOT NULL AUTO_INCREMENT,
  nom VARCHAR(42)
);

ALTER TABLE droit ADD FOREIGN KEY (idPeriode) REFERENCES periode (id);
ALTER TABLE droit ADD FOREIGN KEY (idTypeDroit) REFERENCES typeDroit (id);
ALTER TABLE droit ADD FOREIGN KEY (idExploitation) REFERENCES exploitation (id);

ALTER TABLE exploitation ADD FOREIGN KEY (idCommune) REFERENCES commune (id);

Contraintes :

  • PHP orienté objet + MariaDb

Conception :

  • Fonctionnelle :
    • Lister toutes les fonctionnalités de l'application (en détaillant le plus possible) ⇒ Use cases
    • Identifier et maquetter les interfaces à créer
  • Technique : Lister les opérations à effectuer, essayer de les regrouper en classes.
  • Organisation : Travailler en Pair programming, en 1 seule équipe

Implémentation

  • Créer un repository
  • Développer l'application