-
Notifications
You must be signed in to change notification settings - Fork 0
/
SMW_SQLITE3_Schema.sql
93 lines (81 loc) · 3.19 KB
/
SMW_SQLITE3_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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
-- SQLite3 schema for Semantic MediaWiki?
BEGIN;
CREATE TABLE smw_relations (
subject_id INTEGER NOT NULL,
subject_namespace INTEGER NOT NULL,
subject_title TEXT NOT NULL,
relation_title TEXT NOT NULL,
object_id INTEGER NULL,
object_namespace INTEGER NOT NULL,
object_title TEXT NOT NULL
);
CREATE INDEX smw_relations_index1 ON smw_relations(subject_id, relation_title);
CREATE INDEX smw_relations_index2 ON smw_relations(object_id, object_title, object_namespace);
CREATE TABLE smw_attributes (
subject_id INTEGER NOT NULL,
subject_namespace INTEGER NOT NULL,
subject_title TEXT NOT NULL,
attribute_title TEXT NOT NULL,
value_unit TEXT NOT NULL,
value_datatype TEXT NOT NULL,
value_xsd TEXT NOT NULL,
value_num FLOAT NULL
);
CREATE INDEX smw_attributes_index1 ON smw_attributes(subject_id, attribute_title);
CREATE INDEX smw_attributes_index2 ON smw_attributes(value_num, value_xsd);
CREATE TABLE smw_longstrings (
subject_id INTEGER NOT NULL,
subject_namespace INTEGER NOT NULL,
subject_title TEXT NOT NULL,
attribute_title TEXT NOT NULL,
value_blob TEXT NULL
);
CREATE INDEX smw_longstrings_index1 ON smw_longstrings(subject_id, attribute_title);
CREATE TABLE smw_nary (
subject_id INTEGER NOT NULL,
subject_namespace INTEGER NOT NULL,
subject_title TEXT NOT NULL,
attribute_title TEXT NOT NULL,
nary_key INTEGER NOT NULL
);
CREATE INDEX smw_nary_index1 ON smw_nary(subject_id, attribute_title, nary_key);
CREATE TABLE smw_nary_relations (
subject_id INTEGER NOT NULL,
nary_key INTEGER NOT NULL,
nary_pos INTEGER NOT NULL,
object_id INTEGER NULL,
object_namespace INTEGER NOT NULL,
object_title TEXT NOT NULL
);
CREATE INDEX smw_nary_relations_index1 ON smw_nary_relations(subject_id,nary_key);
CREATE INDEX smw_nary_relations_index2 ON smw_nary_relations(object_id,object_namespace,object_title);
CREATE TABLE smw_nary_attributes (
subject_id INTEGER NOT NULL,
nary_key INTEGER NOT NULL,
nary_pos INTEGER NOT NULL,
value_unit TEXT NULL,
value_xsd TEXT NOT NULL,
value_num FLOAT NULL
);
CREATE INDEX smw_nary_attributes_index1 ON smw_nary_attributes(subject_id, nary_key);
CREATE INDEX smw_nary_attributes_index2 ON smw_nary_attributes(value_num, value_xsd);
CREATE TABLE smw_nary_longstrings (
subject_id INTEGER NOT NULL,
nary_key INTEGER NOT NULL,
nary_pos INTEGER NOT NULL,
value_blob TEXT NULL
);
CREATE INDEX smw_nary_longstrings_index1 ON smw_nary_longstrings(subject_id, nary_key);
CREATE TABLE smw_specialprops (
subject_id INTEGER NOT NULL,
subject_namespace INTEGER NOT NULL,
property_id SMALLINT NOT NULL,
value_string TEXT NOT NULL
);
CREATE INDEX smw_specialprops_index1 ON smw_specialprops(subject_id, property_id);
CREATE TABLE smw_subprops (
subject_title TEXT NOT NULL,
object_title TEXT NOT NULL
);
CREATE INDEX smw_subprops_index1 ON smw_subprops(subject_title, object_title);
COMMIT;