-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathinit.sql
More file actions
78 lines (77 loc) · 2.15 KB
/
init.sql
File metadata and controls
78 lines (77 loc) · 2.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
CREATE DATABASE IF NOT EXISTS chatdb;
use chatdb;
CREATE TABLE IF NOT EXISTS user_info (
id INT AUTO_INCREMENT PRIMARY KEY,
tag VARCHAR(255) NOT NULL,
UNIQUE(tag),
name VARCHAR(255)
CHARACTER SET utf8
);
CREATE TABLE IF NOT EXISTS room_info(
id INT AUTO_INCREMENT PRIMARY KEY ,
type ENUM('direct','group')
);
CREATE TABLE IF NOT EXISTS user_credentials(
login VARCHAR(255) PRIMARY KEY,
password VARCHAR(255) NOT NULL,
userID INT,
FOREIGN KEY (userID) REFERENCES user_info (id)
ON DELETE CASCADE
);
CREATE TABLE IF NOT EXISTS room_users (
userID INT,
roomID INT,
FOREIGN KEY (roomID) REFERENCES room_info (id)
ON DELETE CASCADE,
FOREIGN KEY (userID) REFERENCES user_info (id)
ON DELETE CASCADE
);
CREATE TABLE IF NOT EXISTS group_rooms (
tag VARCHAR(255) PRIMARY KEY,
UNIQUE(tag),
name VARCHAR(255)
CHARACTER SET utf8,
roomID INT,
FOREIGN KEY (roomID) REFERENCES room_info (id)
);
CREATE TABLE IF NOT EXISTS room_messages (
id INT AUTO_INCREMENT PRIMARY KEY,
time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
body VARCHAR(2048)
CHARACTER SET utf8,
roomID INT,
FOREIGN KEY (roomID) REFERENCES room_info (id)
ON DELETE CASCADE,
userID INT,
FOREIGN KEY (userID) REFERENCES user_info (id)
ON DELETE SET NULL,
messageIndex INT NOT NULL
);
CREATE TABLE IF NOT EXISTS message_readings(
roomID INT,
userID INT,
count INT,
FOREIGN KEY (roomID) REFERENCES room_info (id)
ON DELETE CASCADE,
FOREIGN KEY (userID) REFERENCES user_info (id)
ON DELETE CASCADE,
primary key (roomID, userID)
);
CREATE TABLE IF NOT EXISTS group_roles(
id INT,
name VARCHAR(100)
CHARACTER SET utf8,
primary key (id)
);
CREATE TABLE IF NOT EXISTS user_group_roles(
roomID INT,
userID INT,
roleID INT,
FOREIGN KEY (roomID) REFERENCES room_info (id)
ON DELETE CASCADE,
FOREIGN KEY (userID) REFERENCES user_info (id)
ON DELETE CASCADE,
FOREIGN KEY (roleID) REFERENCES group_roles (id)
ON DELETE CASCADE,
primary key (roomID, userID, roleID)
);