Fixed main database structure to line up with original sickbeard structure so that migrating users get our database modifications migrated in without issues plus I've updated our main database structure to reflect all our recent changes so that new fresh installs dont have to go through the migration process

This commit is contained in:
echel0n 2014-05-06 17:03:55 -07:00
parent e3f5f795f0
commit 09dd1b6db2

View file

@ -144,15 +144,19 @@ class InitialSchema(db.SchemaUpgrade):
if not self.hasTable("tv_shows") and not self.hasTable("db_version"): if not self.hasTable("tv_shows") and not self.hasTable("db_version"):
queries = [ queries = [
"CREATE TABLE db_version (db_version INTEGER);", "CREATE TABLE db_version (db_version INTEGER);",
"CREATE TABLE history (action NUMERIC, date NUMERIC, showid NUMERIC, season NUMERIC, episode NUMERIC, quality NUMERIC, resource TEXT, provider TEXT);", "CREATE TABLE history (action NUMERIC, date NUMERIC, showid NUMERIC, season NUMERIC, episode NUMERIC, quality NUMERIC, resource TEXT, provider TEXT)",
"CREATE TABLE imdb_info (tvdb_id INTEGER PRIMARY KEY, imdb_id TEXT, title TEXT, year NUMERIC, akas TEXT, runtimes NUMERIC, genres TEXT, countries TEXT, country_codes TEXT, certificates TEXT, rating TEXT, votes INTEGER, last_update NUMERIC)", "CREATE TABLE imdb_info (indexer_id INTEGER PRIMARY KEY, imdb_id TEXT, title TEXT, year NUMERIC, akas TEXT, runtimes NUMERIC, genres TEXT, countries TEXT, country_codes TEXT, certificates TEXT, rating TEXT, votes INTEGER, last_update NUMERIC)",
"CREATE TABLE info (last_backlog NUMERIC, last_tvdb NUMERIC, last_proper_search NUMERIC);", "CREATE TABLE info (last_backlog NUMERIC, last_indexer NUMERIC, last_proper_search NUMERIC)",
"CREATE TABLE tv_episodes (episode_id INTEGER PRIMARY KEY, showid NUMERIC, tvdbid NUMERIC, name TEXT, season NUMERIC, episode NUMERIC, description TEXT, airdate NUMERIC, hasnfo NUMERIC, hastbn NUMERIC, status NUMERIC, location TEXT, file_size NUMERIC, release_name TEXT, subtitles TEXT, subtitles_searchcount NUMERIC, subtitles_lastsearch TIMESTAMP, is_proper NUMERIC)", "CREATE TABLE scene_numbering(indexer TEXT, indexer_id INTEGER, season INTEGER, episode INTEGER,scene_season INTEGER, scene_episode INTEGER, PRIMARY KEY(indexer_id, season, episode))",
"CREATE TABLE tv_shows (show_id INTEGER PRIMARY KEY, location TEXT, show_name TEXT, tvdb_id NUMERIC, network TEXT, genre TEXT, runtime NUMERIC, quality NUMERIC, airs TEXT, status TEXT, flatten_folders NUMERIC, paused NUMERIC, startyear NUMERIC, tvr_id NUMERIC, tvr_name TEXT, air_by_date NUMERIC, lang TEXT, subtitles NUMERIC, notify_list TEXT, imdb_id TEXT, last_update_tvdb NUMERIC)", "CREATE TABLE tv_shows (show_id INTEGER PRIMARY KEY, indexer_id NUMERIC, indexer TEXT, show_name TEXT, location TEXT, network TEXT, genre TEXT, classification TEXT, runtime NUMERIC, quality NUMERIC, airs TEXT, status TEXT, flatten_folders NUMERIC, paused NUMERIC, startyear NUMERIC, air_by_date NUMERIC, lang TEXT, subtitles NUMERIC, notify_list TEXT, imdb_id TEXT, last_update_indexer NUMERIC, dvdorder NUMERIC, archive_firstmatch NUMERIC, rls_require_words TEXT, rls_ignore_words TEXT, sports NUMERIC);",
"CREATE INDEX idx_tv_episodes_showid_airdate ON tv_episodes(showid,airdate);", "CREATE TABLE tv_episodes (episode_id INTEGER PRIMARY KEY, showid NUMERIC, indexerid NUMERIC, indexer TEXT, name TEXT, season NUMERIC, episode NUMERIC, description TEXT, airdate NUMERIC, hasnfo NUMERIC, hastbn NUMERIC, status NUMERIC, location TEXT, file_size NUMERIC, release_name TEXT, subtitles TEXT, subtitles_searchcount NUMERIC, subtitles_lastsearch TIMESTAMP, is_proper NUMERIC, scene_season NUMERIC, scene_episode NUMERIC);",
"CREATE UNIQUE INDEX idx_indexer_id ON tv_shows (indexer_id)",
"CREATE INDEX idx_showid ON tv_episodes (showid);", "CREATE INDEX idx_showid ON tv_episodes (showid);",
"CREATE UNIQUE INDEX idx_tvdb_id ON tv_shows (tvdb_id);", "CREATE INDEX idx_sta_epi_air ON tv_episodes (status,episode, airdate);",
"INSERT INTO db_version (db_version) VALUES (18);" "CREATE INDEX idx_sta_epi_sta_air ON tv_episodes (season,episode, status, airdate);",
"CREATE INDEX idx_status ON tv_episodes (status,season,episode,airdate);",
"CREATE INDEX idx_tv_episodes_showid_airdate ON tv_episodes(showid,airdate)",
"INSERT INTO db_version (db_version) VALUES (28);"
] ]
for query in queries: for query in queries:
self.connection.action(query) self.connection.action(query)
@ -307,17 +311,7 @@ class RenameSeasonFolders(AddSizeAndSceneNameFields):
self.incDBVersion() self.incDBVersion()
class AddIMDbInfo(RenameSeasonFolders): class Add1080pAndRawHDQualities(RenameSeasonFolders):
def test(self):
return self.checkDBVersion() >= 13
def execute(self):
self.connection.action(
"CREATE TABLE imdb_info (tvdb_id INTEGER PRIMARY KEY, imdb_id TEXT, title TEXT, year NUMERIC, akas TEXT, runtimes NUMERIC, genres TEXT, countries TEXT, country_codes TEXT, certificates TEXT, rating TEXT, votes INTEGER, last_update NUMERIC)")
self.incDBVersion()
class Add1080pAndRawHDQualities(AddIMDbInfo):
"""Add support for 1080p related qualities along with RawHD """Add support for 1080p related qualities along with RawHD
Quick overview of what the upgrade needs to do: Quick overview of what the upgrade needs to do:
@ -334,7 +328,7 @@ class Add1080pAndRawHDQualities(AddIMDbInfo):
""" """
def test(self): def test(self):
return self.checkDBVersion() >= 14 return self.checkDBVersion() >= 12
def _update_status(self, old_status): def _update_status(self, old_status):
(status, quality) = common.Quality.splitCompositeStatus(old_status) (status, quality) = common.Quality.splitCompositeStatus(old_status)
@ -451,11 +445,73 @@ class Add1080pAndRawHDQualities(AddIMDbInfo):
logger.log(u"Performing a vacuum on the database.", logger.DEBUG) logger.log(u"Performing a vacuum on the database.", logger.DEBUG)
self.connection.action("VACUUM") self.connection.action("VACUUM")
class AddShowidTvdbidIndex(Add1080pAndRawHDQualities):
""" Adding index on tvdb_id (tv_shows) and showid (tv_episodes) to speed up searches/queries """
def test(self):
return self.checkDBVersion() >= 13
def execute(self):
backupDatabase(13)
logger.log(u"Check for duplicate shows before adding unique index.")
MainSanityCheck(self.connection).fix_duplicate_shows('tvdb_id')
logger.log(u"Adding index on tvdb_id (tv_shows) and showid (tv_episodes) to speed up searches/queries.")
if not self.hasTable("idx_showid"):
self.connection.action("CREATE INDEX idx_showid ON tv_episodes (showid);")
if not self.hasTable("idx_tvdb_id"):
self.connection.action("CREATE UNIQUE INDEX idx_tvdb_id ON tv_shows (tvdb_id);")
self.incDBVersion()
class AddLastUpdateTVDB(AddShowidTvdbidIndex):
""" Adding column last_update_tvdb to tv_shows for controlling nightly updates """
def test(self):
return self.checkDBVersion() >= 14
def execute(self):
backupDatabase(14)
logger.log(u"Adding column last_update_tvdb to tvshows")
if not self.hasColumn("tv_shows", "last_update_tvdb"):
self.addColumn("tv_shows", "last_update_tvdb", default=1)
self.incDBVersion()
class AddRequireAndIgnoreWords(AddLastUpdateTVDB):
""" Adding column rls_require_words and rls_ignore_words to tv_shows """
class AddProperNamingSupport(Add1080pAndRawHDQualities):
def test(self): def test(self):
return self.checkDBVersion() >= 15 return self.checkDBVersion() >= 15
def execute(self):
backupDatabase(15)
logger.log(u"Adding column rls_require_words to tvshows")
if not self.hasColumn("tv_shows", "rls_require_words"):
self.addColumn("tv_shows", "rls_require_words", "TEXT", "")
logger.log(u"Adding column rls_ignore_words to tvshows")
if not self.hasColumn("tv_shows", "rls_ignore_words"):
self.addColumn("tv_shows", "rls_ignore_words", "TEXT", "")
self.incDBVersion()
class AddIMDbInfo(AddRequireAndIgnoreWords):
def test(self):
return self.checkDBVersion() >= 13
def execute(self):
self.connection.action(
"CREATE TABLE imdb_info (tvdb_id INTEGER PRIMARY KEY, imdb_id TEXT, title TEXT, year NUMERIC, akas TEXT, runtimes NUMERIC, genres TEXT, countries TEXT, country_codes TEXT, certificates TEXT, rating TEXT, votes INTEGER, last_update NUMERIC)")
self.incDBVersion()
class AddProperNamingSupport(AddIMDbInfo):
def test(self):
return self.checkDBVersion() >= 14
def execute(self): def execute(self):
self.addColumn("tv_episodes", "is_proper") self.addColumn("tv_episodes", "is_proper")
self.incDBVersion() self.incDBVersion()
@ -469,50 +525,12 @@ class AddEmailSubscriptionTable(AddProperNamingSupport):
self.addColumn('tv_shows', 'notify_list', 'TEXT', None) self.addColumn('tv_shows', 'notify_list', 'TEXT', None)
self.incDBVersion() self.incDBVersion()
class AddProperSearch(AddEmailSubscriptionTable):
class AddShowidTvdbidIndex(AddEmailSubscriptionTable):
""" Adding index on tvdb_id (tv_shows) and showid (tv_episodes) to speed up searches/queries """
def test(self): def test(self):
return self.checkDBVersion() >= 17 return self.checkDBVersion() >= 16
def execute(self): def execute(self):
backupDatabase(17) backupDatabase(16)
logger.log(u"Check for duplicate shows before adding unique index.")
MainSanityCheck(self.connection).fix_duplicate_shows('tvdb_id')
logger.log(u"Adding index on tvdb_id (tv_shows) and showid (tv_episodes) to speed up searches/queries.")
if not self.hasTable("idx_showid"):
self.connection.action("CREATE INDEX idx_showid ON tv_episodes (showid);")
if not self.hasTable("idx_tvdb_id"):
self.connection.action("CREATE UNIQUE INDEX idx_tvdb_id ON tv_shows (tvdb_id);")
self.incDBVersion()
class AddUpdateTVDB(AddShowidTvdbidIndex):
""" Adding column last_update_tvdb to tv_shows for controlling nightly updates """
def test(self):
return self.checkDBVersion() >= 18
def execute(self):
backupDatabase(18)
logger.log(u"Adding column last_update_tvdb to tvshows")
if not self.hasColumn("tv_shows", "last_update_tvdb"):
self.addColumn("tv_shows", "last_update_tvdb", default=1)
self.incDBVersion()
class AddProperSearch(AddUpdateTVDB):
def test(self):
return self.checkDBVersion() >= 19
def execute(self):
backupDatabase(19)
logger.log(u"Adding column last_proper_search to info") logger.log(u"Adding column last_proper_search to info")
if not self.hasColumn("info", "last_proper_search"): if not self.hasColumn("info", "last_proper_search"):
@ -523,18 +541,16 @@ class AddProperSearch(AddUpdateTVDB):
class AddDvdOrderOption(AddProperSearch): class AddDvdOrderOption(AddProperSearch):
def test(self): def test(self):
return self.checkDBVersion() >= 20 return self.hasColumn("tv_shows", "dvdorder")
def execute(self): def execute(self):
backupDatabase(20)
logger.log(u"Adding column dvdorder to tvshows") logger.log(u"Adding column dvdorder to tvshows")
if not self.hasColumn("tv_shows", "dvdorder"): if not self.hasColumn("tv_shows", "dvdorder"):
self.addColumn("tv_shows", "dvdorder", "NUMERIC", "0") self.addColumn("tv_shows", "dvdorder", "NUMERIC", "0")
self.incDBVersion() self.incDBVersion()
class AddSubtitlesSupport(RenameSeasonFolders): class AddSubtitlesSupport(AddDvdOrderOption):
def test(self): def test(self):
return self.hasColumn("tv_shows", "subtitles") return self.hasColumn("tv_shows", "subtitles")
@ -545,16 +561,12 @@ class AddSubtitlesSupport(RenameSeasonFolders):
self.addColumn("tv_episodes", "subtitles_lastsearch", "TIMESTAMP", str(datetime.datetime.min)) self.addColumn("tv_episodes", "subtitles_lastsearch", "TIMESTAMP", str(datetime.datetime.min))
self.incDBVersion() self.incDBVersion()
class ConvertTVShowsToIndexerScheme(AddDvdOrderOption): class ConvertTVShowsToIndexerScheme(AddSubtitlesSupport):
def test(self): def test(self):
return self.checkDBVersion() >= 22 return self.checkDBVersion() >= 19
def execute(self): def execute(self):
backupDatabase(22) backupDatabase(19)
logger.log(u"Adding column dvdorder to tvshows")
if not self.hasColumn("tv_shows", "dvdorder"):
self.addColumn("tv_shows", "dvdorder", "NUMERIC", "0")
logger.log(u"Converting TV Shows table to Indexer Scheme...") logger.log(u"Converting TV Shows table to Indexer Scheme...")
@ -579,10 +591,10 @@ class ConvertTVShowsToIndexerScheme(AddDvdOrderOption):
class ConvertTVEpisodesToIndexerScheme(ConvertTVShowsToIndexerScheme): class ConvertTVEpisodesToIndexerScheme(ConvertTVShowsToIndexerScheme):
def test(self): def test(self):
return self.checkDBVersion() >= 23 return self.checkDBVersion() >= 20
def execute(self): def execute(self):
backupDatabase(23) backupDatabase(20)
logger.log(u"Converting TV Episodes table to Indexer Scheme...") logger.log(u"Converting TV Episodes table to Indexer Scheme...")
@ -610,10 +622,10 @@ class ConvertTVEpisodesToIndexerScheme(ConvertTVShowsToIndexerScheme):
class ConvertIMDBInfoToIndexerScheme(ConvertTVEpisodesToIndexerScheme): class ConvertIMDBInfoToIndexerScheme(ConvertTVEpisodesToIndexerScheme):
def test(self): def test(self):
return self.checkDBVersion() >= 24 return self.checkDBVersion() >= 21
def execute(self): def execute(self):
backupDatabase(24) backupDatabase(21)
logger.log(u"Converting IMDB Info table to Indexer Scheme...") logger.log(u"Converting IMDB Info table to Indexer Scheme...")
@ -633,10 +645,10 @@ class ConvertIMDBInfoToIndexerScheme(ConvertTVEpisodesToIndexerScheme):
class ConvertInfoToIndexerScheme(ConvertIMDBInfoToIndexerScheme): class ConvertInfoToIndexerScheme(ConvertIMDBInfoToIndexerScheme):
def test(self): def test(self):
return self.checkDBVersion() >= 25 return self.checkDBVersion() >= 22
def execute(self): def execute(self):
backupDatabase(25) backupDatabase(22)
logger.log(u"Converting Info table to Indexer Scheme...") logger.log(u"Converting Info table to Indexer Scheme...")
@ -655,10 +667,10 @@ class ConvertInfoToIndexerScheme(ConvertIMDBInfoToIndexerScheme):
class AddArchiveFirstMatchOption(ConvertInfoToIndexerScheme): class AddArchiveFirstMatchOption(ConvertInfoToIndexerScheme):
def test(self): def test(self):
return self.checkDBVersion() >= 26 return self.checkDBVersion() >= 23
def execute(self): def execute(self):
backupDatabase(26) backupDatabase(23)
logger.log(u"Adding column archive_firstmatch to tvshows") logger.log(u"Adding column archive_firstmatch to tvshows")
if not self.hasColumn("tv_shows", "archive_firstmatch"): if not self.hasColumn("tv_shows", "archive_firstmatch"):
@ -668,10 +680,10 @@ class AddArchiveFirstMatchOption(ConvertInfoToIndexerScheme):
class AddSceneNumbering(AddArchiveFirstMatchOption): class AddSceneNumbering(AddArchiveFirstMatchOption):
def test(self): def test(self):
return self.checkDBVersion() >= 27 return self.checkDBVersion() >= 24
def execute(self): def execute(self):
backupDatabase(27) backupDatabase(24)
if self.hasTable("scene_numbering"): if self.hasTable("scene_numbering"):
self.connection.action("DROP TABLE scene_numbering") self.connection.action("DROP TABLE scene_numbering")
@ -684,10 +696,10 @@ class AddSceneNumbering(AddArchiveFirstMatchOption):
class ConvertIndexerToInteger(AddSceneNumbering): class ConvertIndexerToInteger(AddSceneNumbering):
def test(self): def test(self):
return self.checkDBVersion() >= 28 return self.checkDBVersion() >= 25
def execute(self): def execute(self):
backupDatabase(28) backupDatabase(25)
ql = [] ql = []
logger.log(u"Converting Indexer to Integer ...", logger.MESSAGE) logger.log(u"Converting Indexer to Integer ...", logger.MESSAGE)
@ -706,10 +718,10 @@ class AddRequireAndIgnoreWords(ConvertIndexerToInteger):
""" Adding column rls_require_words and rls_ignore_words to tv_shows """ """ Adding column rls_require_words and rls_ignore_words to tv_shows """
def test(self): def test(self):
return self.checkDBVersion() >= 29 return self.checkDBVersion() >= 26
def execute(self): def execute(self):
backupDatabase(29) backupDatabase(26)
logger.log(u"Adding column rls_require_words to tvshows") logger.log(u"Adding column rls_require_words to tvshows")
if not self.hasColumn("tv_shows", "rls_require_words"): if not self.hasColumn("tv_shows", "rls_require_words"):
@ -723,10 +735,10 @@ class AddRequireAndIgnoreWords(ConvertIndexerToInteger):
class AddSportsOption(AddRequireAndIgnoreWords): class AddSportsOption(AddRequireAndIgnoreWords):
def test(self): def test(self):
return self.checkDBVersion() >= 30 return self.checkDBVersion() >= 27
def execute(self): def execute(self):
backupDatabase(30) backupDatabase(27)
logger.log(u"Adding column sports to tvshows") logger.log(u"Adding column sports to tvshows")
if not self.hasColumn("tv_shows", "sports"): if not self.hasColumn("tv_shows", "sports"):
@ -746,10 +758,10 @@ class AddSportsOption(AddRequireAndIgnoreWords):
class AddSceneNumberingToTvEpisodes(AddSportsOption): class AddSceneNumberingToTvEpisodes(AddSportsOption):
def test(self): def test(self):
return self.checkDBVersion() >= 31 return self.checkDBVersion() >= 28
def execute(self): def execute(self):
backupDatabase(31) backupDatabase(28)
logger.log(u"Adding column scene_season and scene_episode to tvepisodes") logger.log(u"Adding column scene_season and scene_episode to tvepisodes")
if not self.hasColumn("tv_episodes", "scene_season"): if not self.hasColumn("tv_episodes", "scene_season"):