From 183851b06bd6c52f3cae5375f433da720d410447 Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Wed, 11 Oct 2006 18:12:39 +0000 Subject: MediaWiki 1.7.1 wiederhergestellt --- maintenance/oracle/tables.sql | 333 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 333 insertions(+) create mode 100644 maintenance/oracle/tables.sql (limited to 'maintenance/oracle/tables.sql') diff --git a/maintenance/oracle/tables.sql b/maintenance/oracle/tables.sql new file mode 100644 index 00000000..6733f950 --- /dev/null +++ b/maintenance/oracle/tables.sql @@ -0,0 +1,333 @@ +-- SQL to create the initial tables for the MediaWiki database. +-- This is read and executed by the install script; you should +-- not have to run it by itself unless doing a manual install. + +CREATE SEQUENCE user_user_id_seq; + +CREATE TABLE "user" ( + user_id NUMBER(5) NOT NULL PRIMARY KEY, + user_name VARCHAR2(255) DEFAULT '' NOT NULL, + user_real_name VARCHAR2(255) DEFAULT '', + user_password VARCHAR2(128) DEFAULT '', + user_newpassword VARCHAR2(128) default '', + user_email VARCHAR2(255) default '', + user_options CLOB default '', + user_touched TIMESTAMP WITH TIME ZONE, + user_token CHAR(32) default '', + user_email_authenticated TIMESTAMP WITH TIME ZONE DEFAULT NULL, + user_email_token CHAR(32), + user_email_token_expires TIMESTAMP WITH TIME ZONE DEFAULT NULL +); +CREATE UNIQUE INDEX user_name_idx ON "user" (user_name); +CREATE INDEX user_email_token_idx ON "user" (user_email_token); + +CREATE TABLE user_groups ( + ug_user NUMBER(5) DEFAULT '0' NOT NULL + REFERENCES "user" (user_id) + ON DELETE CASCADE, + ug_group VARCHAR2(16) NOT NULL, + CONSTRAINT user_groups_pk PRIMARY KEY (ug_user, ug_group) +); +CREATE INDEX user_groups_group_idx ON user_groups(ug_group); + +CREATE TABLE user_newtalk ( + user_id NUMBER(5) DEFAULT 0 NOT NULL, + user_ip VARCHAR2(40) DEFAULT '' NOT NULL +); +CREATE INDEX user_newtalk_id_idx ON user_newtalk(user_id); +CREATE INDEX user_newtalk_ip_idx ON user_newtalk(user_ip); + +CREATE SEQUENCE page_page_id_seq; +CREATE TABLE page ( + page_id NUMBER(8) NOT NULL PRIMARY KEY, + page_namespace NUMBER(5) NOT NULL, + page_title VARCHAR(255) NOT NULL, + page_restrictions CLOB DEFAULT '', + page_counter NUMBER(20) DEFAULT 0 NOT NULL, + page_is_redirect NUMBER(1) DEFAULT 0 NOT NULL, + page_is_new NUMBER(1) DEFAULT 0 NOT NULL, + page_random NUMBER(25, 24) NOT NULL, + page_touched TIMESTAMP WITH TIME ZONE, + page_latest NUMBER(8) NOT NULL, + page_len NUMBER(8) DEFAULT 0 +); +CREATE UNIQUE INDEX page_id_namespace_title_idx ON page(page_namespace, page_title); +CREATE INDEX page_random_idx ON page(page_random); +CREATE INDEX page_len_idx ON page(page_len); + +CREATE SEQUENCE rev_rev_id_val; +CREATE TABLE revision ( + rev_id NUMBER(8) NOT NULL, + rev_page NUMBER(8) NOT NULL + REFERENCES page (page_id) + ON DELETE CASCADE, + rev_text_id NUMBER(8) NOT NULL, + rev_comment CLOB, + rev_user NUMBER(8) DEFAULT 0 NOT NULL, + rev_user_text VARCHAR2(255) DEFAULT '' NOT NULL, + rev_timestamp TIMESTAMP WITH TIME ZONE NOT NULL, + rev_minor_edit NUMBER(1) DEFAULT 0 NOT NULL, + rev_deleted NUMBER(1) DEFAULT 0 NOT NULL, + CONSTRAINT revision_pk PRIMARY KEY (rev_page, rev_id) +); + +CREATE UNIQUE INDEX rev_id_idx ON revision(rev_id); +CREATE INDEX rev_timestamp_idx ON revision(rev_timestamp); +CREATE INDEX rev_page_timestamp_idx ON revision(rev_page, rev_timestamp); +CREATE INDEX rev_user_timestamp_idx ON revision(rev_user, rev_timestamp); +CREATE INDEX rev_usertext_timestamp_idx ON revision(rev_user_text, rev_timestamp); + +CREATE SEQUENCE text_old_id_val; + +CREATE TABLE text ( + old_id NUMBER(8) NOT NULL, + old_text CLOB, + old_flags CLOB, + CONSTRAINT text_pk PRIMARY KEY (old_id) +); + +CREATE TABLE archive ( + ar_namespace NUMBER(5) NOT NULL, + ar_title VARCHAR2(255) NOT NULL, + ar_text CLOB, + ar_comment CLOB, + ar_user NUMBER(8), + ar_user_text VARCHAR2(255) NOT NULL, + ar_timestamp TIMESTAMP WITH TIME ZONE NOT NULL, + ar_minor_edit NUMBER(1) DEFAULT 0 NOT NULL, + ar_flags CLOB, + ar_rev_id NUMBER(8), + ar_text_id NUMBER(8) +); +CREATE INDEX archive_name_title_timestamp ON archive(ar_namespace,ar_title,ar_timestamp); + +CREATE TABLE pagelinks ( + pl_from NUMBER(8) NOT NULL + REFERENCES page(page_id) + ON DELETE CASCADE, + pl_namespace NUMBER(4) DEFAULT 0 NOT NULL, + pl_title VARCHAR2(255) NOT NULL +); +CREATE UNIQUE INDEX pl_from ON pagelinks(pl_from, pl_namespace, pl_title); +CREATE INDEX pl_namespace ON pagelinks(pl_namespace, pl_title); + +CREATE TABLE imagelinks ( + il_from NUMBER(8) NOT NULL REFERENCES page(page_id) ON DELETE CASCADE, + il_to VARCHAR2(255) NOT NULL +); +CREATE UNIQUE INDEX il_from ON imagelinks(il_from, il_to); +CREATE INDEX il_to ON imagelinks(il_to); + +CREATE TABLE categorylinks ( + cl_from NUMBER(8) NOT NULL REFERENCES page(page_id) ON DELETE CASCADE, + cl_to VARCHAR2(255) NOT NULL, + cl_sortkey VARCHAR2(86) default '', + cl_timestamp TIMESTAMP WITH TIME ZONE NOT NULL +); +CREATE UNIQUE INDEX cl_from ON categorylinks(cl_from, cl_to); +CREATE INDEX cl_sortkey ON categorylinks(cl_to, cl_sortkey); +CREATE INDEX cl_timestamp ON categorylinks(cl_to, cl_timestamp); + +-- +-- Contains a single row with some aggregate info +-- on the state of the site. +-- +CREATE TABLE site_stats ( + ss_row_id NUMBER(8) NOT NULL, + ss_total_views NUMBER(20) default 0, + ss_total_edits NUMBER(20) default 0, + ss_good_articles NUMBER(20) default 0, + ss_total_pages NUMBER(20) default -1, + ss_users NUMBER(20) default -1, + ss_admins NUMBER(10) default -1 +); +CREATE UNIQUE INDEX ss_row_id ON site_stats(ss_row_id); + +-- +-- Stores an ID for every time any article is visited; +-- depending on $wgHitcounterUpdateFreq, it is +-- periodically cleared and the page_counter column +-- in the page table updated for the all articles +-- that have been visited.) +-- +CREATE TABLE hitcounter ( + hc_id NUMBER NOT NULL +); + +-- +-- The internet is full of jerks, alas. Sometimes it's handy +-- to block a vandal or troll account. +-- +CREATE SEQUENCE ipblocks_ipb_id_val; +CREATE TABLE ipblocks ( + ipb_id NUMBER(8) NOT NULL, + ipb_address VARCHAR2(40), + ipb_user NUMBER(8), + ipb_by NUMBER(8) NOT NULL + REFERENCES "user" (user_id) + ON DELETE CASCADE, + ipb_reason CLOB, + ipb_timestamp TIMESTAMP WITH TIME ZONE NOT NULL, + ipb_auto NUMBER(1) DEFAULT 0 NOT NULL, + ipb_expiry TIMESTAMP WITH TIME ZONE, + CONSTRAINT ipblocks_pk PRIMARY KEY (ipb_id) +); +CREATE INDEX ipb_address ON ipblocks(ipb_address); +CREATE INDEX ipb_user ON ipblocks(ipb_user); + +CREATE TABLE image ( + img_name VARCHAR2(255) NOT NULL, + img_size NUMBER(8) NOT NULL, + img_width NUMBER(5) NOT NULL, + img_height NUMBER(5) NOT NULL, + img_metadata CLOB, + img_bits NUMBER(3), + img_media_type VARCHAR2(10), + img_major_mime VARCHAR2(12) DEFAULT 'unknown', + img_minor_mime VARCHAR2(32) DEFAULT 'unknown', + img_description CLOB NOT NULL, + img_user NUMBER(8) NOT NULL REFERENCES "user"(user_id) ON DELETE CASCADE, + img_user_text VARCHAR2(255) NOT NULL, + img_timestamp TIMESTAMP WITH TIME ZONE, + CONSTRAINT image_pk PRIMARY KEY (img_name) +); +CREATE INDEX img_size_idx ON image(img_size); +CREATE INDEX img_timestamp_idx ON image(img_timestamp); + +CREATE TABLE oldimage ( + oi_name VARCHAR2(255) NOT NULL, + oi_archive_name VARCHAR2(255) NOT NULL, + oi_size NUMBER(8) NOT NULL, + oi_width NUMBER(5) NOT NULL, + oi_height NUMBER(5) NOT NULL, + oi_bits NUMBER(3) NOT NULL, + oi_description CLOB, + oi_user NUMBER(8) NOT NULL REFERENCES "user"(user_id), + oi_user_text VARCHAR2(255) NOT NULL, + oi_timestamp TIMESTAMP WITH TIME ZONE NOT NULL +); +CREATE INDEX oi_name ON oldimage (oi_name); + +CREATE SEQUENCE rc_rc_id_seq; +CREATE TABLE recentchanges ( + rc_id NUMBER(8) NOT NULL, + rc_timestamp TIMESTAMP WITH TIME ZONE, + rc_cur_time TIMESTAMP WITH TIME ZONE, + rc_user NUMBER(8) DEFAULT 0 NOT NULL, + rc_user_text VARCHAR2(255), + rc_namespace NUMBER(4) DEFAULT 0 NOT NULL, + rc_title VARCHAR2(255) NOT NULL, + rc_comment VARCHAR2(255), + rc_minor NUMBER(3) DEFAULT 0 NOT NULL, + rc_bot NUMBER(3) DEFAULT 0 NOT NULL, + rc_new NUMBER(3) DEFAULT 0 NOT NULL, + rc_cur_id NUMBER(8), + rc_this_oldid NUMBER(8) NOT NULL, + rc_last_oldid NUMBER(8) NOT NULL, + rc_type NUMBER(3) DEFAULT 0 NOT NULL, + rc_moved_to_ns NUMBER(3), + rc_moved_to_title VARCHAR2(255), + rc_patrolled NUMBER(3) DEFAULT 0 NOT NULL, + rc_ip VARCHAR2(40), + CONSTRAINT rc_pk PRIMARY KEY (rc_id) +); +CREATE INDEX rc_timestamp ON recentchanges (rc_timestamp); +CREATE INDEX rc_namespace_title ON recentchanges(rc_namespace, rc_title); +CREATE INDEX rc_cur_id ON recentchanges(rc_cur_id); +CREATE INDEX new_name_timestamp ON recentchanges(rc_new, rc_namespace, rc_timestamp); +CREATE INDEX rc_ip ON recentchanges(rc_ip); + +CREATE TABLE watchlist ( + wl_user NUMBER(8) NOT NULL + REFERENCES "user"(user_id) + ON DELETE CASCADE, + wl_namespace NUMBER(8) DEFAULT 0 NOT NULL, + wl_title VARCHAR2(255) NOT NULL, + wl_notificationtimestamp TIMESTAMP WITH TIME ZONE DEFAULT NULL +); +CREATE UNIQUE INDEX wl_user_namespace_title ON watchlist + (wl_user, wl_namespace, wl_title); +CREATE INDEX wl_namespace_title ON watchlist(wl_namespace, wl_title); + +-- +-- Used by texvc math-rendering extension to keep track +-- of previously-rendered items. +-- +CREATE TABLE math ( + math_inputhash VARCHAR2(16) NOT NULL UNIQUE, + math_outputhash VARCHAR2(16) NOT NULL, + math_html_conservativeness NUMBER(1) NOT NULL, + math_html CLOB, + math_mathml CLOB +); + +-- +-- Recognized interwiki link prefixes +-- +CREATE TABLE interwiki ( + iw_prefix VARCHAR2(32) NOT NULL UNIQUE, + iw_url VARCHAR2(127) NOT NULL, + iw_local NUMBER(1) NOT NULL, + iw_trans NUMBER(1) DEFAULT 0 NOT NULL +); + +CREATE TABLE querycache ( + qc_type VARCHAR2(32) NOT NULL, + qc_value NUMBER(5) DEFAULT 0 NOT NULL, + qc_namespace NUMBER(4) DEFAULT 0 NOT NULL, + qc_title VARCHAR2(255) +); +CREATE INDEX querycache_type_value ON querycache(qc_type, qc_value); + +-- +-- For a few generic cache operations if not using Memcached +-- +CREATE TABLE objectcache ( + keyname CHAR(255) DEFAULT '', + value CLOB, + exptime TIMESTAMP WITH TIME ZONE +); +CREATE UNIQUE INDEX oc_keyname_idx ON objectcache(keyname); +CREATE INDEX oc_exptime_idx ON objectcache(exptime); + +CREATE TABLE logging ( + log_type VARCHAR2(10) NOT NULL, + log_action VARCHAR2(10) NOT NULL, + log_timestamp TIMESTAMP WITH TIME ZONE NOT NULL, + log_user NUMBER(8) REFERENCES "user"(user_id), + log_namespace NUMBER(4), + log_title VARCHAR2(255) NOT NULL, + log_comment VARCHAR2(255), + log_params CLOB +); +CREATE INDEX logging_type_name ON logging(log_type, log_timestamp); +CREATE INDEX logging_user_time ON logging(log_user, log_timestamp); +CREATE INDEX logging_page_time ON logging(log_namespace, log_title, log_timestamp); + +-- Hold group name and description +--CREATE TABLE /*$wgDBprefix*/groups ( +-- gr_id int(5) unsigned NOT NULL auto_increment, +-- gr_name varchar(50) NOT NULL default '', +-- gr_description varchar(255) NOT NULL default '', +-- gr_rights tinyblob, +-- PRIMARY KEY (gr_id) +-- +--) TYPE=InnoDB; + +CREATE OR REPLACE PROCEDURE add_user_right (name VARCHAR2, new_right VARCHAR2) AS + user_id "user".user_id%TYPE;; + user_is_missing EXCEPTION;; +BEGIN + SELECT user_id INTO user_id FROM "user" WHERE user_name = name;; + INSERT INTO user_groups (ug_user, ug_group) VALUES(user_id, new_right);; +EXCEPTION + WHEN NO_DATA_FOUND THEN + DBMS_OUTPUT.PUT_LINE('The specified user does not exist.');; +END add_user_right;; +; + +CREATE OR REPLACE PROCEDURE add_interwiki (prefix VARCHAR2, url VARCHAR2, is_local NUMBER) AS +BEGIN + INSERT INTO interwiki (iw_prefix, iw_url, iw_local) VALUES(prefix, url, is_local);; +END add_interwiki;; +; \ No newline at end of file -- cgit v1.2.2