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.spb.ru/releases.rss');
125 insert into ttrss_feeds (owner_uid
, title
, feed_url
) values
126 (1, 'Tiny Tiny RSS: Forum', 'http://tt-rss.spb.ru/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 num_comments
integer not null default 0,
138 comments varchar(250) not null default '',
139 author
varchar(250) not null default '') TYPE=InnoDB
;
141 create index ttrss_entries_date_entered_index
on ttrss_entries(date_entered
);
143 create table ttrss_user_entries (
144 int_id
integer not null primary key auto_increment
,
145 ref_id
integer not null,
148 owner_uid
integer not null,
149 marked bool
not null default 0,
150 published bool
not null default 0,
152 score
int not null default 0,
154 unread bool
not null default 1,
156 foreign key (ref_id
) references ttrss_entries(id) ON DELETE CASCADE,
158 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE,
159 index (orig_feed_id
),
160 foreign key (orig_feed_id
) references ttrss_archived_feeds(id) ON DELETE SET NULL,
162 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
164 create table ttrss_entry_comments (id integer not null primary key,
165 ref_id
integer not null,
166 owner_uid
integer not null,
167 private bool
not null default 0,
168 date_entered datetime
not null,
170 foreign key (ref_id
) references ttrss_entries(id) ON DELETE CASCADE,
172 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
174 create table ttrss_filter_types (id integer primary key,
175 name varchar(120) unique not null,
176 description
varchar(250) not null unique) TYPE=InnoDB
;
178 insert into ttrss_filter_types (id,name,description
) values (1, 'title', 'Title');
179 insert into ttrss_filter_types (id,name,description
) values (2, 'content', 'Content');
180 insert into ttrss_filter_types (id,name,description
) values (3, 'both',
182 insert into ttrss_filter_types (id,name,description
) values (4, 'link',
184 insert into ttrss_filter_types (id,name,description
) values (5, 'date',
186 insert into ttrss_filter_types (id,name,description
) values (6, 'author', 'Author');
188 create table ttrss_filter_actions (id integer not null primary key,
189 name varchar(120) unique not null,
190 description
varchar(250) not null unique) TYPE=InnoDB
;
192 insert into ttrss_filter_actions (id,name,description
) values (1, 'filter',
195 insert into ttrss_filter_actions (id,name,description
) values (2, 'catchup',
198 insert into ttrss_filter_actions (id,name,description
) values (3, 'mark',
201 insert into ttrss_filter_actions (id,name,description
) values (4, 'tag',
204 insert into ttrss_filter_actions (id,name,description
) values (5, 'publish',
207 insert into ttrss_filter_actions (id,name,description
) values (6, 'score',
210 insert into ttrss_filter_actions (id,name,description
) values (7, 'label',
213 create table ttrss_filters (id integer not null primary key auto_increment
,
214 owner_uid
integer not null,
215 feed_id
integer default null,
216 filter_type
integer not null,
217 reg_exp
varchar(250) not null,
218 filter_param
varchar(250) not null default '',
219 inverse bool
not null default false,
220 enabled bool
not null default true,
221 action_id
integer not null default 1,
222 action_param
varchar(250) not null default '',
224 foreign key (filter_type
) references ttrss_filter_types(id) ON DELETE CASCADE,
226 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
228 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE,
230 foreign key (action_id
) references ttrss_filter_actions(id) ON DELETE CASCADE) TYPE=InnoDB
;
232 create table ttrss_tags (id integer primary key auto_increment
,
233 owner_uid
integer not null,
234 tag_name
varchar(250) not null,
235 post_int_id
integer not null,
237 foreign key (post_int_id
) references ttrss_user_entries(int_id
) ON DELETE CASCADE,
239 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
241 create table ttrss_version (schema_version
int not null) TYPE=InnoDB
;
243 insert into ttrss_version
values (66);
245 create table ttrss_enclosures (id integer primary key auto_increment
,
246 content_url
text not null,
247 content_type
varchar(250) not null,
248 post_id
integer not null,
250 duration
text not null,
252 foreign key (post_id
) references ttrss_entries(id) ON DELETE cascade) TYPE=InnoDB
;
254 create table ttrss_settings_profiles(id integer primary key auto_increment
,
255 title
varchar(250) not null,
256 owner_uid
integer not null,
258 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE) TYPE=InnoDB
;
260 create table ttrss_prefs_types (id integer not null primary key,
261 type_name
varchar(100) not null) TYPE=InnoDB
;
263 insert into ttrss_prefs_types (id, type_name
) values (1, 'bool');
264 insert into ttrss_prefs_types (id, type_name
) values (2, 'string');
265 insert into ttrss_prefs_types (id, type_name
) values (3, 'integer');
267 create table ttrss_prefs_sections (id integer not null primary key,
268 section_name
varchar(100) not null) TYPE=InnoDB
;
270 insert into ttrss_prefs_sections (id, section_name
) values (1, 'General');
271 insert into ttrss_prefs_sections (id, section_name
) values (2, 'Interface');
272 insert into ttrss_prefs_sections (id, section_name
) values (3, 'Advanced');
274 create table ttrss_prefs (pref_name
varchar(250) not null primary key,
275 type_id
integer not null,
276 section_id
integer not null default 1,
277 short_desc
text not null,
278 help_text
varchar(250) not null default '',
279 access_level
integer not null default 0,
280 def_value
text not null,
282 foreign key (type_id
) references ttrss_prefs_types(id),
284 foreign key (section_id
) references ttrss_prefs_sections(id)) TYPE=InnoDB
;
286 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_FEED_ICONS', 1, 'true', 'Enable feed icons',3);
287 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);
288 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);
289 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
,help_text
) values('ENABLE_LABELS', 1, 'false', 'Enable labels',3,
290 '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.');
292 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);
294 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);
296 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,
297 '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.');
299 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,
300 'Link to user stylesheet to override default style, disabled if empty.');
302 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_FEED_CATS', 1, 'false', 'Enable feed categories',2);
304 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);
306 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);
307 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);
309 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);
311 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,
312 'Display expanded list of feed articles, instead of separate displays for headlines and article content');
314 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);
316 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);
318 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,
319 'When "Mark as read" button is clicked in toolbar, automatically open next feed with unread articles.');
321 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);
323 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);
325 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);
327 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);
329 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,
330 'This option enables sending daily digest of new (and unread) headlines on your configured e-mail address');
332 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);
334 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,
335 'This option enables marking articles as read automatically in combined mode (except for Fresh articles feed) while you scroll article list.');
337 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_MODE', 2, 'adaptive', '', 1);
339 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_LIMIT', 3, '30', '', 1);
341 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_ACTIVE_TAB', 2, '', '', 1);
343 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_INFOBOX_DISABLE_OVERLAY', 1, 'false', '', 1);
345 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,
346 'Strip all but most common HTML tags when reading articles.');
348 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,
349 'When auto-detecting tags in articles these tags will not be applied (comma-separated list).');
351 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_SEARCH_TOOLBAR', 1, 'false', 'Enable search toolbar',2);
353 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_ENABLE_PAGINATION', 2, '', '', 1);
355 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_PREFS_PUBLISH_KEY', 2, '', '', 1);
357 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);
359 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);
361 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);
363 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('PURGE_UNREAD_ARTICLES', 1, 'true', 'Purge unread articles',3);
365 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);
367 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.');
369 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,
370 'When this option is enabled, headlines in Special feeds and Labels are grouped by feeds');
372 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);
374 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);
376 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.');
378 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_DEFAULT_VIEW_ORDER_BY', 2, 'default', '', 1);
380 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.');
382 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('ENABLE_API_ACCESS', 1, 'false', 'Enable external API', 3);
384 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_SPECIAL', 1, 'false', '', 1);
386 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_LABELS', 1, 'false', '', 1);
388 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_UNCAT', 1, 'false', '', 1);
390 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_COLLAPSED_FEEDLIST', 1, 'false', '', 1);
392 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_ENABLE_CATS', 1, 'false', '', 1);
394 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_SHOW_IMAGES', 1, 'false', '', 1);
396 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_HIDE_READ', 1, 'false', '', 1);
398 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_MOBILE_SORT_FEEDS_UNREAD', 1, 'false', '', 1);
400 insert into ttrss_prefs (pref_name
,type_id
,def_value
,short_desc
,section_id
) values('_THEME_ID', 2, '0', '', 1);
402 create table ttrss_user_prefs (
403 owner_uid
integer not null,
404 pref_name
varchar(250),
408 foreign key (profile
) references ttrss_settings_profiles(id) ON DELETE CASCADE,
410 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
412 foreign key (pref_name
) references ttrss_prefs(pref_name
) ON DELETE CASCADE) TYPE=InnoDB
;
414 create table ttrss_scheduled_updates (id integer not null primary key auto_increment
,
415 owner_uid
integer not null,
416 feed_id
integer default null,
417 entered datetime
not null,
418 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE,
419 foreign key (feed_id
) references ttrss_feeds(id) ON DELETE CASCADE) TYPE=InnoDB
;
421 create table ttrss_sessions (id varchar(250) unique not null primary key,
423 expire
integer not null,
425 index (expire
)) TYPE=InnoDB
;
427 create table ttrss_feedbrowser_cache (
428 feed_url
text not null,
430 subscribers
integer not null);
432 create table ttrss_labels2 (id integer not null primary key auto_increment
,
433 owner_uid
integer not null,
434 caption
varchar(250) not null,
435 fg_color
varchar(15) not null default '',
436 bg_color
varchar(15) not null default '',
437 foreign key (owner_uid
) references ttrss_users(id) ON DELETE CASCADE
440 create table ttrss_user_labels2 (label_id
integer not null,
441 article_id
integer not null,
442 foreign key (label_id
) references ttrss_labels2(id) ON DELETE CASCADE,
443 foreign key (article_id
) references ttrss_entries(id) ON DELETE CASCADE