source: subversion/trunk/roundcubemail/SQL/sqlite.initial.sql @ 2077

Last change on this file since 2077 was 2077, checked in by alec, 5 years ago
  • fix r2076: removed cache.session_id column, removed DELETEs from cache in session_gc
  • trust DB server's time when "touching" cache and messages tables
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.5 KB
Line 
1-- RoundCube Webmail initial database structure
2-- Version 0.1
3--
4
5-- --------------------------------------------------------
6
7--
8-- Table structure for table `cache`
9--
10
11CREATE TABLE cache (
12  cache_id integer NOT NULL PRIMARY KEY,
13  user_id integer NOT NULL default 0,
14  cache_key varchar(128) NOT NULL default '',
15  created datetime NOT NULL default '0000-00-00 00:00:00',
16  data longtext NOT NULL
17);
18
19CREATE INDEX ix_cache_user_cache_key ON cache(user_id, cache_key);
20
21
22-- --------------------------------------------------------
23
24--
25-- Table structure for table contacts
26--
27
28CREATE TABLE contacts (
29  contact_id integer NOT NULL PRIMARY KEY,
30  user_id integer NOT NULL default '0',
31  changed datetime NOT NULL default '0000-00-00 00:00:00',
32  del tinyint NOT NULL default '0',
33  name varchar(128) NOT NULL default '',
34  email varchar(128) NOT NULL default '',
35  firstname varchar(128) NOT NULL default '',
36  surname varchar(128) NOT NULL default '',
37  vcard text NOT NULL default ''
38);
39
40CREATE INDEX ix_contacts_user_id ON contacts(user_id);
41
42-- --------------------------------------------------------
43
44--
45-- Table structure for table identities
46--
47
48CREATE TABLE identities (
49  identity_id integer NOT NULL PRIMARY KEY,
50  user_id integer NOT NULL default '0',
51  del tinyint NOT NULL default '0',
52  standard tinyint NOT NULL default '0',
53  name varchar(128) NOT NULL default '',
54  organization varchar(128) default '',
55  email varchar(128) NOT NULL default '',
56  "reply-to" varchar(128) NOT NULL default '',
57  bcc varchar(128) NOT NULL default '',
58  signature text NOT NULL default '',
59  html_signature tinyint NOT NULL default '0'
60);
61
62CREATE INDEX ix_identities_user_id ON identities(user_id);
63
64
65-- --------------------------------------------------------
66
67--
68-- Table structure for table users
69--
70
71CREATE TABLE users (
72  user_id integer NOT NULL PRIMARY KEY,
73  username varchar(128) NOT NULL default '',
74  mail_host varchar(128) NOT NULL default '',
75  alias varchar(128) NOT NULL default '',
76  created datetime NOT NULL default '0000-00-00 00:00:00',
77  last_login datetime NOT NULL default '0000-00-00 00:00:00',
78  language varchar(5) NOT NULL default 'en',
79  preferences text NOT NULL default ''
80);
81
82CREATE INDEX ix_users_username ON users(username);
83CREATE INDEX ix_users_alias ON users(alias);
84
85-- --------------------------------------------------------
86
87--
88-- Table structure for table session
89--
90
91CREATE TABLE session (
92  sess_id varchar(40) NOT NULL PRIMARY KEY,
93  created datetime NOT NULL default '0000-00-00 00:00:00',
94  changed datetime NOT NULL default '0000-00-00 00:00:00',
95  ip varchar(40) NOT NULL default '',
96  vars text NOT NULL
97);
98
99CREATE INDEX ix_session_changed ON session (changed);
100
101-- --------------------------------------------------------
102
103--
104-- Table structure for table messages
105--
106
107CREATE TABLE messages (
108  message_id integer NOT NULL PRIMARY KEY,
109  user_id integer NOT NULL default '0',
110  del tinyint NOT NULL default '0',
111  cache_key varchar(128) NOT NULL default '',
112  created datetime NOT NULL default '0000-00-00 00:00:00',
113  idx integer NOT NULL default '0',
114  uid integer NOT NULL default '0',
115  subject varchar(255) NOT NULL default '',
116  "from" varchar(255) NOT NULL default '',
117  "to" varchar(255) NOT NULL default '',
118  "cc" varchar(255) NOT NULL default '',
119  "date" datetime NOT NULL default '0000-00-00 00:00:00',
120  size integer NOT NULL default '0',
121  headers text NOT NULL,
122  structure text
123);
124
125CREATE INDEX ix_messages_user_cache_uid ON messages(user_id,cache_key,uid);
126CREATE INDEX ix_messages_created ON messages (created);
Note: See TracBrowser for help on using the repository browser.