2 SET CHARACTER SET utf8
;
4 drop table if exists ttrss_user_labels2
;
5 drop table if exists ttrss_labels2
;
6 drop table if exists ttrss_feedbrowser_cache
;
7 drop table if exists ttrss_version
;
8 drop table if exists ttrss_labels
;
9 drop table if exists ttrss_filters
;
10 drop table if exists ttrss_filter_types
;
11 drop table if exists ttrss_filter_actions
;
12 drop table if exists ttrss_user_prefs
;
13 drop table if exists ttrss_prefs
;
14 drop table if exists ttrss_prefs_types
;
15 drop table if exists ttrss_prefs_sections
;
16 drop table if exists ttrss_tags
;
17 drop table if exists ttrss_enclosures
;
18 drop table if exists ttrss_settings_profiles
;
19 drop table if exists ttrss_entry_comments
;
20 drop table if exists ttrss_user_entries
;
21 drop table if exists ttrss_entries
;
22 drop table if exists ttrss_scheduled_updates
;
23 drop table if exists ttrss_counters_cache
;
24 drop table if exists ttrss_cat_counters_cache
;
25 drop table if exists ttrss_feeds
;
26 drop table if exists ttrss_archived_feeds
;
27 drop table if exists ttrss_feed_categories
;
28 drop table if exists ttrss_users
;
29 drop table if exists ttrss_themes
;
30 drop table if exists ttrss_sessions
;
34 create table ttrss_themes(id integer not null primary key auto_increment
,
35 theme_name
varchar(200) not null,
36 theme_path
varchar(200) not null) TYPE=InnoDB
;
38 insert into ttrss_themes (theme_name
, theme_path
) values ('Old-skool', 'compat');
39 insert into ttrss_themes (theme_name
, theme_path
) values ('Graycube', 'graycube');
40 insert into ttrss_themes (theme_name
, theme_path
) values ('Default (Compact)', 'compact');
41 insert into ttrss_themes (theme_name
, theme_path
) values ('Three-pane', '3pane');
43 create table ttrss_users (id integer primary key not null auto_increment
,
44 login varchar(120) not null unique,
45 pwd_hash
varchar(250) not null,
46 last_login datetime
default null,
47 access_level
integer not null default 0,
48 theme_id
integer default null,
49 email
varchar(250) not null default '',
50 email_digest bool
not null default false,
51 last_digest_sent datetime
default null,
52 created datetime
default null,
54 foreign key (theme_id
) references ttrss_themes(id)) TYPE=InnoDB
;
56 insert into ttrss_users (login,pwd_hash
,access_level
) values ('admin',
57 'SHA1:5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8', 10);
59 create table ttrss_feed_categories(id integer not null primary key auto_increment
,
60 owner_uid
integer not null,
61 title
varchar(200) not null,
62 collapsed bool
not null default false,
63 order_id
integer not null default 0,
65 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
67 create table ttrss_archived_feeds (id integer not null primary key,
68 owner_uid
integer not null,
69 title
varchar(200) not null,
70 feed_url
text not null,
71 site_url
varchar(250) not null default '',
73 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
75 create table ttrss_counters_cache (
76 feed_id
integer not null,
77 owner_uid
integer not null,
78 value integer not null default 0,
79 updated datetime
not null,
80 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE
83 create table ttrss_cat_counters_cache (
84 feed_id
integer not null,
85 owner_uid
integer not null,
86 value integer not null default 0,
87 updated datetime
not null,
88 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE
91 create table ttrss_feeds (id integer not null auto_increment
primary key,
92 owner_uid
integer not null,
93 title
varchar(200) not null,
94 cat_id
integer default null,
95 feed_url
text not null,
96 icon_url
varchar(250) not null default '',
97 update_interval
integer not null default 0,
98 purge_interval
integer not null default 0,
99 last_updated datetime
default 0,
100 last_error
varchar(250) not null default '',
101 site_url
varchar(250) not null default '',
102 auth_login
varchar(250) not null default '',
103 auth_pass
varchar(250) not null default '',
104 parent_feed
integer default null,
105 private bool
not null default false,
106 rtl_content bool
not null default false,
107 hidden bool
not null default false,
108 include_in_digest
boolean not null default true,
109 cache_images
boolean not null default false,
110 auth_pass_encrypted
boolean not null default false,
111 last_viewed datetime
default null,
112 last_update_started datetime
default null,
113 always_display_enclosures
boolean not null default false,
114 update_method
integer not null default 0,
116 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
118 foreign key (cat_id
) references ttrss_feed_categories(id) ON DELETE SET NULL,
120 foreign key (parent_feed
) references ttrss_feeds(id) ON DELETE SET NULL) TYPE=InnoDB
;
122 insert into ttrss_feeds (owner_uid
, title
, feed_url
) values
123 (1, 'Tiny Tiny RSS: New Releases', 'http://tt-rss.org/releases.rss');
125 insert into ttrss_feeds (owner_uid
, title
, feed_url
) values
126 (1, 'Tiny Tiny RSS: Forum', 'http://tt-rss.org/forum/rss.php');
128 create table ttrss_entries (id integer not null primary key auto_increment
,
130 guid
varchar(255) not null unique,
132 updated datetime
not null,
133 content text not null,
134 content_hash
varchar(250) not null,
135 no_orig_date bool
not null default 0,
136 date_entered datetime
not null,
137 date_updated datetime
not null,
138 num_comments
integer not null default 0,
139 comments varchar(250) not null default '',
140 author
varchar(250) not null default '') TYPE=InnoDB
;
142 create index ttrss_entries_date_entered_index
on ttrss_entries(date_entered
);
144 create table ttrss_user_entries (
145 int_id
integer not null primary key auto_increment
,
146 ref_id
integer not null,
149 owner_uid
integer not null,
150 marked bool
not null default 0,
151 published bool
not null default 0,
153 score
int not null default 0,
155 unread bool
not null default 1,
157 foreign key (ref_id
) references ttrss_entries(id) ON DELETE CASCADE,
159 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE,
160 index (orig_feed_id
),
161 foreign key (orig_feed_id
) references ttrss_archived_feeds(id) ON DELETE SET NULL,
163 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
165 create table ttrss_entry_comments (id integer not null primary key,
166 ref_id
integer not null,
167 owner_uid
integer not null,
168 private bool
not null default 0,
169 date_entered datetime
not null,
171 foreign key (ref_id
) references ttrss_entries(id) ON DELETE CASCADE,
173 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
175 create table ttrss_filter_types (id integer primary key,
176 name varchar(120) unique not null,
177 description
varchar(250) not null unique) TYPE=InnoDB
;
179 insert into ttrss_filter_types (id,name,description
) values (1, 'title', 'Title');
180 insert into ttrss_filter_types (id,name,description
) values (2, 'content', 'Content');
181 insert into ttrss_filter_types (id,name,description
) values (3, 'both',
183 insert into ttrss_filter_types (id,name,description
) values (4, 'link',
185 insert into ttrss_filter_types (id,name,description
) values (5, 'date',
187 insert into ttrss_filter_types (id,name,description
) values (6, 'author', 'Author');
189 create table ttrss_filter_actions (id integer not null primary key,
190 name varchar(120) unique not null,
191 description
varchar(250) not null unique) TYPE=InnoDB
;
193 insert into ttrss_filter_actions (id,name,description
) values (1, 'filter',
196 insert into ttrss_filter_actions (id,name,description
) values (2, 'catchup',
199 insert into ttrss_filter_actions (id,name,description
) values (3, 'mark',
202 insert into ttrss_filter_actions (id,name,description
) values (4, 'tag',
205 insert into ttrss_filter_actions (id,name,description
) values (5, 'publish',
208 insert into ttrss_filter_actions (id,name,description
) values (6, 'score',
211 insert into ttrss_filter_actions (id,name,description
) values (7, 'label',
214 create table ttrss_filters (id integer not null primary key auto_increment
,
215 owner_uid
integer not null,
216 feed_id
integer default null,
217 filter_type
integer not null,
218 reg_exp
varchar(250) not null,
219 filter_param
varchar(250) not null default '',
220 inverse bool
not null default false,
221 enabled bool
not null default true,
222 action_id
integer not null default 1,
223 action_param
varchar(250) not null default '',
225 foreign key (filter_type
) references ttrss_filter_types(id) ON DELETE CASCADE,
227 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
229 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE,
231 foreign key (action_id
) references ttrss_filter_actions(id) ON DELETE CASCADE) TYPE=InnoDB
;
233 create table ttrss_tags (id integer primary key auto_increment
,
234 owner_uid
integer not null,
235 tag_name
varchar(250) not null,
236 post_int_id
integer not null,
238 foreign key (post_int_id
) references ttrss_user_entries(int_id
) ON DELETE CASCADE,
240 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
242 create table ttrss_version (schema_version
int not null) TYPE=InnoDB
;
244 insert into ttrss_version
values (67);
246 create table ttrss_enclosures (id integer primary key auto_increment
,
247 content_url
text not null,
248 content_type
varchar(250) not null,
249 post_id
integer not null,
251 duration
text not null,
253 foreign key (post_id
) references ttrss_entries(id) ON DELETE cascade) TYPE=InnoDB
;
255 create table ttrss_settings_profiles(id integer primary key auto_increment
,
256 title
varchar(250) not null,
257 owner_uid
integer not null,
259 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
261 create table ttrss_prefs_types (id integer not null primary key,
262 type_name
varchar(100) not null) TYPE=InnoDB
;
264 insert into ttrss_prefs_types (id, type_name
) values (1, 'bool');
265 insert into ttrss_prefs_types (id, type_name
) values (2, 'string');
266 insert into ttrss_prefs_types (id, type_name
) values (3, 'integer');
268 create table ttrss_prefs_sections (id integer not null primary key,
269 section_name
varchar(100) not null) TYPE=InnoDB
;
271 insert into ttrss_prefs_sections (id, section_name
) values (1, 'General');
272 insert into ttrss_prefs_sections (id, section_name
) values (2, 'Interface');
273 insert into ttrss_prefs_sections (id, section_name
) values (3, 'Advanced');
275 create table ttrss_prefs (pref_name
varchar(250) not null primary key,
276 type_id
integer not null,
277 section_id
integer not null default 1,
278 short_desc
text not null,
279 help_text
varchar(250) not null default '',
280 access_level
integer not null default 0,
281 def_value
text not null,
283 foreign key (type_id
) references ttrss_prefs_types(id),
285 foreign key (section_id
) references ttrss_prefs_sections(id)) TYPE=InnoDB
;
287 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_FEED_ICONS', 1, 'true', 'Enable feed icons',3);
288 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('PURGE_OLD_DAYS', 3, '60', 'Purge old posts after this number of days (0 - disables)',1);
289 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('UPDATE_POST_ON_CHECKSUM_CHANGE', 1, 'true', 'Update post on checksum change',1);
290 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ENABLE_LABELS', 1, 'false', 'Enable labels',3,
291 'Experimental support for virtual feeds based on user crafted SQL queries. This feature is highly experimental and at this point not user friendly. Use with caution.');
293 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('DEFAULT_UPDATE_INTERVAL', 3, '30', 'Default interval between feed updates',1);
295 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('DEFAULT_ARTICLE_LIMIT', 3, '30', 'Amount of articles to display at once',2);
297 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ALLOW_DUPLICATE_POSTS', 1, 'true', 'Allow duplicate posts',1,
298 'This option is useful when you are reading several planet-type aggregators with partially colliding userbase. When disabled, it forces same posts from different feeds to appear only once.');
300 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('USER_STYLESHEET_URL', 2, '', 'User stylesheet URL',2,
301 'Link to user stylesheet to override default style, disabled if empty.');
303 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_FEED_CATS', 1, 'false', 'Enable feed categories',2);
305 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('SHOW_CONTENT_PREVIEW', 1, 'true', 'Show content preview in headlines list',2);
307 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('SHORT_DATE_FORMAT', 2, 'M d, G:i', 'Short date format',3);
308 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('LONG_DATE_FORMAT', 2, 'D, M d Y - G:i', 'Long date format',3);
310 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('HEADLINES_SMART_DATE', 1, 'true', 'Use more accessible date/time format for headlines',3);
312 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('COMBINED_DISPLAY_MODE', 1, 'false', 'Combined feed display',2,
313 'Display expanded list of feed articles, instead of separate displays for headlines and article content');
315 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('HIDE_READ_FEEDS', 1, 'false', 'Hide feeds with no unread messages',2);
317 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('OPEN_LINKS_IN_NEW_WINDOW', 1, 'true', 'Open article links in new browser window',2);
319 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ON_CATCHUP_SHOW_NEXT_FEED', 1, 'false', 'On catchup show next feed',2,
320 'When "Mark as read" button is clicked in toolbar, automatically open next feed with unread articles.');
322 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('FEEDS_SORT_BY_UNREAD', 1, 'false', 'Sort feeds by unread articles count',2);
324 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('EXTENDED_FEEDLIST', 1, 'false', 'Show additional information in feedlist',3);
326 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('MARK_UNREAD_ON_UPDATE', 1, 'false', 'Set articles as unread on update',3);
328 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('REVERSE_HEADLINES', 1, 'false', 'Reverse headline order (oldest first)',2);
330 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('DIGEST_ENABLE', 1, 'false', 'Enable e-mail digest',1,
331 'This option enables sending daily digest of new (and unread) headlines on your configured e-mail address');
333 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('CONFIRM_FEED_CATCHUP', 1, 'true', 'Confirm marking feed as read',3);
335 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('CDM_AUTO_CATCHUP', 1, 'false', 'Mark articles as read automatically',2,
336 'This option enables marking articles as read automatically in combined mode (except for Fresh articles feed) while you scroll article list.');
338 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_MODE', 2, 'adaptive', '', 1);
340 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_LIMIT', 3, '30', '', 1);
342 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_ACTIVE_TAB', 2, '', '', 1);
344 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_INFOBOX_DISABLE_OVERLAY', 1, 'false', '', 1);
346 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('STRIP_UNSAFE_TAGS', 1, 'true', 'Strip unsafe tags from articles', 3,
347 'Strip all but most common HTML tags when reading articles.');
349 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('BLACKLISTED_TAGS', 2, 'main, generic, misc, uncategorized, blog, blogroll, general, news', 'Blacklisted tags', 3,
350 'When auto-detecting tags in articles these tags will not be applied (comma-separated list).');
352 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_SEARCH_TOOLBAR', 1, 'false', 'Enable search toolbar',2);
354 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_ENABLE_PAGINATION', 2, '', '', 1);
356 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_PUBLISH_KEY', 2, '', '', 1);
358 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('FRESH_ARTICLE_MAX_AGE', 3, '24', 'Maximum age of fresh articles (in hours)',2);
360 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('DIGEST_CATCHUP', 1, 'false', 'Mark articles in e-mail digest as read',1);
362 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('CDM_EXPANDED', 1, 'true', 'Automatically expand articles in combined mode',3);
364 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('PURGE_UNREAD_ARTICLES', 1, 'true', 'Purge unread articles',3);
366 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('HIDE_READ_SHOWS_SPECIAL', 1, 'true', 'Show special feeds when hiding read feeds',3);
368 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('HIDE_FEEDLIST', 1, 'false', 'Hide feedlist',2, 'This option hides feedlist and allows it to be toggled on the fly, useful for small screens.');
370 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('VFEED_GROUP_BY_FEED', 1, 'false', 'Group headlines in virtual feeds',2,
371 'When this option is enabled, headlines in Special feeds and Labels are grouped by feeds');
373 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('SYNC_COUNTERS', 1, 'false', 'Prefer more accurate feedlist counters to UI speed',3);
375 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('STRIP_IMAGES', 1, 'false', 'Do not show images in articles', 2);
377 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ENABLE_FLASH_PLAYER', 1, 'true', 'Enable inline MP3 player', 3, 'Enable the Flash-based XSPF Player to play MP3-format podcast enclosures.');
379 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_ORDER_BY', 2, 'default', '', 1);
381 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ENABLE_OFFLINE_READING', 1, 'false', 'Enable offline reading',1, 'Synchronize new articles for offline reading using Google Gears.');
383 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_API_ACCESS', 1, 'false', 'Enable external API', 3);
385 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_SPECIAL', 1, 'false', '', 1);
387 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_LABELS', 1, 'false', '', 1);
389 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_UNCAT', 1, 'false', '', 1);
391 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_FEEDLIST', 1, 'false', '', 1);
393 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_ENABLE_CATS', 1, 'false', '', 1);
395 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_SHOW_IMAGES', 1, 'false', '', 1);
397 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_HIDE_READ', 1, 'false', '', 1);
399 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_SORT_FEEDS_UNREAD', 1, 'false', '', 1);
401 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_THEME_ID', 2, '0', '', 1);
403 create table ttrss_user_prefs (
404 owner_uid
integer not null,
405 pref_name
varchar(250),
409 foreign key (profile
) references ttrss_settings_profiles(id) ON DELETE CASCADE,
411 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
413 foreign key (pref_name
) references ttrss_prefs(pref_name
) ON DELETE CASCADE) TYPE=InnoDB
;
415 create table ttrss_scheduled_updates (id integer not null primary key auto_increment
,
416 owner_uid
integer not null,
417 feed_id
integer default null,
418 entered datetime
not null,
419 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
420 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE) TYPE=InnoDB
;
422 create table ttrss_sessions (id varchar(250) unique not null primary key,
424 expire
integer not null,
426 index (expire
)) TYPE=InnoDB
;
428 create table ttrss_feedbrowser_cache (
429 feed_url
text not null,
431 subscribers
integer not null);
433 create table ttrss_labels2 (id integer not null primary key auto_increment
,
434 owner_uid
integer not null,
435 caption
varchar(250) not null,
436 fg_color
varchar(15) not null default '',
437 bg_color
varchar(15) not null default '',
438 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE
441 create table ttrss_user_labels2 (label_id
integer not null,
442 article_id
integer not null,
443 foreign key (label_id
) references ttrss_labels2(id) ON DELETE CASCADE,
444 foreign key (article_id
) references ttrss_entries(id) ON DELETE CASCADE