mirror of
https://github.com/krateng/maloja.git
synced 2023-08-10 21:12:55 +03:00
Improved DB cleanup
This commit is contained in:
parent
9f26cce34b
commit
40c0edb06f
@ -700,34 +700,34 @@ def clean_db():
|
|||||||
|
|
||||||
with SCROBBLE_LOCK:
|
with SCROBBLE_LOCK:
|
||||||
with engine.begin() as conn:
|
with engine.begin() as conn:
|
||||||
#log(f"Database Cleanup...")
|
log(f"Database Cleanup...")
|
||||||
|
|
||||||
### Delete tracks that have no scrobbles (delete their trackartist entries first)
|
to_delete = [
|
||||||
a1 = conn.execute(sql.text('''
|
# tracks with no scrobbles (trackartist entries first)
|
||||||
delete from trackartists where track_id in (select id from tracks where id not in (select track_id from scrobbles))
|
"from trackartists where track_id in (select id from tracks where id not in (select track_id from scrobbles))",
|
||||||
''')).rowcount
|
"from tracks where id not in (select track_id from scrobbles)",
|
||||||
a2 = conn.execute(sql.text('''
|
# artists with no tracks
|
||||||
delete from tracks where id not in (select track_id from scrobbles)
|
"from artists where id not in (select artist_id from trackartists) and id not in (select target_artist from associated_artists)",
|
||||||
''')).rowcount
|
# tracks with no artists (scrobbles first)
|
||||||
|
"from scrobbles where track_id in (select id from tracks where id not in (select track_id from trackartists))",
|
||||||
|
"from tracks where id not in (select track_id from trackartists)"
|
||||||
|
]
|
||||||
|
|
||||||
if a2+a1>0: log(f"Deleted {a2} tracks without scrobbles ({a1} track artist entries)")
|
for d in to_delete:
|
||||||
|
selection = conn.execute(sql.text(f"select * {d}"))
|
||||||
|
for row in selection.all():
|
||||||
|
log(f"Deleting {row}")
|
||||||
|
deletion = conn.execute(sql.text(f"delete {d}"))
|
||||||
|
|
||||||
### Delete artists that have no tracks
|
log("Database Cleanup complete!")
|
||||||
a3 = conn.execute(sql.text('''
|
|
||||||
delete from artists where id not in (select artist_id from trackartists) and id not in (select target_artist from associated_artists)
|
|
||||||
''')).rowcount
|
|
||||||
|
|
||||||
if a3>0: log(f"Deleted {a3} artists without tracks")
|
|
||||||
|
|
||||||
### Delete tracks that have no artists (delete their scrobbles first)
|
|
||||||
a4 = conn.execute(sql.text('''
|
|
||||||
delete from scrobbles where track_id in (select id from tracks where id not in (select track_id from trackartists))
|
|
||||||
''')).rowcount
|
|
||||||
a5 = conn.execute(sql.text('''
|
|
||||||
delete from tracks where id not in (select track_id from trackartists)
|
|
||||||
''')).rowcount
|
|
||||||
|
|
||||||
if a5+a4>0: log(f"Deleted {a5} tracks without artists ({a4} scrobbles)")
|
#if a2+a1>0: log(f"Deleted {a2} tracks without scrobbles ({a1} track artist entries)")
|
||||||
|
|
||||||
|
#if a3>0: log(f"Deleted {a3} artists without tracks")
|
||||||
|
|
||||||
|
#if a5+a4>0: log(f"Deleted {a5} tracks without artists ({a4} scrobbles)")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user