6a1430ef9e3a68ef82a14f41b9cf0140ed475480
[lhc/web/wiklou.git] / tests / phpunit / includes / db / sqlite / tables-1.15.sql
1 -- This is a copy of MediaWiki 1.15 schema shared by MySQL and SQLite.
2 -- It is used for updater testing. Comments are stripped to decrease
3 -- file size, as we don't need to maintain it.
4
5 CREATE TABLE /*_*/user (
6 user_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
7 user_name varchar(255) binary NOT NULL default '',
8 user_real_name varchar(255) binary NOT NULL default '',
9 user_password tinyblob NOT NULL,
10 user_newpassword tinyblob NOT NULL,
11 user_newpass_time binary(14),
12 user_email tinytext NOT NULL,
13 user_touched binary(14) NOT NULL default '',
14 user_token binary(32) NOT NULL default '',
15 user_email_authenticated binary(14),
16 user_email_token binary(32),
17 user_email_token_expires binary(14),
18 user_registration binary(14),
19 user_editcount int
20 ) /*$wgDBTableOptions*/;
21 CREATE UNIQUE INDEX /*i*/user_name ON /*_*/user (user_name);
22 CREATE INDEX /*i*/user_email_token ON /*_*/user (user_email_token);
23 CREATE TABLE /*_*/user_groups (
24 ug_user int unsigned NOT NULL default 0,
25 ug_group varbinary(16) NOT NULL default ''
26 ) /*$wgDBTableOptions*/;
27 CREATE UNIQUE INDEX /*i*/ug_user_group ON /*_*/user_groups (ug_user,ug_group);
28 CREATE INDEX /*i*/ug_group ON /*_*/user_groups (ug_group);
29 CREATE TABLE /*_*/user_newtalk (
30 user_id int NOT NULL default 0,
31 user_ip varbinary(40) NOT NULL default '',
32 user_last_timestamp binary(14) NOT NULL default ''
33 ) /*$wgDBTableOptions*/;
34 CREATE INDEX /*i*/un_user_id ON /*_*/user_newtalk (user_id);
35 CREATE INDEX /*i*/un_user_ip ON /*_*/user_newtalk (user_ip);
36 CREATE TABLE /*_*/page (
37 page_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
38 page_namespace int NOT NULL,
39 page_title varchar(255) binary NOT NULL,
40 page_restrictions tinyblob NOT NULL,
41 page_counter bigint unsigned NOT NULL default 0,
42 page_is_redirect tinyint unsigned NOT NULL default 0,
43 page_is_new tinyint unsigned NOT NULL default 0,
44 page_random real unsigned NOT NULL,
45 page_touched binary(14) NOT NULL default '',
46 page_latest int unsigned NOT NULL,
47 page_len int unsigned NOT NULL
48 ) /*$wgDBTableOptions*/;
49 CREATE UNIQUE INDEX /*i*/name_title ON /*_*/page (page_namespace,page_title);
50 CREATE INDEX /*i*/page_random ON /*_*/page (page_random);
51 CREATE INDEX /*i*/page_len ON /*_*/page (page_len);
52 CREATE TABLE /*_*/revision (
53 rev_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
54 rev_page int unsigned NOT NULL,
55 rev_text_id int unsigned NOT NULL,
56 rev_comment tinyblob NOT NULL,
57 rev_user int unsigned NOT NULL default 0,
58 rev_user_text varchar(255) binary NOT NULL default '',
59 rev_timestamp binary(14) NOT NULL default '',
60 rev_minor_edit tinyint unsigned NOT NULL default 0,
61 rev_deleted tinyint unsigned NOT NULL default 0,
62 rev_len int unsigned,
63 rev_parent_id int unsigned default NULL
64 ) /*$wgDBTableOptions*/ MAX_ROWS=10000000 AVG_ROW_LENGTH=1024;
65 CREATE UNIQUE INDEX /*i*/rev_page_id ON /*_*/revision (rev_page, rev_id);
66 CREATE INDEX /*i*/rev_timestamp ON /*_*/revision (rev_timestamp);
67 CREATE INDEX /*i*/page_timestamp ON /*_*/revision (rev_page,rev_timestamp);
68 CREATE INDEX /*i*/user_timestamp ON /*_*/revision (rev_user,rev_timestamp);
69 CREATE INDEX /*i*/usertext_timestamp ON /*_*/revision (rev_user_text,rev_timestamp);
70 CREATE TABLE /*_*/text (
71 old_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
72 old_text mediumblob NOT NULL,
73 old_flags tinyblob NOT NULL
74 ) /*$wgDBTableOptions*/ MAX_ROWS=10000000 AVG_ROW_LENGTH=10240;
75 CREATE TABLE /*_*/archive (
76 ar_namespace int NOT NULL default 0,
77 ar_title varchar(255) binary NOT NULL default '',
78 ar_text mediumblob NOT NULL,
79 ar_comment tinyblob NOT NULL,
80 ar_user int unsigned NOT NULL default 0,
81 ar_user_text varchar(255) binary NOT NULL,
82 ar_timestamp binary(14) NOT NULL default '',
83 ar_minor_edit tinyint NOT NULL default 0,
84 ar_flags tinyblob NOT NULL,
85 ar_rev_id int unsigned,
86 ar_text_id int unsigned,
87 ar_deleted tinyint unsigned NOT NULL default 0,
88 ar_len int unsigned,
89 ar_page_id int unsigned,
90 ar_parent_id int unsigned default NULL
91 ) /*$wgDBTableOptions*/;
92 CREATE INDEX /*i*/name_title_timestamp ON /*_*/archive (ar_namespace,ar_title,ar_timestamp);
93 CREATE INDEX /*i*/ar_usertext_timestamp ON /*_*/archive (ar_user_text,ar_timestamp);
94 CREATE TABLE /*_*/pagelinks (
95 pl_from int unsigned NOT NULL default 0,
96 pl_namespace int NOT NULL default 0,
97 pl_title varchar(255) binary NOT NULL default ''
98 ) /*$wgDBTableOptions*/;
99 CREATE UNIQUE INDEX /*i*/pl_from ON /*_*/pagelinks (pl_from,pl_namespace,pl_title);
100 CREATE UNIQUE INDEX /*i*/pl_namespace ON /*_*/pagelinks (pl_namespace,pl_title,pl_from);
101 CREATE TABLE /*_*/templatelinks (
102 tl_from int unsigned NOT NULL default 0,
103 tl_namespace int NOT NULL default 0,
104 tl_title varchar(255) binary NOT NULL default ''
105 ) /*$wgDBTableOptions*/;
106 CREATE UNIQUE INDEX /*i*/tl_from ON /*_*/templatelinks (tl_from,tl_namespace,tl_title);
107 CREATE UNIQUE INDEX /*i*/tl_namespace ON /*_*/templatelinks (tl_namespace,tl_title,tl_from);
108 CREATE TABLE /*_*/imagelinks (
109 il_from int unsigned NOT NULL default 0,
110 il_to varchar(255) binary NOT NULL default ''
111 ) /*$wgDBTableOptions*/;
112 CREATE UNIQUE INDEX /*i*/il_from ON /*_*/imagelinks (il_from,il_to);
113 CREATE UNIQUE INDEX /*i*/il_to ON /*_*/imagelinks (il_to,il_from);
114 CREATE TABLE /*_*/categorylinks (
115 cl_from int unsigned NOT NULL default 0,
116 cl_to varchar(255) binary NOT NULL default '',
117 cl_sortkey varchar(70) binary NOT NULL default '',
118 cl_timestamp timestamp NOT NULL
119 ) /*$wgDBTableOptions*/;
120 CREATE UNIQUE INDEX /*i*/cl_from ON /*_*/categorylinks (cl_from,cl_to);
121 CREATE INDEX /*i*/cl_sortkey ON /*_*/categorylinks (cl_to,cl_sortkey,cl_from);
122 CREATE INDEX /*i*/cl_timestamp ON /*_*/categorylinks (cl_to,cl_timestamp);
123 CREATE TABLE /*_*/category (
124 cat_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
125 cat_title varchar(255) binary NOT NULL,
126 cat_pages int signed NOT NULL default 0,
127 cat_subcats int signed NOT NULL default 0,
128 cat_files int signed NOT NULL default 0,
129 cat_hidden tinyint unsigned NOT NULL default 0
130 ) /*$wgDBTableOptions*/;
131 CREATE UNIQUE INDEX /*i*/cat_title ON /*_*/category (cat_title);
132 CREATE INDEX /*i*/cat_pages ON /*_*/category (cat_pages);
133 CREATE TABLE /*_*/externallinks (
134 el_from int unsigned NOT NULL default 0,
135 el_to blob NOT NULL,
136 el_index blob NOT NULL
137 ) /*$wgDBTableOptions*/;
138 CREATE INDEX /*i*/el_from ON /*_*/externallinks (el_from, el_to(40));
139 CREATE INDEX /*i*/el_to ON /*_*/externallinks (el_to(60), el_from);
140 CREATE INDEX /*i*/el_index ON /*_*/externallinks (el_index(60));
141 CREATE TABLE /*_*/langlinks (
142 ll_from int unsigned NOT NULL default 0,
143
144 ll_lang varbinary(20) NOT NULL default '',
145 ll_title varchar(255) binary NOT NULL default ''
146 ) /*$wgDBTableOptions*/;
147 CREATE UNIQUE INDEX /*i*/ll_from ON /*_*/langlinks (ll_from, ll_lang);
148 CREATE INDEX /*i*/ll_lang ON /*_*/langlinks (ll_lang, ll_title);
149 CREATE TABLE /*_*/site_stats (
150 ss_row_id int unsigned NOT NULL,
151 ss_total_views bigint unsigned default 0,
152 ss_total_edits bigint unsigned default 0,
153 ss_good_articles bigint unsigned default 0,
154 ss_total_pages bigint default '-1',
155 ss_users bigint default '-1',
156 ss_active_users bigint default '-1',
157 ss_admins int default '-1',
158 ss_images int default 0
159 ) /*$wgDBTableOptions*/;
160 CREATE UNIQUE INDEX /*i*/ss_row_id ON /*_*/site_stats (ss_row_id);
161 CREATE TABLE /*_*/hitcounter (
162 hc_id int unsigned NOT NULL
163 ) ENGINE=HEAP MAX_ROWS=25000;
164 CREATE TABLE /*_*/ipblocks (
165 ipb_id int NOT NULL PRIMARY KEY AUTO_INCREMENT,
166 ipb_address tinyblob NOT NULL,
167 ipb_user int unsigned NOT NULL default 0,
168 ipb_by int unsigned NOT NULL default 0,
169 ipb_by_text varchar(255) binary NOT NULL default '',
170 ipb_reason tinyblob NOT NULL,
171 ipb_timestamp binary(14) NOT NULL default '',
172 ipb_auto bool NOT NULL default 0,
173 ipb_anon_only bool NOT NULL default 0,
174 ipb_create_account bool NOT NULL default 1,
175 ipb_enable_autoblock bool NOT NULL default '1',
176 ipb_expiry varbinary(14) NOT NULL default '',
177 ipb_range_start tinyblob NOT NULL,
178 ipb_range_end tinyblob NOT NULL,
179 ipb_deleted bool NOT NULL default 0,
180 ipb_block_email bool NOT NULL default 0,
181 ipb_allow_usertalk bool NOT NULL default 0
182 ) /*$wgDBTableOptions*/;
183
184 CREATE UNIQUE INDEX /*i*/ipb_address ON /*_*/ipblocks (ipb_address(255), ipb_user, ipb_auto, ipb_anon_only);
185 CREATE INDEX /*i*/ipb_user ON /*_*/ipblocks (ipb_user);
186 CREATE INDEX /*i*/ipb_range ON /*_*/ipblocks (ipb_range_start(8), ipb_range_end(8));
187 CREATE INDEX /*i*/ipb_timestamp ON /*_*/ipblocks (ipb_timestamp);
188 CREATE INDEX /*i*/ipb_expiry ON /*_*/ipblocks (ipb_expiry);
189 CREATE TABLE /*_*/image (
190 img_name varchar(255) binary NOT NULL default '' PRIMARY KEY,
191 img_size int unsigned NOT NULL default 0,
192 img_width int NOT NULL default 0,
193 img_height int NOT NULL default 0,
194 img_metadata mediumblob NOT NULL,
195 img_bits int NOT NULL default 0,
196 img_media_type ENUM("UNKNOWN", "BITMAP", "DRAWING", "AUDIO", "VIDEO", "MULTIMEDIA", "OFFICE", "TEXT", "EXECUTABLE", "ARCHIVE") default NULL,
197 img_major_mime ENUM("unknown", "application", "audio", "image", "text", "video", "message", "model", "multipart") NOT NULL default "unknown",
198 img_minor_mime varbinary(32) NOT NULL default "unknown",
199 img_description tinyblob NOT NULL,
200 img_user int unsigned NOT NULL default 0,
201 img_user_text varchar(255) binary NOT NULL,
202 img_timestamp varbinary(14) NOT NULL default '',
203 img_sha1 varbinary(32) NOT NULL default ''
204 ) /*$wgDBTableOptions*/;
205 CREATE INDEX /*i*/img_usertext_timestamp ON /*_*/image (img_user_text,img_timestamp);
206 CREATE INDEX /*i*/img_size ON /*_*/image (img_size);
207 CREATE INDEX /*i*/img_timestamp ON /*_*/image (img_timestamp);
208 CREATE INDEX /*i*/img_sha1 ON /*_*/image (img_sha1);
209 CREATE TABLE /*_*/oldimage (
210 oi_name varchar(255) binary NOT NULL default '',
211 oi_archive_name varchar(255) binary NOT NULL default '',
212 oi_size int unsigned NOT NULL default 0,
213 oi_width int NOT NULL default 0,
214 oi_height int NOT NULL default 0,
215 oi_bits int NOT NULL default 0,
216 oi_description tinyblob NOT NULL,
217 oi_user int unsigned NOT NULL default 0,
218 oi_user_text varchar(255) binary NOT NULL,
219 oi_timestamp binary(14) NOT NULL default '',
220 oi_metadata mediumblob NOT NULL,
221 oi_media_type ENUM("UNKNOWN", "BITMAP", "DRAWING", "AUDIO", "VIDEO", "MULTIMEDIA", "OFFICE", "TEXT", "EXECUTABLE", "ARCHIVE") default NULL,
222 oi_major_mime ENUM("unknown", "application", "audio", "image", "text", "video", "message", "model", "multipart") NOT NULL default "unknown",
223 oi_minor_mime varbinary(32) NOT NULL default "unknown",
224 oi_deleted tinyint unsigned NOT NULL default 0,
225 oi_sha1 varbinary(32) NOT NULL default ''
226 ) /*$wgDBTableOptions*/;
227 CREATE INDEX /*i*/oi_usertext_timestamp ON /*_*/oldimage (oi_user_text,oi_timestamp);
228 CREATE INDEX /*i*/oi_name_timestamp ON /*_*/oldimage (oi_name,oi_timestamp);
229 CREATE INDEX /*i*/oi_name_archive_name ON /*_*/oldimage (oi_name,oi_archive_name(14));
230 CREATE INDEX /*i*/oi_sha1 ON /*_*/oldimage (oi_sha1);
231 CREATE TABLE /*_*/filearchive (
232 fa_id int NOT NULL PRIMARY KEY AUTO_INCREMENT,
233 fa_name varchar(255) binary NOT NULL default '',
234 fa_archive_name varchar(255) binary default '',
235 fa_storage_group varbinary(16),
236 fa_storage_key varbinary(64) default '',
237 fa_deleted_user int,
238 fa_deleted_timestamp binary(14) default '',
239 fa_deleted_reason text,
240 fa_size int unsigned default 0,
241 fa_width int default 0,
242 fa_height int default 0,
243 fa_metadata mediumblob,
244 fa_bits int default 0,
245 fa_media_type ENUM("UNKNOWN", "BITMAP", "DRAWING", "AUDIO", "VIDEO", "MULTIMEDIA", "OFFICE", "TEXT", "EXECUTABLE", "ARCHIVE") default NULL,
246 fa_major_mime ENUM("unknown", "application", "audio", "image", "text", "video", "message", "model", "multipart") default "unknown",
247 fa_minor_mime varbinary(32) default "unknown",
248 fa_description tinyblob,
249 fa_user int unsigned default 0,
250 fa_user_text varchar(255) binary,
251 fa_timestamp binary(14) default '',
252 fa_deleted tinyint unsigned NOT NULL default 0
253 ) /*$wgDBTableOptions*/;
254 CREATE INDEX /*i*/fa_name ON /*_*/filearchive (fa_name, fa_timestamp);
255 CREATE INDEX /*i*/fa_storage_group ON /*_*/filearchive (fa_storage_group, fa_storage_key);
256 CREATE INDEX /*i*/fa_deleted_timestamp ON /*_*/filearchive (fa_deleted_timestamp);
257 CREATE INDEX /*i*/fa_user_timestamp ON /*_*/filearchive (fa_user_text,fa_timestamp);
258 CREATE TABLE /*_*/recentchanges (
259 rc_id int NOT NULL PRIMARY KEY AUTO_INCREMENT,
260 rc_timestamp varbinary(14) NOT NULL default '',
261 rc_cur_time varbinary(14) NOT NULL default '',
262 rc_user int unsigned NOT NULL default 0,
263 rc_user_text varchar(255) binary NOT NULL,
264 rc_namespace int NOT NULL default 0,
265 rc_title varchar(255) binary NOT NULL default '',
266 rc_comment varchar(255) binary NOT NULL default '',
267 rc_minor tinyint unsigned NOT NULL default 0,
268 rc_bot tinyint unsigned NOT NULL default 0,
269 rc_new tinyint unsigned NOT NULL default 0,
270 rc_cur_id int unsigned NOT NULL default 0,
271 rc_this_oldid int unsigned NOT NULL default 0,
272 rc_last_oldid int unsigned NOT NULL default 0,
273 rc_type tinyint unsigned NOT NULL default 0,
274 rc_moved_to_ns tinyint unsigned NOT NULL default 0,
275 rc_moved_to_title varchar(255) binary NOT NULL default '',
276 rc_patrolled tinyint unsigned NOT NULL default 0,
277 rc_ip varbinary(40) NOT NULL default '',
278 rc_old_len int,
279 rc_new_len int,
280 rc_deleted tinyint unsigned NOT NULL default 0,
281 rc_logid int unsigned NOT NULL default 0,
282 rc_log_type varbinary(255) NULL default NULL,
283 rc_log_action varbinary(255) NULL default NULL,
284 rc_params blob NULL
285 ) /*$wgDBTableOptions*/;
286 CREATE INDEX /*i*/rc_timestamp ON /*_*/recentchanges (rc_timestamp);
287 CREATE INDEX /*i*/rc_namespace_title ON /*_*/recentchanges (rc_namespace, rc_title);
288 CREATE INDEX /*i*/rc_cur_id ON /*_*/recentchanges (rc_cur_id);
289 CREATE INDEX /*i*/new_name_timestamp ON /*_*/recentchanges (rc_new,rc_namespace,rc_timestamp);
290 CREATE INDEX /*i*/rc_ip ON /*_*/recentchanges (rc_ip);
291 CREATE INDEX /*i*/rc_ns_usertext ON /*_*/recentchanges (rc_namespace, rc_user_text);
292 CREATE INDEX /*i*/rc_user_text ON /*_*/recentchanges (rc_user_text, rc_timestamp);
293 CREATE TABLE /*_*/watchlist (
294 wl_user int unsigned NOT NULL,
295 wl_namespace int NOT NULL default 0,
296 wl_title varchar(255) binary NOT NULL default '',
297 wl_notificationtimestamp varbinary(14)
298 ) /*$wgDBTableOptions*/;
299 CREATE UNIQUE INDEX /*i*/wl_user ON /*_*/watchlist (wl_user, wl_namespace, wl_title);
300 CREATE INDEX /*i*/namespace_title ON /*_*/watchlist (wl_namespace, wl_title);
301 CREATE TABLE /*_*/math (
302 math_inputhash varbinary(16) NOT NULL,
303 math_outputhash varbinary(16) NOT NULL,
304 math_html_conservativeness tinyint NOT NULL,
305 math_html text,
306 math_mathml text
307 ) /*$wgDBTableOptions*/;
308 CREATE UNIQUE INDEX /*i*/math_inputhash ON /*_*/math (math_inputhash);
309 CREATE TABLE /*_*/searchindex (
310 si_page int unsigned NOT NULL,
311 si_title varchar(255) NOT NULL default '',
312 si_text mediumtext NOT NULL
313 ) ENGINE=MyISAM;
314 CREATE UNIQUE INDEX /*i*/si_page ON /*_*/searchindex (si_page);
315 CREATE FULLTEXT INDEX /*i*/si_title ON /*_*/searchindex (si_title);
316 CREATE FULLTEXT INDEX /*i*/si_text ON /*_*/searchindex (si_text);
317 CREATE TABLE /*_*/interwiki (
318 iw_prefix varchar(32) NOT NULL,
319 iw_url blob NOT NULL,
320 iw_local bool NOT NULL,
321 iw_trans tinyint NOT NULL default 0
322 ) /*$wgDBTableOptions*/;
323 CREATE UNIQUE INDEX /*i*/iw_prefix ON /*_*/interwiki (iw_prefix);
324 CREATE TABLE /*_*/querycache (
325 qc_type varbinary(32) NOT NULL,
326 qc_value int unsigned NOT NULL default 0,
327 qc_namespace int NOT NULL default 0,
328 qc_title varchar(255) binary NOT NULL default ''
329 ) /*$wgDBTableOptions*/;
330 CREATE INDEX /*i*/qc_type ON /*_*/querycache (qc_type,qc_value);
331 CREATE TABLE /*_*/objectcache (
332 keyname varbinary(255) NOT NULL default '' PRIMARY KEY,
333 value mediumblob,
334 exptime datetime
335 ) /*$wgDBTableOptions*/;
336 CREATE INDEX /*i*/exptime ON /*_*/objectcache (exptime);
337 CREATE TABLE /*_*/transcache (
338 tc_url varbinary(255) NOT NULL,
339 tc_contents text,
340 tc_time int NOT NULL
341 ) /*$wgDBTableOptions*/;
342 CREATE UNIQUE INDEX /*i*/tc_url_idx ON /*_*/transcache (tc_url);
343 CREATE TABLE /*_*/logging (
344 log_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
345 log_type varbinary(10) NOT NULL default '',
346 log_action varbinary(10) NOT NULL default '',
347 log_timestamp binary(14) NOT NULL default '19700101000000',
348 log_user int unsigned NOT NULL default 0,
349 log_namespace int NOT NULL default 0,
350 log_title varchar(255) binary NOT NULL default '',
351 log_comment varchar(255) NOT NULL default '',
352 log_params blob NOT NULL,
353 log_deleted tinyint unsigned NOT NULL default 0
354 ) /*$wgDBTableOptions*/;
355 CREATE INDEX /*i*/type_time ON /*_*/logging (log_type, log_timestamp);
356 CREATE INDEX /*i*/user_time ON /*_*/logging (log_user, log_timestamp);
357 CREATE INDEX /*i*/page_time ON /*_*/logging (log_namespace, log_title, log_timestamp);
358 CREATE INDEX /*i*/times ON /*_*/logging (log_timestamp);
359 CREATE TABLE /*_*/trackbacks (
360 tb_id int PRIMARY KEY AUTO_INCREMENT,
361 tb_page int REFERENCES /*_*/page(page_id) ON DELETE CASCADE,
362 tb_title varchar(255) NOT NULL,
363 tb_url blob NOT NULL,
364 tb_ex text,
365 tb_name varchar(255)
366 ) /*$wgDBTableOptions*/;
367 CREATE INDEX /*i*/tb_page ON /*_*/trackbacks (tb_page);
368 CREATE TABLE /*_*/job (
369 job_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
370 job_cmd varbinary(60) NOT NULL default '',
371 job_namespace int NOT NULL,
372 job_title varchar(255) binary NOT NULL,
373 job_params blob NOT NULL
374 ) /*$wgDBTableOptions*/;
375 CREATE INDEX /*i*/job_cmd ON /*_*/job (job_cmd, job_namespace, job_title);
376 CREATE TABLE /*_*/querycache_info (
377 qci_type varbinary(32) NOT NULL default '',
378 qci_timestamp binary(14) NOT NULL default '19700101000000'
379 ) /*$wgDBTableOptions*/;
380 CREATE UNIQUE INDEX /*i*/qci_type ON /*_*/querycache_info (qci_type);
381 CREATE TABLE /*_*/redirect (
382 rd_from int unsigned NOT NULL default 0 PRIMARY KEY,
383 rd_namespace int NOT NULL default 0,
384 rd_title varchar(255) binary NOT NULL default ''
385 ) /*$wgDBTableOptions*/;
386 CREATE INDEX /*i*/rd_ns_title ON /*_*/redirect (rd_namespace,rd_title,rd_from);
387 CREATE TABLE /*_*/querycachetwo (
388 qcc_type varbinary(32) NOT NULL,
389 qcc_value int unsigned NOT NULL default 0,
390 qcc_namespace int NOT NULL default 0,
391 qcc_title varchar(255) binary NOT NULL default '',
392 qcc_namespacetwo int NOT NULL default 0,
393 qcc_titletwo varchar(255) binary NOT NULL default ''
394 ) /*$wgDBTableOptions*/;
395 CREATE INDEX /*i*/qcc_type ON /*_*/querycachetwo (qcc_type,qcc_value);
396 CREATE INDEX /*i*/qcc_title ON /*_*/querycachetwo (qcc_type,qcc_namespace,qcc_title);
397 CREATE INDEX /*i*/qcc_titletwo ON /*_*/querycachetwo (qcc_type,qcc_namespacetwo,qcc_titletwo);
398 CREATE TABLE /*_*/page_restrictions (
399 pr_page int NOT NULL,
400 pr_type varbinary(60) NOT NULL,
401 pr_level varbinary(60) NOT NULL,
402 pr_cascade tinyint NOT NULL,
403 pr_user int NULL,
404 pr_expiry varbinary(14) NULL,
405 pr_id int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT
406 ) /*$wgDBTableOptions*/;
407 CREATE UNIQUE INDEX /*i*/pr_pagetype ON /*_*/page_restrictions (pr_page,pr_type);
408 CREATE INDEX /*i*/pr_typelevel ON /*_*/page_restrictions (pr_type,pr_level);
409 CREATE INDEX /*i*/pr_level ON /*_*/page_restrictions (pr_level);
410 CREATE INDEX /*i*/pr_cascade ON /*_*/page_restrictions (pr_cascade);
411 CREATE TABLE /*_*/protected_titles (
412 pt_namespace int NOT NULL,
413 pt_title varchar(255) binary NOT NULL,
414 pt_user int unsigned NOT NULL,
415 pt_reason tinyblob,
416 pt_timestamp binary(14) NOT NULL,
417 pt_expiry varbinary(14) NOT NULL default '',
418 pt_create_perm varbinary(60) NOT NULL
419 ) /*$wgDBTableOptions*/;
420 CREATE UNIQUE INDEX /*i*/pt_namespace_title ON /*_*/protected_titles (pt_namespace,pt_title);
421 CREATE INDEX /*i*/pt_timestamp ON /*_*/protected_titles (pt_timestamp);
422 CREATE TABLE /*_*/page_props (
423 pp_page int NOT NULL,
424 pp_propname varbinary(60) NOT NULL,
425 pp_value blob NOT NULL
426 ) /*$wgDBTableOptions*/;
427 CREATE UNIQUE INDEX /*i*/pp_page_propname ON /*_*/page_props (pp_page,pp_propname);
428 CREATE TABLE /*_*/updatelog (
429 ul_key varchar(255) NOT NULL PRIMARY KEY
430 ) /*$wgDBTableOptions*/;
431 CREATE TABLE /*_*/change_tag (
432 ct_rc_id int NULL,
433 ct_log_id int NULL,
434 ct_rev_id int NULL,
435 ct_tag varchar(255) NOT NULL,
436 ct_params blob NULL
437 ) /*$wgDBTableOptions*/;
438 CREATE UNIQUE INDEX /*i*/change_tag_rc_tag ON /*_*/change_tag (ct_rc_id,ct_tag);
439 CREATE UNIQUE INDEX /*i*/change_tag_log_tag ON /*_*/change_tag (ct_log_id,ct_tag);
440 CREATE UNIQUE INDEX /*i*/change_tag_rev_tag ON /*_*/change_tag (ct_rev_id,ct_tag);
441 CREATE INDEX /*i*/change_tag_tag_id ON /*_*/change_tag (ct_tag,ct_rc_id,ct_rev_id,ct_log_id);
442 CREATE TABLE /*_*/tag_summary (
443 ts_rc_id int NULL,
444 ts_log_id int NULL,
445 ts_rev_id int NULL,
446 ts_tags blob NOT NULL
447 ) /*$wgDBTableOptions*/;
448 CREATE UNIQUE INDEX /*i*/tag_summary_rc_id ON /*_*/tag_summary (ts_rc_id);
449 CREATE UNIQUE INDEX /*i*/tag_summary_log_id ON /*_*/tag_summary (ts_log_id);
450 CREATE UNIQUE INDEX /*i*/tag_summary_rev_id ON /*_*/tag_summary (ts_rev_id);
451 CREATE TABLE /*_*/valid_tag (
452 vt_tag varchar(255) NOT NULL PRIMARY KEY
453 ) /*$wgDBTableOptions*/;