Aller au contenu

Modélisation avec MERISE

La méthode Merise

Vous avez peut-être entendu parlé de Merise, et plus particulièrement du MCD, MLD et MPD. Merise une méthode d’analyse, de conception et de gestion de projet informatique. C’est une méthode ancienne qui est toujours très prisée par certains concepteurs. Cette méthode est très orientée données. Il est de plus en plus fréquent d’utiliser le diagramme des classes du langage UML lors d’un développement objet. Cependant, vous devez connaitre et être capable d’écrire un MCD, un MLD et un MPD.

Le MCD

C’est le Modèle Conceptuel de Données. L’équivalent UML est le diagramme des classes du MOO.
Dans le MCD, on parle d’entités et de relations. L’entité c’est la classe du MOO, représentée par un rectangle. La relation correspond à l’association dans le MOO. Elle est représentée par une forme ovoïde. En Merise, nous avons des cardinalités que nous appelons multiplicités en UML.
L’entité a un identifiant et des propriétés. La relation est un verbe et peut avoir des attributs.

Construire un MCD

Le MLD

Le Modèle Logique de Données est la transformation du MCD en ensemble de tables.
Une entité devient une table. Un identifiant devient la clef primaire. Une propriété devient un champ.
A ce niveau là apparaît la clef étrangère.

Construire un MLD
Complément sur les cardinalités

Le MPD

Le Modèle Physique de Données est la transformation du MLD dans le format d’une base de données. Le résultat final sera un script SQL qui permettra de créer la base dans le SGBDR. Il y a un MPD par modèle de base (Oracle, PostgreSQL, MySql).

Outils

MySql Workbench

MySql Workbench utilise un “Physical schema” ou “EER Diagram”. Ce n’est pas un modèle Merise. Il s’approche d’un modèle physique (MPD)

physical schema

Pour simplifier, on dira que le “physical schema” est la base de données qui contient les tables. L’interface graphique permet de créer des tables, des champs, de relier les tables entre elles, etc…

EER Diagram

EER comme Enhanced Entity–Relationship (entité association étendu).
Il s’agit d’un modèle graphique. L’outil EER Diagram permet de créer graphiquement une base. Attention, c’est un mélange de MLD et MCD !

Pour créer une base de données, on passe soit par le MCD-MLD-MPD de Merise, soit par le diagramme de classe UML. L’identification des entités se fait de la même manière. On peut donc appliquer les règles de Merise en faisant bien attention à l’inversion des multiplicités (UML) beaucoup plus facile à écrire que les cardinalités d’un MCD.

EER

Lorsque l’on a fini la modélisation, on génère le script. C’est ce script que l’on va exécuter pour créer physiquement la base (physical schema).

Voici une partie du script correspondant au schéma ci-dessus :

CREATE TABLE IF NOT EXISTS `mydb`.`Etudiant` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `nom` VARCHAR(45) NOT NULL,
  `prenom` VARCHAR(45) NOT NULL,
  `diplome` VARCHAR(45) NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `mydb`.`Matiere` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `nom` VARCHAR(45) NULL,
  `nbHeure` INT NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `mydb`.`Professeur` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `nom` VARCHAR(45) NOT NULL,
  `prenom` VARCHAR(45) NOT NULL,
  `competence` VARCHAR(45) NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `mydb`.`Cours` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `salle` VARCHAR(45) NULL,
  `horaire` DATETIME NULL,
  `idMatiere` INT NOT NULL,
  `idProfesseur` INT NOT NULL,
  PRIMARY KEY (`id`),
  INDEX `fk_Cours_Matiere_idx` (`idMatiere` ASC),
  INDEX `fk_Cours_Professeur1_idx` (`idProfesseur` ASC),
  CONSTRAINT `fk_Cours_Matiere`
    FOREIGN KEY (`idMatiere`)
    REFERENCES `mydb`.`Matiere` (`id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_Cours_Professeur1`
    FOREIGN KEY (`idProfesseur`)
    REFERENCES `mydb`.`Professeur` (`id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `mydb`.`Participant` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `place` INT NOT NULL,
  `idCours` INT NOT NULL,
  `idEtudiant` INT NOT NULL,
  PRIMARY KEY (`id`),
  INDEX `fk_Participant_Cours1_idx` (`idCours` ASC),
  INDEX `fk_Participant_Etudiant1_idx` (`idEtudiant` ASC),
  CONSTRAINT `fk_Participant_Cours1`
    FOREIGN KEY (`idCours`)
    REFERENCES `mydb`.`Cours` (`id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_Participant_Etudiant1`
    FOREIGN KEY (`idEtudiant`)
    REFERENCES `mydb`.`Etudiant` (`id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;

Pratiquez !

Auto-école

Solution pour l’auto-école

GTD-Gestionnaire de Tâches

Auteur : Philippe Bouget