This repository has been archived on 2021-09-15. You can view files and clone it, but cannot push or open issues or pull requests.
ModuleWeb/SRC/init/table.sql

167 lines
3.8 KiB
SQL
Executable File

DROP TABLE IF EXISTS password_resets;
DROP TABLE IF EXISTS description;
DROP TABLE IF EXISTS assolisteaoeuvre;
DROP TABLE IF EXISTS assolisteajeu;
DROP TABLE IF EXISTS listeoeuvre;
DROP TABLE IF EXISTS assodesignationaoeuvre;
DROP TABLE IF EXISTS assoauteuraoeuvre;
DROP TABLE IF EXISTS assodatationaoeuvre;
DROP TABLE IF EXISTS oeuvre;
DROP TABLE IF EXISTS auteur;
DROP TABLE IF EXISTS designation;
DROP TABLE IF EXISTS technique;
DROP TABLE IF EXISTS domaine;
DROP TABLE IF EXISTS matiere;
DROP TABLE IF EXISTS datation;
DROP TABLE IF EXISTS users;
DROP TABLE IF EXISTS niveau;
DROP TABLE IF EXISTS jeu;
CREATE TABLE jeu (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(50),
description VARCHAR(255),
PRIMARY KEY (id)
);
CREATE TABLE niveau (
id INT NOT NULL AUTO_INCREMENT,
idjeu INT NOT NULL,
difficulte INT,
caractéristique VARCHAR(255),
PRIMARY KEY (id),
FOREIGN KEY (idjeu) REFERENCES jeu(id)
);
CREATE TABLE users (
id INT NOT NULL AUTO_INCREMENT,
firstname VARCHAR(50),
lastname VARCHAR(50),
city VARCHAR(50),
password VARCHAR(255),
email VARCHAR(50),
image VARCHAR(255),
remember_token VARCHAR(100),
droits INT DEFAULT 0,
PRIMARY KEY (id)
);
CREATE TABLE designation (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(255) NOT NULL,
urldesignation VARCHAR(255),
PRIMARY KEY (id)
);
CREATE TABLE auteur (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(50) NOT NULL,
anecdote VARCHAR(255),
PRIMARY KEY (id)
);
CREATE TABLE technique (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(50) NOT NULL,
urltechnique VARCHAR(255),
PRIMARY KEY (id)
);
CREATE TABLE domaine (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(50) NOT NULL,
PRIMARY KEY (id)
);
CREATE TABLE matiere (
id INT NOT NULL AUTO_INCREMENT,
nom VARCHAR(50) NOT NULL,
PRIMARY KEY (id)
);
CREATE TABLE datation (
id INT NOT NULL AUTO_INCREMENT,
debut DATE,
fin DATE,
PRIMARY KEY (id)
);
CREATE TABLE oeuvre (
id INT NOT NULL AUTO_INCREMENT,
iddate INT,
idtechnique INT,
iddomaine INT,
idmatiere INT,
urlPhoto VARCHAR(50),
PRIMARY KEY (id),
FOREIGN KEY (idtechnique) REFERENCES technique(id),
FOREIGN KEY (iddomaine) REFERENCES domaine(id),
FOREIGN KEY (idmatiere) REFERENCES matiere(id),
FOREIGN KEY (iddate) REFERENCES datation(id)
);
CREATE TABLE assodesignationaoeuvre (
oeuvre_id INT NOT NULL,
designation_id INT NOT NULL,
PRIMARY KEY (designation_id,oeuvre_id),
FOREIGN KEY (designation_id) REFERENCES designation(id),
FOREIGN KEY (oeuvre_id) REFERENCES oeuvre(id)
);
CREATE TABLE assoauteuraoeuvre (
oeuvre_id INT NOT NULL,
auteur_id INT NOT NULL,
PRIMARY KEY (auteur_id,oeuvre_id),
FOREIGN KEY (auteur_id) REFERENCES auteur(id),
FOREIGN KEY (oeuvre_id) REFERENCES oeuvre(id)
);
CREATE TABLE listeoeuvre (
id INT NOT NULL AUTO_INCREMENT,
iduser INT NOT NULL,
nom VARCHAR(50),
etat INT(1) DEFAULT 0,
dateCreation TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (id),
FOREIGN KEY (iduser) REFERENCES users(id)
);
CREATE TABLE assolisteaoeuvre (
liste_oeuvre_id INT NOT NULL,
oeuvre_id INT NOT NULL,
PRIMARY KEY (liste_oeuvre_id,oeuvre_id),
FOREIGN KEY (liste_oeuvre_id) REFERENCES listeoeuvre(id),
FOREIGN KEY (oeuvre_id) REFERENCES oeuvre(id)
);
CREATE TABLE assolisteajeu (
liste_oeuvre_id INT NOT NULL,
jeu_id INT NOT NULL,
PRIMARY KEY (liste_oeuvre_id,jeu_id),
FOREIGN KEY (liste_oeuvre_id) REFERENCES listeoeuvre(id),
FOREIGN KEY (jeu_id) REFERENCES jeu(id)
);
CREATE TABLE description (
id INT NOT NULL AUTO_INCREMENT,
idoeuvre INT NOT NULL,
idlisteoeuvre INT NOT NULL,
libelle VARCHAR(255),
PRIMARY KEY (id),
FOREIGN KEY (idoeuvre) REFERENCES oeuvre(id),
FOREIGN KEY (idlisteoeuvre) REFERENCES listeoeuvre(id)
);
CREATE TABLE password_resets (
token VARCHAR(255),
email VARCHAR(255),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (token)
);