Mercurial > hg > rc1
comparison SQL/oracle.initial.sql @ 0:1e000243b222
vanilla 1.3.3 distro, I hope
| author | Charlie Root |
|---|---|
| date | Thu, 04 Jan 2018 15:50:29 -0500 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:1e000243b222 |
|---|---|
| 1 -- Roundcube Webmail initial database structure | |
| 2 -- This was tested with Oracle 11g | |
| 3 | |
| 4 CREATE TABLE "users" ( | |
| 5 "user_id" integer PRIMARY KEY, | |
| 6 "username" varchar(128) NOT NULL, | |
| 7 "mail_host" varchar(128) NOT NULL, | |
| 8 "created" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 9 "last_login" timestamp with time zone DEFAULT NULL, | |
| 10 "failed_login" timestamp with time zone DEFAULT NULL, | |
| 11 "failed_login_counter" integer DEFAULT NULL, | |
| 12 "language" varchar(5), | |
| 13 "preferences" long DEFAULT NULL, | |
| 14 CONSTRAINT "users_username_key" UNIQUE ("username", "mail_host") | |
| 15 ); | |
| 16 | |
| 17 CREATE SEQUENCE "users_seq" | |
| 18 START WITH 1 INCREMENT BY 1 NOMAXVALUE; | |
| 19 | |
| 20 CREATE TRIGGER "users_seq_trig" | |
| 21 BEFORE INSERT ON "users" FOR EACH ROW | |
| 22 BEGIN | |
| 23 :NEW."user_id" := "users_seq".nextval; | |
| 24 END; | |
| 25 / | |
| 26 | |
| 27 CREATE TABLE "session" ( | |
| 28 "sess_id" varchar(128) NOT NULL PRIMARY KEY, | |
| 29 "changed" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 30 "ip" varchar(41) NOT NULL, | |
| 31 "vars" long NOT NULL | |
| 32 ); | |
| 33 | |
| 34 CREATE INDEX "session_changed_idx" ON "session" ("changed"); | |
| 35 | |
| 36 | |
| 37 CREATE TABLE "identities" ( | |
| 38 "identity_id" integer PRIMARY KEY, | |
| 39 "user_id" integer NOT NULL | |
| 40 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 41 "changed" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 42 "del" smallint DEFAULT 0 NOT NULL, | |
| 43 "standard" smallint DEFAULT 0 NOT NULL, | |
| 44 "name" varchar(128) NOT NULL, | |
| 45 "organization" varchar(128), | |
| 46 "email" varchar(128) NOT NULL, | |
| 47 "reply-to" varchar(128), | |
| 48 "bcc" varchar(128), | |
| 49 "signature" long, | |
| 50 "html_signature" integer DEFAULT 0 NOT NULL | |
| 51 ); | |
| 52 | |
| 53 CREATE INDEX "identities_user_id_idx" ON "identities" ("user_id", "del"); | |
| 54 CREATE INDEX "identities_email_idx" ON "identities" ("email", "del"); | |
| 55 | |
| 56 CREATE SEQUENCE "identities_seq" | |
| 57 START WITH 1 INCREMENT BY 1 NOMAXVALUE; | |
| 58 | |
| 59 CREATE TRIGGER "identities_seq_trig" | |
| 60 BEFORE INSERT ON "identities" FOR EACH ROW | |
| 61 BEGIN | |
| 62 :NEW."identity_id" := "identities_seq".nextval; | |
| 63 END; | |
| 64 / | |
| 65 | |
| 66 CREATE TABLE "contacts" ( | |
| 67 "contact_id" integer PRIMARY KEY, | |
| 68 "user_id" integer NOT NULL | |
| 69 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 70 "changed" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 71 "del" smallint DEFAULT 0 NOT NULL, | |
| 72 "name" varchar(128) DEFAULT NULL, | |
| 73 "email" varchar(4000) DEFAULT NULL, | |
| 74 "firstname" varchar(128) DEFAULT NULL, | |
| 75 "surname" varchar(128) DEFAULT NULL, | |
| 76 "vcard" long, | |
| 77 "words" varchar(4000) | |
| 78 ); | |
| 79 | |
| 80 CREATE INDEX "contacts_user_id_idx" ON "contacts" ("user_id", "del"); | |
| 81 | |
| 82 CREATE SEQUENCE "contacts_seq" | |
| 83 START WITH 1 INCREMENT BY 1 NOMAXVALUE; | |
| 84 | |
| 85 CREATE TRIGGER "contacts_seq_trig" | |
| 86 BEFORE INSERT ON "contacts" FOR EACH ROW | |
| 87 BEGIN | |
| 88 :NEW."contact_id" := "contacts_seq".nextval; | |
| 89 END; | |
| 90 / | |
| 91 | |
| 92 CREATE TABLE "contactgroups" ( | |
| 93 "contactgroup_id" integer PRIMARY KEY, | |
| 94 "user_id" integer NOT NULL | |
| 95 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 96 "changed" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 97 "del" smallint DEFAULT 0 NOT NULL, | |
| 98 "name" varchar(128) NOT NULL | |
| 99 ); | |
| 100 | |
| 101 CREATE INDEX "contactgroups_user_id_idx" ON "contactgroups" ("user_id", "del"); | |
| 102 | |
| 103 CREATE SEQUENCE "contactgroups_seq" | |
| 104 START WITH 1 INCREMENT BY 1 NOMAXVALUE; | |
| 105 | |
| 106 CREATE TRIGGER "contactgroups_seq_trig" | |
| 107 BEFORE INSERT ON "contactgroups" FOR EACH ROW | |
| 108 BEGIN | |
| 109 :NEW."contactgroup_id" := "contactgroups_seq".nextval; | |
| 110 END; | |
| 111 / | |
| 112 | |
| 113 CREATE TABLE "contactgroupmembers" ( | |
| 114 "contactgroup_id" integer NOT NULL | |
| 115 REFERENCES "contactgroups" ("contactgroup_id") ON DELETE CASCADE, | |
| 116 "contact_id" integer NOT NULL | |
| 117 REFERENCES "contacts" ("contact_id") ON DELETE CASCADE, | |
| 118 "created" timestamp with time zone DEFAULT current_timestamp NOT NULL, | |
| 119 PRIMARY KEY ("contactgroup_id", "contact_id") | |
| 120 ); | |
| 121 | |
| 122 CREATE INDEX "contactgroupmembers_idx" ON "contactgroupmembers" ("contact_id"); | |
| 123 | |
| 124 | |
| 125 CREATE TABLE "cache" ( | |
| 126 "user_id" integer NOT NULL | |
| 127 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 128 "cache_key" varchar(128) NOT NULL, | |
| 129 "expires" timestamp with time zone DEFAULT NULL, | |
| 130 "data" long NOT NULL, | |
| 131 PRIMARY KEY ("user_id", "cache_key") | |
| 132 ); | |
| 133 | |
| 134 CREATE INDEX "cache_expires_idx" ON "cache" ("expires"); | |
| 135 | |
| 136 | |
| 137 CREATE TABLE "cache_shared" ( | |
| 138 "cache_key" varchar(255) NOT NULL, | |
| 139 "expires" timestamp with time zone DEFAULT NULL, | |
| 140 "data" long NOT NULL, | |
| 141 PRIMARY KEY ("cache_key") | |
| 142 ); | |
| 143 | |
| 144 CREATE INDEX "cache_shared_expires_idx" ON "cache_shared" ("expires"); | |
| 145 | |
| 146 | |
| 147 CREATE TABLE "cache_index" ( | |
| 148 "user_id" integer NOT NULL | |
| 149 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 150 "mailbox" varchar(255) NOT NULL, | |
| 151 "expires" timestamp with time zone DEFAULT NULL, | |
| 152 "valid" smallint DEFAULT 0 NOT NULL, | |
| 153 "data" long NOT NULL, | |
| 154 PRIMARY KEY ("user_id", "mailbox") | |
| 155 ); | |
| 156 | |
| 157 CREATE INDEX "cache_index_expires_idx" ON "cache_index" ("expires"); | |
| 158 | |
| 159 | |
| 160 CREATE TABLE "cache_thread" ( | |
| 161 "user_id" integer NOT NULL | |
| 162 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 163 "mailbox" varchar(255) NOT NULL, | |
| 164 "expires" timestamp with time zone DEFAULT NULL, | |
| 165 "data" long NOT NULL, | |
| 166 PRIMARY KEY ("user_id", "mailbox") | |
| 167 ); | |
| 168 | |
| 169 CREATE INDEX "cache_thread_expires_idx" ON "cache_thread" ("expires"); | |
| 170 | |
| 171 | |
| 172 CREATE TABLE "cache_messages" ( | |
| 173 "user_id" integer NOT NULL | |
| 174 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 175 "mailbox" varchar(255) NOT NULL, | |
| 176 "uid" integer NOT NULL, | |
| 177 "expires" timestamp with time zone DEFAULT NULL, | |
| 178 "data" long NOT NULL, | |
| 179 "flags" integer DEFAULT 0 NOT NULL, | |
| 180 PRIMARY KEY ("user_id", "mailbox", "uid") | |
| 181 ); | |
| 182 | |
| 183 CREATE INDEX "cache_messages_expires_idx" ON "cache_messages" ("expires"); | |
| 184 | |
| 185 | |
| 186 CREATE TABLE "dictionary" ( | |
| 187 "user_id" integer DEFAULT NULL | |
| 188 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 189 "language" varchar(5) NOT NULL, | |
| 190 "data" long DEFAULT NULL, | |
| 191 CONSTRAINT "dictionary_user_id_lang_key" UNIQUE ("user_id", "language") | |
| 192 ); | |
| 193 | |
| 194 | |
| 195 CREATE TABLE "searches" ( | |
| 196 "search_id" integer PRIMARY KEY, | |
| 197 "user_id" integer NOT NULL | |
| 198 REFERENCES "users" ("user_id") ON DELETE CASCADE, | |
| 199 "type" smallint DEFAULT 0 NOT NULL, | |
| 200 "name" varchar(128) NOT NULL, | |
| 201 "data" long NOT NULL, | |
| 202 CONSTRAINT "searches_user_id_key" UNIQUE ("user_id", "type", "name") | |
| 203 ); | |
| 204 | |
| 205 CREATE SEQUENCE "searches_seq" | |
| 206 START WITH 1 INCREMENT BY 1 NOMAXVALUE; | |
| 207 | |
| 208 CREATE TRIGGER "searches_seq_trig" | |
| 209 BEFORE INSERT ON "searches" FOR EACH ROW | |
| 210 BEGIN | |
| 211 :NEW."search_id" := "searches_seq".nextval; | |
| 212 END; | |
| 213 / | |
| 214 | |
| 215 CREATE TABLE "system" ( | |
| 216 "name" varchar(64) NOT NULL PRIMARY KEY, | |
| 217 "value" long | |
| 218 ); | |
| 219 | |
| 220 INSERT INTO "system" ("name", "value") VALUES ('roundcube-version', '2016112200'); |
