-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase.py
More file actions
66 lines (61 loc) · 1.77 KB
/
database.py
File metadata and controls
66 lines (61 loc) · 1.77 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
# Database initialization
import sqlite3
conn = sqlite3.connect("osu_pass.db")
cursor = conn.cursor()
cursor.execute("""
CREATE TABLE IF NOT EXISTS users (
discord_id INTEGER PRIMARY KEY,
osu_id INTEGER UNIQUE NOT NULL,
total_performance_points INTEGER DEFAULT 0,
discord_name TEXT NOT NULL,
osu_name TEXT NOT NULL
)
""")
cursor.execute("""
CREATE TABLE IF NOT EXISTS maps (
map_id INTEGER PRIMARY KEY,
performance_points REAL NOT NULL DEFAULT 0,
hr_mult REAL NOT NULL DEFAULT 1.2,
dt_mult REAL NOT NULL DEFAULT 1.5,
ez_mult REAL NOT NULL DEFAULT 0,
ht_mult REAL NOT NULL DEFAULT 0,
fl_mult REAL NOT NULL DEFAULT 2,
map_name TEXT NOT NULL,
diff_name TEXT NOT NULL,
sr_nm REAL NOT NULL,
sr_hr REAL NOT NULL,
sr_dt REAL NOT NULL,
sr_ez REAL NOT NULL DEFAULT 0,
sr_fl REAL NOT NULL,
sr_ht REAL NOT NULL DEFAULT 0,
sr_htez REAL NOT NULL DEFAULT 0,
sr_hthr REAL NOT NULL DEFAULT 0,
sr_hrdt REAL NOT NULL,
sr_ezdt REAL NOT NULL DEFAULT 0,
sr_dtfl REAL NOT NULL,
sr_hrfl REAL NOT NULL,
sr_ezfl REAL NOT NULL DEFAULT 0,
sr_htfl REAL NOT NULL DEFAULT 0,
sr_hrdtfl REAL NOT NULL,
sr_ezdtfl REAL NOT NULL DEFAULT 0,
sr_hrhtfl REAL NOT NULL DEFAULT 0,
sr_ezhtfl REAL NOT NULL DEFAULT 0,
map_rank INTEGER NOT NULL,
top_acc REAL
)
""")
cursor.execute("""
CREATE TABLE IF NOT EXISTS scores (
score_id INTEGER PRIMARY KEY,
user_osu_id INTEGER NOT NULL,
map_id INTEGER NOT NULL,
performance_points REAL NOT NULL,
mods TEXT,
star_rating REAL NOT NULL,
accuracy REAL NOT NULL,
FOREIGN KEY (user_osu_id) REFERENCES users(osu_id) ON DELETE CASCADE,
FOREIGN KEY (map_id) REFERENCES maps(map_id)
)
""")
conn.commit()
conn.close()