mirror of
https://github.com/gabehf/Koito.git
synced 2026-03-07 21:48:18 -08:00
32 lines
809 B
Go
32 lines
809 B
Go
// Code generated by sqlc. DO NOT EDIT.
|
|
// versions:
|
|
// sqlc v1.30.0
|
|
// source: etc.sql
|
|
|
|
package repository
|
|
|
|
import (
|
|
"context"
|
|
)
|
|
|
|
const cleanOrphanedEntries = `-- name: CleanOrphanedEntries :exec
|
|
DO $$
|
|
BEGIN
|
|
DELETE FROM tracks WHERE id NOT IN (SELECT l.track_id FROM listens l);
|
|
DELETE FROM releases WHERE id NOT IN (SELECT t.release_id FROM tracks t);
|
|
DELETE FROM artists WHERE id NOT IN (SELECT at.artist_id FROM artist_tracks at);
|
|
DELETE FROM artist_releases ar
|
|
WHERE NOT EXISTS (
|
|
SELECT 1
|
|
FROM artist_tracks at
|
|
JOIN tracks t ON at.track_id = t.id
|
|
WHERE at.artist_id = ar.artist_id
|
|
AND t.release_id = ar.release_id
|
|
);
|
|
END $$
|
|
`
|
|
|
|
func (q *Queries) CleanOrphanedEntries(ctx context.Context) error {
|
|
_, err := q.db.Exec(ctx, cleanOrphanedEntries)
|
|
return err
|
|
}
|