From 99b81119a4420fd5b0db384ce39497b437d12dc6 Mon Sep 17 00:00:00 2001 From: ice-myles <96409608+ice-myles@users.noreply.github.com> Date: Tue, 3 Sep 2024 13:18:37 +0300 Subject: [PATCH] Delete requests are rewritten to use single field index + ANY instead of composite index + IN. --- go.mod | 2 +- go.sum | 4 ++-- notifications/scheduler.go | 14 +++++--------- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/go.mod b/go.mod index 0bfb7e6..757d871 100644 --- a/go.mod +++ b/go.mod @@ -129,7 +129,7 @@ require ( github.com/onsi/ginkgo/v2 v2.20.2 // indirect github.com/opencontainers/go-digest v1.0.0 // indirect github.com/opencontainers/image-spec v1.1.0 // indirect - github.com/opencontainers/runc v1.1.13 // indirect + github.com/opencontainers/runc v1.1.14 // indirect github.com/pascaldekloe/name v1.0.1 // indirect github.com/pelletier/go-toml/v2 v2.2.3 // indirect github.com/pierrec/lz4/v4 v4.1.21 // indirect diff --git a/go.sum b/go.sum index 9e54843..cca400b 100644 --- a/go.sum +++ b/go.sum @@ -373,8 +373,8 @@ github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8 github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM= github.com/opencontainers/image-spec v1.1.0 h1:8SG7/vwALn54lVB/0yZ/MMwhFrPYtpEHQb2IpWsCzug= github.com/opencontainers/image-spec v1.1.0/go.mod h1:W4s4sFTMaBeK1BQLXbG4AdM2szdn85PY75RI83NrTrM= -github.com/opencontainers/runc v1.1.13 h1:98S2srgG9vw0zWcDpFMn5TRrh8kLxa/5OFUstuUhmRs= -github.com/opencontainers/runc v1.1.13/go.mod h1:R016aXacfp/gwQBYw2FDGa9m+n6atbLWrYY8hNMT/sA= +github.com/opencontainers/runc v1.1.14 h1:rgSuzbmgz5DUJjeSnw337TxDbRuqjs6iqQck/2weR6w= +github.com/opencontainers/runc v1.1.14/go.mod h1:E4C2z+7BxR7GHXp0hAY53mek+x49X1LjPNeMTfRGvOA= github.com/pascaldekloe/name v1.0.1 h1:9lnXOHeqeHHnWLbKfH6X98+4+ETVqFqxN09UXSjcMb0= github.com/pascaldekloe/name v1.0.1/go.mod h1:Z//MfYJnH4jVpQ9wkclwu2I2MkHmXTlT9wR5UZScttM= github.com/pelletier/go-toml/v2 v2.2.3 h1:YmeHyLY8mFWbdkNWwpr+qIL2bEqT0o95WSdkNHvL12M= diff --git a/notifications/scheduler.go b/notifications/scheduler.go index 70be662..5af5814 100644 --- a/notifications/scheduler.go +++ b/notifications/scheduler.go @@ -257,16 +257,12 @@ func (s *Scheduler) deleteScheduledNotifications(ctx context.Context, notificati if len(notifications) == 0 { return nil } - const numFields = 5 - values := make([]string, 0, numFields*len(notifications)) - params := make([]any, 0, numFields*len(notifications)) - for idx, n := range notifications { - values = append(values, fmt.Sprintf("($%[1]v, $%[2]v, $%[3]v, $%[4]v, $%[5]v)", idx*numFields+1, idx*numFields+2, idx*numFields+3, idx*numFields+4, idx*numFields+5)) //nolint:gomnd,mnd,lll // . - params = append(params, n.UserID, n.Uniqueness, n.NotificationType, n.NotificationChannel, n.NotificationChannelValue) + indexes := make([]int64, 0, len(notifications)) + for _, n := range notifications { + indexes = append(indexes, n.I) } - sql := fmt.Sprintf(`DELETE FROM scheduled_notifications - WHERE (user_id, uniqueness, notification_type, notification_channel, notification_channel_value) IN (%v)`, strings.Join(values, ",")) - _, err := storage.Exec(ctx, s.db, sql, params...) + sql := `DELETE FROM scheduled_notifications WHERE i = ANY($1)` + _, err := storage.Exec(ctx, s.db, sql, indexes) return errors.Wrapf(err, "failed to delete scheduled notifications %#v", notifications) }