You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sae_2a_anglais/Project/db/createdb.sql

93 lines
2.3 KiB

DROP TABLE IF EXISTS Translate;
DROP TABLE IF EXISTS Register;
DROP TABLE IF EXISTS Practice;
DROP TABLE IF EXISTS Be;
DROP TABLE IF EXISTS VocabularyList;
DROP TABLE IF EXISTS Vocabulary;
DROP TABLE IF EXISTS Language;
DROP TABLE IF EXISTS User_;
DROP TABLE IF EXISTS Role_;
DROP TABLE IF EXISTS Group_;
CREATE TABLE Group_(
id int(10) PRIMARY KEY AUTO_INCREMENT,
num numeric NOT NULL,
year numeric NOT NULL,
sector varchar(50) NOT NULL
);
CREATE TABLE User_(
id int(10) PRIMARY KEY AUTO_INCREMENT,
password text NOT NULL,
email text NOT NULL,
name text NOT NULL,
surname text NOT NULL,
nickname varchar(30),
image text NOT NULL,
extraTime boolean,
groupID int(10),
FOREIGN KEY (groupID) REFERENCES Group_(id)
);
CREATE TABLE Role_(
id int(1) PRIMARY KEY AUTO_INCREMENT,
name varchar(10) NOT NULL
);
CREATE TABLE Be(
userID int(10),
roleID int(1),
FOREIGN KEY (userID) REFERENCES User_(id),
FOREIGN KEY (roleID) REFERENCES Role_(id),
PRIMARY KEY (userID, roleID)
);
CREATE TABLE VocabularyList(
id int(10) PRIMARY KEY AUTO_INCREMENT,
name varchar(30) NOT NULL,
image text NOT NULL,
userID int(10),
FOREIGN KEY (userID) REFERENCES User_(id)
);
CREATE TABLE Practice(
vocabID int(10),
groupID int(10),
FOREIGN KEY (vocabID) REFERENCES VocabularyList(id),
FOREIGN KEY (groupID) REFERENCES Group_(id),
PRIMARY KEY (vocabID, groupID)
);
CREATE TABLE Language(
name varchar(30) PRIMARY KEY
);
CREATE TABLE Vocabulary(
word varchar(30) PRIMARY KEY
);
CREATE TABLE Translate(
id int(10) PRIMARY KEY AUTO_INCREMENT,
firstWord varchar(30),
secondWord varchar(30),
listVoc int(10),
FOREIGN KEY (firstWord) REFERENCES Vocabulary(word),
FOREIGN KEY (secondWord) REFERENCES Vocabulary(word),
FOREIGN KEY (listVoc) REFERENCES VocabularyList(id)
);
CREATE TABLE Register(
language varchar(30),
word varchar(30),
FOREIGN KEY (language) REFERENCES Language(name),
FOREIGN KEY (word) REFERENCES Vocabulary(word),
PRIMARY KEY (language, word)
);
INSERT INTO Role_ VALUES (1, 'admin');
INSERT INTO Role_ VALUES (2, 'teacher');
INSERT INTO Role_ VALUES (3, 'student');
INSERT INTO Language VALUES ('English');
INSERT INTO Language VALUES ('French');