moodle/mod/forum/db/oci8po.sql

216 lines
7.9 KiB
MySQL
Executable File

rem
rem Table structure for table forum
rem
drop TABLE prefix_forum;
CREATE TABLE prefix_forum (
id number(10) primary key,
course number(10) default '0' NOT NULL,
type varchar2(64) default 'general' not null,
constraint type_check CHECK (type IN (
'single','news','general','social','eachuser','teacher')),
name varchar2(255) default '' not null,
intro varchar2(1024) NOT NULL,
open number(2) default '2' not null,
assessed number(10) default '0' NOT NULL,
scale number(10) default '0' NOT NULL,
maxbytes number(10) default '0' NOT NULL,
forcesubscribe number(1) default '0' NOT NULL,
timemodified number(10) default '0' NOT NULL
);
COMMENT on table prefix_forum is 'Forums contain and structure discussion';
drop sequence p_forum_seq;
create sequence p_forum_seq;
create or replace trigger p_forum_trig
before insert on prefix_forum
referencing new as new_row
for each row
begin
select p_forum_seq.nextval into :new_row.id from dual;
end;
.
/
insert into prefix_forum(course,type,name,intro,open,assessed,scale,forcesubscribe,timemodified) values(1,'single','1','1',1,1,1,1,1);
insert into prefix_forum(course,type,name,intro,open,assessed,scale,forcesubscribe,timemodified) values(2,'general','2','2',2,2,2,2,2);
insert into prefix_forum(course,type,name,intro,open,assessed,scale,forcesubscribe,timemodified) values(3,'eachuser','3','3',3,3,3,3,3);
rem should fail the check constraint
insert into prefix_forum(course,type,name,intro,open,assessed,scale,forcesubscribe,timemodified) values(4,'4','4','4',4,4,4,4,4);
select * from prefix_forum order by 1,2;
rem --------------------------------------------------------
rem
rem Table structure for table forum_discussions
rem
drop TABLE prefix_forum_discussions;
CREATE TABLE prefix_forum_discussions (
id number(10) primary key,
course number(10) default '0' NOT NULL,
forum number(10) default '0' NOT NULL,
name varchar2(255) default '' not null,
firstpost number(10) default '0' NOT NULL,
assessed number(1) default '1' not null,
timemodified number(10) default '0' NOT NULL
);
COMMENT on table prefix_forum_discussions is 'Forums are composed of discussions';
drop sequence p_forum_disc_seq;
create sequence p_forum_disc_seq;
create or replace trigger p_forum_disc_trig
before insert on prefix_forum_discussions
referencing new as new_row
for each row
begin
select p_forum_disc_seq.nextval into :new_row.id from dual;
end;
.
/
insert into prefix_forum_discussions(course,forum,name,firstpost,assessed,timemodified) values(1,1,'1',1,1,1);
insert into prefix_forum_discussions(course,forum,name,firstpost,assessed,timemodified) values(2,2,'2',2,2,2);
insert into prefix_forum_discussions(course,forum,name,firstpost,assessed,timemodified) values(3,3,'3',3,3,3);
insert into prefix_forum_discussions(course,forum,name,firstpost,assessed,timemodified) values(4,4,'4',4,4,4);
select * from prefix_forum_discussions order by 1,2;
rem --------------------------------------------------------
rem
rem Table structure for table forum_posts
rem
drop TABLE prefix_forum_posts;
CREATE TABLE prefix_forum_posts (
id number(10) primary key,
discussion number(10) default '0' NOT NULL,
parent number(10) default '0' NOT NULL,
userid number(10) default '0' NOT NULL,
created number(10) default '0' NOT NULL,
modified number(10) default '0' NOT NULL,
mailed number(2) default '0' NOT NULL,
subject varchar2(255) default '' not null,
message varchar2(1024) NOT NULL,
format number(2) default '0' NOT NULL,
attachment varchar2(100) default '' not null,
totalscore number(4) default '0' NOT NULL
);
drop sequence p_forum_posts_seq;
create sequence p_forum_posts_seq;
create or replace trigger p_forum_posts_trig
before insert on prefix_forum_posts
referencing new as new_row
for each row
begin
select p_forum_posts_seq.nextval into :new_row.id from dual;
end;
.
/
COMMENT on table prefix_forum_posts is 'All posts are stored in this table';
insert into prefix_forum_posts (discussion,parent,userid,created,modified,mailed,subject,message,format,attachment,totalscore) values(1,1,1,1,1,1,'1','1',1,'1',1);
insert into prefix_forum_posts (discussion,parent,userid,created,modified,mailed,subject,message,format,attachment,totalscore) values(2,2,2,2,2,2,'2','2',2,'2',2);
insert into prefix_forum_posts (discussion,parent,userid,created,modified,mailed,subject,message,format,attachment,totalscore) values(3,3,3,3,3,3,'3','3',3,'3',3);
insert into prefix_forum_posts (discussion,parent,userid,created,modified,mailed,subject,message,format,attachment,totalscore) values(4,4,4,4,4,4,'4','4',4,'4',4);
select * from prefix_forum_posts order by 1,2;
rem --------------------------------------------------------
rem
rem Table structure for table forum_ratings
rem
drop TABLE prefix_forum_ratings;
CREATE TABLE prefix_forum_ratings (
id number(10) primary key,
userid number(10) default '0' NOT NULL,
post number(10) default '0' NOT NULL,
time number(10) default '0' NOT NULL,
rating number(4) default '0' NOT NULL
);
drop sequence p_forum_ratings_seq;
create sequence p_forum_ratings_seq;
create or replace trigger p_forum_ratings_trig
before insert on prefix_forum_ratings
referencing new as new_row
for each row
begin
select p_forum_ratings_seq.nextval into :new_row.id from dual;
end;
.
/
COMMENT on table prefix_forum_ratings is 'Contains user ratings for individual posts';
insert into prefix_forum_ratings(userid,post,time,rating) values(1,1,1,1);
insert into prefix_forum_ratings(userid,post,time,rating) values(2,2,2,2);
insert into prefix_forum_ratings(userid,post,time,rating) values(3,3,3,3);
insert into prefix_forum_ratings(userid,post,time,rating) values(4,4,4,4);
select * from prefix_forum_ratings order by 1,2;
rem --------------------------------------------------------
rem
rem Table structure for table forum_subscriptions
rem
drop TABLE prefix_forum_subscriptions;
CREATE TABLE prefix_forum_subscriptions (
id number(10) primary key,
userid number(10) default '0' NOT NULL,
forum number(10) default '0' NOT NULL
);
drop sequence p_forum_subscrip_seq;
create sequence p_forum_subscrip_seq;
create or replace trigger p_forum_subscrip_trig
before insert on prefix_forum_subscriptions
referencing new as new_row
for each row
begin
select p_forum_subscrip_seq.nextval into :new_row.id from dual;
end;
.
/
COMMENT on table prefix_forum_subscriptions is 'Keeps track of who is subscribed to what forum';
insert into prefix_forum_subscriptions(userid,forum) values(1,1);
insert into prefix_forum_subscriptions(userid,forum) values(2,2);
insert into prefix_forum_subscriptions(userid,forum) values(3,3);
insert into prefix_forum_subscriptions(userid,forum) values(4,4);
select * from prefix_forum_subscriptions order by 1,2;
rem --------------------------------------------------------
rem
rem Dumping data for table log_display
rem
delete from prefix_log_display where module = 'forum';
INSERT INTO prefix_log_display VALUES ('forum', 'add', 'forum', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'update', 'forum', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'add discussion', 'forum_discussions', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'add post', 'forum_posts', 'subject');
INSERT INTO prefix_log_display VALUES ('forum', 'update post', 'forum_posts', 'subject');
INSERT INTO prefix_log_display VALUES ('forum', 'move discussion', 'forum_discussions', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'view subscribers', 'forum', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'view discussion', 'forum_discussions', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'view forum', 'forum', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'subscribe', 'forum', 'name');
INSERT INTO prefix_log_display VALUES ('forum', 'unsubscribe', 'forum', 'name');
select * from prefix_log_display where module = 'forum';