-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase_creation.sql
More file actions
28 lines (25 loc) · 840 Bytes
/
Copy pathdatabase_creation.sql
File metadata and controls
28 lines (25 loc) · 840 Bytes
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
-- rim of database
CREATE TABLE owner (
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
name VARCHAR(255) NOT NULL
);
CREATE TABLE device (
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
name VARCHAR(255) NOT NULL,
owner_id INTEGER NOT NULL,
FOREIGN KEY (owner_id) REFERENCES owner (id)
ON UPDATE CASCADE
ON DELETE CASCADE
);
CREATE TABLE key (
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
license_key VARCHAR(255) NOT NULL,
in_use BOOLEAN NOT NULL DEFAULT 0,
device_id INTEGER DEFAULT NULL,
FOREIGN KEY (device_id) REFERENCES device (id)
ON UPDATE CASCADE
ON DELETE SET DEFAULT
);
CREATE UNIQUE INDEX owner_name ON owner (name);
CREATE UNIQUE INDEX device_name ON device (name);
CREATE UNIQUE INDEX license_key_id ON key (license_key);