Populate database

This commit is contained in:
raul 2024-12-09 10:43:12 +01:00
parent 37444f6e9b
commit 271d66216c
Signed by: raul
GPG Key ID: C1AA797073F17129
1 changed files with 71 additions and 4 deletions

View File

@ -1,10 +1,50 @@
-- create a table
CREATE TABLE ALUMNOS (
id_alumno INT PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
nombre TEXT NOT NULL,
apellido1 TEXT,
apellido2 TEXT,
email TEXT NOT NULL
nombre VARCHAR(255) NOT NULL,
apellido1 VARCHAR(255),
apellido2 VARCHAR(255),
email VARCHAR(255) NOT NULL
);
CREATE TABLE PROFESORES (
id_profesor INT PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
nombre VARCHAR(255) NOT NULL,
apellido1 VARCHAR(255),
apellido2 VARCHAR(255),
email VARCHAR(255) NOT NULL
);
CREATE TABLE CUESTIONARIOS (
id_cuestionario INT PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
id_profesor INT NOT NULL,
titulo VARCHAR(255) NOT NULL,
descripcion VARCHAR(255),
CONSTRAINT fk_profesor FOREIGN KEY(id_profesor) REFERENCES PROFESORES(id_profesor)
);
CREATE TABLE PREGUNTAS (
id_pregunta INT PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
id_cuestionario INT NOT NULL,
enunciado VARCHAR(255) NOT NULL,
CONSTRAINT fk_cuestionario FOREIGN KEY(id_cuestionario) REFERENCES CUESTIONARIOS(id_cuestionario)
);
CREATE TABLE RESPUESTAS (
id_respuesta INT PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
id_pregunta INT NOT NULL,
respuesta VARCHAR(255) NOT NULL,
es_verdadera BOOLEAN NOT NULL,
CONSTRAINT fk_pregunta FOREIGN KEY(id_pregunta) REFERENCES PREGUNTAS(id_pregunta)
);
CREATE TABLE JUEGA (
id_intento INT PRIMARY KEY,
id_alumno INT NOT NULL,
id_cuestionario INT NOT NULL,
num_correctas INT NOT NULL,
CONSTRAINT fk_alumno FOREIGN KEY(id_alumno) REFERENCES ALUMNOS(id_alumno),
CONSTRAINT id_cuestionario FOREIGN KEY(id_cuestionario) REFERENCES CUESTIONARIOS(id_cuestionario)
);
-- add test data
@ -12,3 +52,30 @@ INSERT INTO ALUMNOS (nombre, apellido1, apellido2, email)
VALUES ('Raúl', 'Bulgariu', 'Suciu', 'raul@bulgariu.xyz'),
('Pepito', 'Prueba', 'de Ejemplo', 'pepito@gmail.com');
INSERT INTO PROFESORES (nombre, apellido1, apellido2, email)
VALUES ('Jacinto', 'Sánchez', 'Villa', 'j.sanchezvilla@gmail.com');
INSERT INTO PROFESORES (nombre, apellido1, email)
VALUES ('David', 'Balaguer', 'david@gmail.com');
INSERT INTO CUESTIONARIOS (id_profesor, titulo, descripcion)
VALUES (1, 'Examen SOM', 'Cuestionario con preguntas sobre SOM'),
(2, 'Examen OFI', 'Cuestionario con preguntas sobre OFI');
INSERT INTO PREGUNTAS (id_cuestionario, enunciado)
VALUES (1, 'Qué comando muestra los archivos del directorio actual?'),
(1, 'Como podemos editar un archivo de texto?'),
(2, 'Es GIMP un editor de texto?');
INSERT INTO RESPUESTAS (id_pregunta, respuesta, es_verdadera)
VALUES (1, 'whoami', false),
(1, 'ls', true),
(1, 'chmod', false),
(1, 'sudo', false),
(2, 'nano', true),
(2, 'cat', false),
(2, 'vim', true),
(2, 'less', false),
(3, 'Verdadero', false),
(3, 'Falso', true);