mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	Merge pull request #2103 from selfhost-alt/faster-scan-for-empty-series
Scan for empty book series more efficiently
This commit is contained in:
		
						commit
						4e01722ba6
					
				| @ -666,7 +666,11 @@ class Database { | |||||||
|   async cleanDatabase() { |   async cleanDatabase() { | ||||||
|     // Remove invalid Podcast records
 |     // Remove invalid Podcast records
 | ||||||
|     const podcastsWithNoLibraryItem = await this.podcastModel.findAll({ |     const podcastsWithNoLibraryItem = await this.podcastModel.findAll({ | ||||||
|       where: Sequelize.where(Sequelize.literal(`(SELECT count(*) FROM libraryItems li WHERE li.mediaId = podcast.id)`), 0) |       include: { | ||||||
|  |         model: this.libraryItemModel, | ||||||
|  |         required: false | ||||||
|  |       }, | ||||||
|  |       where: { '$libraryItem.id$': null } | ||||||
|     }) |     }) | ||||||
|     for (const podcast of podcastsWithNoLibraryItem) { |     for (const podcast of podcastsWithNoLibraryItem) { | ||||||
|       Logger.warn(`Found podcast "${podcast.title}" with no libraryItem - removing it`) |       Logger.warn(`Found podcast "${podcast.title}" with no libraryItem - removing it`) | ||||||
| @ -675,7 +679,11 @@ class Database { | |||||||
| 
 | 
 | ||||||
|     // Remove invalid Book records
 |     // Remove invalid Book records
 | ||||||
|     const booksWithNoLibraryItem = await this.bookModel.findAll({ |     const booksWithNoLibraryItem = await this.bookModel.findAll({ | ||||||
|       where: Sequelize.where(Sequelize.literal(`(SELECT count(*) FROM libraryItems li WHERE li.mediaId = book.id)`), 0) |       include: { | ||||||
|  |         model: this.libraryItemModel, | ||||||
|  |         required: false | ||||||
|  |       }, | ||||||
|  |       where: { '$libraryItem.id$': null } | ||||||
|     }) |     }) | ||||||
|     for (const book of booksWithNoLibraryItem) { |     for (const book of booksWithNoLibraryItem) { | ||||||
|       Logger.warn(`Found book "${book.title}" with no libraryItem - removing it`) |       Logger.warn(`Found book "${book.title}" with no libraryItem - removing it`) | ||||||
| @ -684,7 +692,11 @@ class Database { | |||||||
| 
 | 
 | ||||||
|     // Remove empty series
 |     // Remove empty series
 | ||||||
|     const emptySeries = await this.seriesModel.findAll({ |     const emptySeries = await this.seriesModel.findAll({ | ||||||
|       where: Sequelize.where(Sequelize.literal(`(SELECT count(*) FROM bookSeries bs WHERE bs.seriesId = series.id)`), 0) |       include: { | ||||||
|  |         model: this.bookSeriesModel, | ||||||
|  |         required: false | ||||||
|  |       }, | ||||||
|  |       where: { '$bookSeries.id$': null } | ||||||
|     }) |     }) | ||||||
|     for (const series of emptySeries) { |     for (const series of emptySeries) { | ||||||
|       Logger.warn(`Found series "${series.name}" with no books - removing it`) |       Logger.warn(`Found series "${series.name}" with no books - removing it`) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user