annotate database/schema/classify.sql @ 14:dfd62aad74f4

note that the test environment hasn't been merged into this tree yet. (from last Feb.)
author David A. Holland
date Mon, 03 Sep 2012 13:41:57 -0400
parents d42c0db81e28
children ca4679ac4e02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
1 --
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
2 -- Classification.
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
3 --
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
4 --
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
5 -- Sorting and classifying bug reports usefully is a nontrivial
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
6 -- problem. For this reason, rather than bake in any particular
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
7 -- taxonomy, we allow multiple arbitrary classification schemes,
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
8 -- all of which are created equal. (Administratively, some will
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
9 -- be more equal than others, but that does not concern the
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
10 -- database.)
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
11 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
12 -- There are several classification schemes/taxonomies that already
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
13 -- exist or have been invented but not yet deployed. These fall into
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
14 -- the following categories:
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
15 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
16 -- 1. Hierarchical taxonomy. The only existing hierarchical taxonomy
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
17 -- is the one dholland uses in the out-of-GNATS PR lists, which
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
18 -- classifies PRs by location in the system. A second projected one is
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
19 -- classification by consequences (crashes, hangs, etc.) The possible
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
20 -- classifications are defined in advance and stored in the database.
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
21 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
22 -- 2. Flat taxonomy, that is, a selection from an enumeration of
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
23 -- values. Existing schemes of this type include:
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
24 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
25 -- * the old GNATS scheme of categories (bin, kern, lib, etc.)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
26 -- * the old GNATS scheme of classes (sw-bug, doc-bug, etc.)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
27 -- * the old GNATS severity field (critical, serious, non-critical)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
28 -- * the old GNATS priority field (high, medium, low)
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
29 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
30 -- For these the possible values are defined in advance and stored in
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
31 -- the database.
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
32 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
33 -- 3. String value. Most of the time this is really a flat taxonomy
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
34 -- where the number of possible values is large or changes dynamically
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
35 -- with external circumstances, or both, such that storing a copy of
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
36 -- the legal values in the database would create a maintenanc hassle.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
37 -- There are none of these at present; the only projected one at the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
38 -- moment is FreeBSD's idea of "the nearest man page to where the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
39 -- problem appears to be".
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
40 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
41 -- 4. Systems of tags, that is, zero or more selections from a list
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
42 -- of possible values. Current schemes of this type include the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
43 -- [456]-ONLY tags, the 6-CRITICAL/6-IMPORTANT/etc. release branch
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
44 -- tags, the STUCK tag, EASY, PATCH, PULLUPS-NEEDED, etc. Some of
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
45 -- these should be separate flat taxonomy schemes rather than tags,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
46 -- and some of them should maybe be states rather than tags too.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
47 -- (And, perhaps some of the current states should be tags...)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
48 -- In addition we want to allow every developer to have their own
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
49 -- private tags that aren't exposed. And, we might want to have
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
50 -- project-only tags that other developers can see but users can't.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
51 -- (It remains to be seen if that's really a good idea.)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
52 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
53 -- Note also that a list of PRs is equivalent to a tag on those PRs.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
54 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
55 -- It is also possible that there may be additional classifications
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
56 -- (possibly of any of the above types, but most likely tags) that are
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
57 -- views rather than data, that is, derived from other information.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
58 -- One example of this is "PRs in feedback more than 6 months".
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
59 --
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
60 --
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
61 -- We assume that new classification schemes will be added on the fly,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
62 -- not frequently, but frequently enough that the list of schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
63 -- should not be hard-coded into programs that access the database,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
64 -- and we don't want to have to create a new table for each new scheme
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
65 -- either.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
66 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
67 -- Therefore, the way I'll do this is to create one table (or rather,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
68 -- one family of tables) for each type of classification scheme, and
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
69 -- make them able to handle arbitrary instances.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
70 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
71 -- For hierarchical schemes there is no point trying to encode the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
72 -- hierarchical structure in SQL; that is a waste of time. Instead
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
73 -- we'll expand the tree of allowed values and rely on the access
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
74 -- software to present the schemes sensibly.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
75 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
76 -- It remains unclear what views ought to be defined.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
77 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
78 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
79 -- Notes on the representations:
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
80 -- * a scheme is "total" if it should be defined on all PRs
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
81 -- * if the data contains a null value for a particular scheme,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
82 -- that means "not specified yet".
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
83 -- * the hierarchical and flat schemes are no different schema-
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
84 -- wise but are separate to allow different handling in software.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
85 -- * the ordering field in the values tables should be used so that
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
86 -- ORDER BY ordering ASCENDING produces the desired output order
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
87 -- of the legal values.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
88 -- * the obsolete field for values is for entries that are allowed
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
89 -- to still exist in the database but that should not be used
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
90 -- with new PRs or for new classifications of old PRs.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
91 -- * the ordering field for the classifications themselves should
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
92 -- be used so that ORDER BY ordering ASCENDING produces the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
93 -- desired output order of the classification schemes. The
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
94 -- numbers are global across classification scheme types so
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
95 -- schemes of the same type do not need to be sorted together.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
96 --
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
97 --
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
98
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
99 ------------------------------------------------------------
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
100 -- Hierarchical schemes.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
101
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
102 -- names and properties of the hierarchical schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
103 CREATE TABLE hierclass_names (
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
104 name text primary key,
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
105 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
106 total boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
107 description text not null
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
108 )
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
109 WITHOUT OIDS;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
110
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
111 -- allowed values of the hierarchical schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
112 CREATE TABLE hierclass_values (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
113 scheme text not null references hierclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
114 value text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
115 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
116 obsolete boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
117 description text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
118 primary key (scheme, value)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
119 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
120 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
121
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
122 -- classification of PRs according to the hierarchical schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
123 CREATE TABLE hierclass_data (
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
124 pr bigint not null references PRs (id),
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
125 scheme text not null references hierclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
126 value text ,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
127 primary key (pr, scheme),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
128 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
129 -- what I want here is for it to reference hierclass_values unless
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
130 -- the value is null. or should the values table include a row
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
131 -- with null value where that's allowed? I forget how null values
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
132 -- interoperate with reference constraints except that it's messy.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
133 -- XXX. (if changing this change the similar logic below as well)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
134 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
135 constraint (scheme, value) references hierclass_values (scheme, value)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
136 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
137 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
138
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
139 ------------------------------------------------------------
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
140 -- Enumerated flat schemes.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
141
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
142 -- names and properties of the flat schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
143 CREATE TABLE flatclass_names (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
144 name text primary key,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
145 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
146 total boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
147 description text not null
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
148 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
149 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
150
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
151 -- allowed values of the flat schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
152 CREATE TABLE flatclass_values (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
153 scheme text not null references flatclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
154 value text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
155 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
156 obsolete boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
157 description text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
158 primary key (scheme, value)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
159 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
160 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
161
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
162 -- classification of PRs according to the flat schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
163 CREATE TABLE flatclass_data (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
164 pr bigint not null references PRs (id),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
165 scheme text not null references flatclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
166 value text ,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
167 primary key (pr, scheme),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
168 -- as above
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
169 constraint (scheme, value) references flatclass_values (scheme, value)
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
170 )
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
171 WITHOUT OIDS;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
172
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
173 ------------------------------------------------------------
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
174 -- Text schemes.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
175
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
176 -- names and properties of the text schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
177 CREATE TABLE textclass_names (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
178 name text primary key,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
179 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
180 total boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
181 description text not null
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
182 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
183 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
184
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
185 -- classification of PRs according to the text schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
186 CREATE TABLE textclass_data (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
187 pr bigint not null references PRs (id),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
188 scheme text not null references textclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
189 value text ,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
190 primary key (pr, scheme),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
191 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
192 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
193
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
194 ------------------------------------------------------------
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
195 -- Tag schemes.
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
196
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
197 -- names and properties of the tag schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
198 -- (total does not make sense here)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
199 CREATE TABLE tagclass_names (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
200 name text primary key,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
201 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
202 description text not null
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
203 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
204 WITHOUT OIDS;
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
205
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
206 -- allowed values of the tag schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
207 -- (each PR can reference zero or more of these)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
208 CREATE TABLE tagclass_values (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
209 scheme text not null references tagclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
210 value text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
211 ordering int not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
212 obsolete boolean not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
213 description text not null,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
214 primary key (scheme, value)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
215 )
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
216 WITHOUT OIDS;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
217
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
218 -- classification of PRs according to the tag schemes
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
219 -- (each PR/scheme pair is listed once for each tag attached to it)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
220 CREATE TABLE tagclass_data (
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
221 pr bigint not null references PRs (id),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
222 scheme text not null references tagclass_names (name),
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
223 value text ,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
224 -- as above
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
225 constraint (scheme, value) references tagclass_values (scheme, value)
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
226 )
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
227 WITHOUT OIDS;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
228
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
229 -- view where tags are collected into a string
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
230 -- XXX does concat(value) work, and if not, is there any way to do this?
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
231 CREATE VIEW tagclass_stringdata AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
232 SELECT pr, scheme, concat(value) as value
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
233 FROM tagclass_data
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
234 GROUP BY pr, scheme
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
235 ;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
236
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
237 ------------------------------------------------------------
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
238 -- some views
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
239
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
240 -- views that pull in the ordering fields.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
241 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
242 -- (If you use only one of the ordering fields, as is likely to be
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
243 -- the case in practice, I think we can rely on the query optimizer
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
244 -- to drop the join that collects in the other ordering field. If
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
245 -- not, maybe this should be restructured.)
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
246 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
247 -- XXX what do these do when _data.value is null?
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
248
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
249 CREATE VIEW hierclass_data_ordered AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
250 SELECT hierclass_data.pr as pr,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
251 hierclass_data.scheme as scheme,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
252 hierclass_names.ordering as schemeordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
253 hierclass_data.value as value,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
254 hierclass_values.ordering as valueordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
255 FROM hierclass_data, hierclass_names, hierclass_values
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
256 WHERE
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
257 hierclass_data.scheme = hierclass_names.name
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
258 AND hierclass_data.scheme = hierclass_values.scheme
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
259 AND hierclass_data.value = hierclass_values.value
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
260 ;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
261
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
262 CREATE VIEW flatclass_data_ordered AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
263 SELECT flatclass_data.pr as pr,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
264 flatclass_data.scheme as scheme,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
265 flatclass_names.ordering as schemeordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
266 flatclass_data.value as value,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
267 flatclass_values.ordering as valueordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
268 FROM flatclass_data, flatclass_names, flatclass_values
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
269 WHERE
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
270 flatclass_data.scheme = flatclass_names.name
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
271 AND flatclass_data.scheme = flatclass_values.scheme
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
272 AND flatclass_data.value = flatclass_values.value
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
273 ;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
274
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
275 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
276 -- XXX what I'd like to do here is produce textclass_data.value as
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
277 -- valueordering; then sorting by valueordering would produce the
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
278 -- desired results (the entries sorted by text order of the values).
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
279 -- That produces a type conflict though if we combine this view
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
280 -- with the other ordered views where the ordering is a number.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
281 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
282 -- Next best would be to order by textclass_data.value in this view
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
283 -- and produce the row number of the result (or some other fresh
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
284 -- sequence) as valueordering. However, I don't think that's possible.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
285 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
286 -- What's here (using a fixed value of 1) will run but it's not
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
287 -- particularly desirable.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
288 --
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
289 CREATE VIEW textclass_data_ordered AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
290 SELECT textclass_data.pr as pr,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
291 textclass_data.scheme as scheme,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
292 textclass_names.ordering as schemeordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
293 textclass_data.value as value,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
294 1 as valueordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
295 FROM textclass_data, textclass_names
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
296 WHERE
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
297 textclass_data.scheme = textclass_names.name
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
298 ;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
299
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
300 CREATE VIEW tagclass_data_ordered AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
301 SELECT tagclass_data.pr as pr,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
302 tagclass_data.scheme as scheme,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
303 tagclass_names.ordering as schemeordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
304 tagclass_data.value as value,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
305 tagclass_values.ordering as valueordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
306 FROM tagclass_data, tagclass_names, tagclass_values
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
307 WHERE
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
308 tagclass_data.scheme = tagclass_names.name
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
309 AND tagclass_data.scheme = tagclass_values.scheme
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
310 AND tagclass_data.value = tagclass_values.value
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
311 ;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
312
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
313 -- ordered version of tagclass_stringdata
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
314 -- XXX does concat(value) work, and if not, is there any way to do this?
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
315 CREATE VIEW tagclass_stringdata_ordered AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
316 SELECT pr, scheme, schemeordering,
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
317 concat(value) as value, first(valueordering) as valueordering
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
318 FROM tagclass_data
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
319 ORDER BY valueordering
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
320 GROUP BY pr, scheme
8
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
321 ;
68cc276ac118 SQL material from old tree, split up for accessibility.
David A. Holland
parents:
diff changeset
322
11
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
323
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
324 -- a view that combines all the classification data.
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
325
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
326 CREATE VIEW classifications AS
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
327 SELECT * FROM hierclass_data_ordered
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
328 UNION SELECT * FROM flatclass_data_ordered
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
329 UNION SELECT * FROM textclass_data_ordered
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
330 UNION SELECT * FROM tagclass_stringdata_ordered
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
331 ORDER BY schemeordering
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
332 ;
d42c0db81e28 Update the classification stuff.
David A. Holland
parents: 8
diff changeset
333