-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmm_schema.sql
65 lines (60 loc) · 1.91 KB
/
mm_schema.sql
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
# Music Match database
# Based on a BOINC database
#
# user table fields:
# send_email: notification email frequency (see notification.inc)
# expavg_time: when last email was sent
# seti_id: verification code during registration
# seti_total_cpu: last visit time
# an ensemble (performing group)
# Info is kept in ensemble/ID.json
#
create table ensemble (
id integer not null auto_increment,
create_time double not null,
user_id integer not null,
name varchar(255) not null default '',
unique(name),
primary key (id)
) engine = InnoDB;
create table ensemble_member (
create_time double not null,
ensemble_id integer not null,
user_id integer not null,
status tinyint not null,
# 0 pending approval
# 1 approved (user is member)
# 2 declined
# 3 removed
unique(ensemble_id, user_id)
) engine = InnoDB;
# BOINC notify table:
# id
# userid
# create_time
# type
# opaque
alter table notify
add column sent_by_email double not null default 0,
add column last_view double not null default 0,
add column id2 integer not null default 0,
add unique notify_un (userid, type, opaque, id2)
;
# a search and its results
#
create table search (
id integer not null auto_increment,
create_time double not null,
user_id integer not null,
params text not null,
# role, search args in JSON
params_hash char(64) not null,
view_results text not null,
view_time double not null,
rerun_time double not null default 0,
# when we last reran the search
rerun_nnew integer not null default 0,
# number of new results found on rerun, relative to view_results
unique(user_id, params_hash),
primary key (id)
) engine = InnoDB;