From 722c78d25440b909794b788f59613f4c4159377d Mon Sep 17 00:00:00 2001 From: Charith Ellawala Date: Fri, 6 Dec 2024 12:03:29 +0000 Subject: [PATCH 1/3] fix: Support multi-argument version of unnest Currently, `sqlc` errors out when it encounters the multi-argument version of the `UNNEST` function. This is because the function is not marked as variadic. Instead, the argument type is defined as [`anymultirange`](https://www.postgresql.org/docs/current/extend-type-system.html#EXTEND-TYPES-POLYMORPHIC). Fixes #3507 Signed-off-by: Charith Ellawala --- .../postgresql/pgx/v4/go/db.go | 32 +++++++ .../postgresql/pgx/v4/go/models.go | 25 +++++ .../postgresql/pgx/v4/go/querier.go | 16 ++++ .../postgresql/pgx/v4/go/query.sql.go | 89 +++++++++++++++++ .../postgresql/pgx/v4/query.sql | 9 ++ .../postgresql/pgx/v4/schema.sql | 12 +++ .../postgresql/pgx/v4/sqlc.json | 14 +++ .../postgresql/pgx/v5/go/db.go | 32 +++++++ .../postgresql/pgx/v5/go/models.go | 22 +++++ .../postgresql/pgx/v5/go/querier.go | 16 ++++ .../postgresql/pgx/v5/go/query.sql.go | 89 +++++++++++++++++ .../postgresql/pgx/v5/query.sql | 9 ++ .../postgresql/pgx/v5/schema.sql | 12 +++ .../postgresql/pgx/v5/sqlc.json | 14 +++ .../postgresql/stdlib/go/db.go | 31 ++++++ .../postgresql/stdlib/go/models.go | 25 +++++ .../postgresql/stdlib/go/querier.go | 16 ++++ .../postgresql/stdlib/go/query.sql.go | 96 +++++++++++++++++++ .../postgresql/stdlib/query.sql | 9 ++ .../postgresql/stdlib/schema.sql | 12 +++ .../postgresql/stdlib/sqlc.json | 13 +++ internal/sql/catalog/public.go | 2 +- 22 files changed, 594 insertions(+), 1 deletion(-) create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/db.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/models.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/querier.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/query.sql.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/query.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/schema.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/sqlc.json create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/db.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/models.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/querier.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/query.sql.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/query.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/schema.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/sqlc.json create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/db.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/models.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/querier.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/query.sql.go create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/query.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/schema.sql create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/sqlc.json diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/db.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/db.go new file mode 100644 index 0000000000..58779be81d --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/db.go @@ -0,0 +1,32 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" + + "github.com/jackc/pgconn" + "github.com/jackc/pgx/v4" +) + +type DBTX interface { + Exec(context.Context, string, ...interface{}) (pgconn.CommandTag, error) + Query(context.Context, string, ...interface{}) (pgx.Rows, error) + QueryRow(context.Context, string, ...interface{}) pgx.Row +} + +func New(db DBTX) *Queries { + return &Queries{db: db} +} + +type Queries struct { + db DBTX +} + +func (q *Queries) WithTx(tx pgx.Tx) *Queries { + return &Queries{ + db: tx, + } +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/models.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/models.go new file mode 100644 index 0000000000..7f48124961 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/models.go @@ -0,0 +1,25 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "database/sql" + "time" + + "github.com/google/uuid" +) + +type Memory struct { + ID uuid.UUID + VampireID uuid.UUID + Memory string + Victim string + CreatedAt time.Time + UpdatedAt sql.NullTime +} + +type Vampire struct { + ID uuid.UUID +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/querier.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/querier.go new file mode 100644 index 0000000000..0e41f337f9 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/querier.go @@ -0,0 +1,16 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" +) + +type Querier interface { + CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) + GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) +} + +var _ Querier = (*Queries)(nil) diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/query.sql.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/query.sql.go new file mode 100644 index 0000000000..1347124e37 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/go/query.sql.go @@ -0,0 +1,89 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 +// source: query.sql + +package querytest + +import ( + "context" + + "github.com/google/uuid" +) + +const createMemories = `-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest($1::uuid[], $2::text[], $3::text[]) +RETURNING + id, vampire_id, memory, victim, created_at, updated_at +` + +type CreateMemoriesParams struct { + Vampires []uuid.UUID + Memories []string + Victims []string +} + +func (q *Queries) CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) { + rows, err := q.db.Query(ctx, createMemories, arg.Vampires, arg.Memories, arg.Victims) + if err != nil { + return nil, err + } + defer rows.Close() + var items []Memory + for rows.Next() { + var i Memory + if err := rows.Scan( + &i.ID, + &i.VampireID, + &i.Memory, + &i.Victim, + &i.CreatedAt, + &i.UpdatedAt, + ); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} + +const getMemories = `-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest($1::uuid[], $2::text[], $3::text[]) AS vampires (id, memory, victim) +` + +type GetMemoriesParams struct { + Vampires []uuid.UUID + Memories []string + Victims []string +} + +type GetMemoriesRow struct { + VampiresID uuid.UUID + VampiresMemory string + VampiresVictim string +} + +func (q *Queries) GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) { + rows, err := q.db.Query(ctx, getMemories, arg.Vampires, arg.Memories, arg.Victims) + if err != nil { + return nil, err + } + defer rows.Close() + var items []GetMemoriesRow + for rows.Next() { + var i GetMemoriesRow + if err := rows.Scan(&i.VampiresID, &i.VampiresMemory, &i.VampiresVictim); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/query.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/query.sql new file mode 100644 index 0000000000..9f68d6a231 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/query.sql @@ -0,0 +1,9 @@ +-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest(@vampires::uuid[], @memories::text[], @victims::text[]) +RETURNING + *; + +-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest(@vampires::uuid[], @memories::text[], @victims::text[]) AS vampires (id, memory, victim); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/schema.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/schema.sql new file mode 100644 index 0000000000..f9e6714af4 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/schema.sql @@ -0,0 +1,12 @@ +CREATE TABLE vampires ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid () +); + +CREATE TABLE memories ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid (), + vampire_id uuid REFERENCES vampires (id) NOT NULL, + memory text NOT NULL, + victim text NOT NULL, + created_at timestamp NOT NULL DEFAULT NOW(), + updated_at timestamp +); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/sqlc.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/sqlc.json new file mode 100644 index 0000000000..e0530db353 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/sqlc.json @@ -0,0 +1,14 @@ +{ + "version": "1", + "packages": [ + { + "path": "go", + "engine": "postgresql", + "sql_package": "pgx/v4", + "name": "querytest", + "schema": "schema.sql", + "queries": "query.sql", + "emit_interface": true + } + ] +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/db.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/db.go new file mode 100644 index 0000000000..69ef001548 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/db.go @@ -0,0 +1,32 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" + + "github.com/jackc/pgx/v5" + "github.com/jackc/pgx/v5/pgconn" +) + +type DBTX interface { + Exec(context.Context, string, ...interface{}) (pgconn.CommandTag, error) + Query(context.Context, string, ...interface{}) (pgx.Rows, error) + QueryRow(context.Context, string, ...interface{}) pgx.Row +} + +func New(db DBTX) *Queries { + return &Queries{db: db} +} + +type Queries struct { + db DBTX +} + +func (q *Queries) WithTx(tx pgx.Tx) *Queries { + return &Queries{ + db: tx, + } +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/models.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/models.go new file mode 100644 index 0000000000..91fc8705a0 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/models.go @@ -0,0 +1,22 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "github.com/jackc/pgx/v5/pgtype" +) + +type Memory struct { + ID pgtype.UUID + VampireID pgtype.UUID + Memory string + Victim string + CreatedAt pgtype.Timestamp + UpdatedAt pgtype.Timestamp +} + +type Vampire struct { + ID pgtype.UUID +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/querier.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/querier.go new file mode 100644 index 0000000000..0e41f337f9 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/querier.go @@ -0,0 +1,16 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" +) + +type Querier interface { + CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) + GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) +} + +var _ Querier = (*Queries)(nil) diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/query.sql.go b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/query.sql.go new file mode 100644 index 0000000000..cbe6805fcf --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/go/query.sql.go @@ -0,0 +1,89 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 +// source: query.sql + +package querytest + +import ( + "context" + + "github.com/jackc/pgx/v5/pgtype" +) + +const createMemories = `-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest($1::uuid[], $2::text[], $3::text[]) +RETURNING + id, vampire_id, memory, victim, created_at, updated_at +` + +type CreateMemoriesParams struct { + Vampires []pgtype.UUID + Memories []string + Victims []string +} + +func (q *Queries) CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) { + rows, err := q.db.Query(ctx, createMemories, arg.Vampires, arg.Memories, arg.Victims) + if err != nil { + return nil, err + } + defer rows.Close() + var items []Memory + for rows.Next() { + var i Memory + if err := rows.Scan( + &i.ID, + &i.VampireID, + &i.Memory, + &i.Victim, + &i.CreatedAt, + &i.UpdatedAt, + ); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} + +const getMemories = `-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest($1::uuid[], $2::text[], $3::text[]) AS vampires(id, memory, victim) +` + +type GetMemoriesParams struct { + Vampires []pgtype.UUID + Memories []string + Victims []string +} + +type GetMemoriesRow struct { + VampiresID pgtype.UUID + VampiresMemory string + VampiresVictim string +} + +func (q *Queries) GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) { + rows, err := q.db.Query(ctx, getMemories, arg.Vampires, arg.Memories, arg.Victims) + if err != nil { + return nil, err + } + defer rows.Close() + var items []GetMemoriesRow + for rows.Next() { + var i GetMemoriesRow + if err := rows.Scan(&i.VampiresID, &i.VampiresMemory, &i.VampiresVictim); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/query.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/query.sql new file mode 100644 index 0000000000..79999815a5 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/query.sql @@ -0,0 +1,9 @@ +-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest(@vampires::uuid[], @memories::text[], @victims::text[]) +RETURNING + *; + +-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest(@vampires::uuid[], @memories::text[], @victims::text[]) AS vampires(id, memory, victim); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/schema.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/schema.sql new file mode 100644 index 0000000000..f9e6714af4 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/schema.sql @@ -0,0 +1,12 @@ +CREATE TABLE vampires ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid () +); + +CREATE TABLE memories ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid (), + vampire_id uuid REFERENCES vampires (id) NOT NULL, + memory text NOT NULL, + victim text NOT NULL, + created_at timestamp NOT NULL DEFAULT NOW(), + updated_at timestamp +); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/sqlc.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/sqlc.json new file mode 100644 index 0000000000..007fb8530f --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/sqlc.json @@ -0,0 +1,14 @@ +{ + "version": "1", + "packages": [ + { + "path": "go", + "engine": "postgresql", + "sql_package": "pgx/v5", + "name": "querytest", + "schema": "schema.sql", + "queries": "query.sql", + "emit_interface": true + } + ] +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/db.go b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/db.go new file mode 100644 index 0000000000..0ea90b328a --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/db.go @@ -0,0 +1,31 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" + "database/sql" +) + +type DBTX interface { + ExecContext(context.Context, string, ...interface{}) (sql.Result, error) + PrepareContext(context.Context, string) (*sql.Stmt, error) + QueryContext(context.Context, string, ...interface{}) (*sql.Rows, error) + QueryRowContext(context.Context, string, ...interface{}) *sql.Row +} + +func New(db DBTX) *Queries { + return &Queries{db: db} +} + +type Queries struct { + db DBTX +} + +func (q *Queries) WithTx(tx *sql.Tx) *Queries { + return &Queries{ + db: tx, + } +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/models.go b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/models.go new file mode 100644 index 0000000000..7f48124961 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/models.go @@ -0,0 +1,25 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "database/sql" + "time" + + "github.com/google/uuid" +) + +type Memory struct { + ID uuid.UUID + VampireID uuid.UUID + Memory string + Victim string + CreatedAt time.Time + UpdatedAt sql.NullTime +} + +type Vampire struct { + ID uuid.UUID +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/querier.go b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/querier.go new file mode 100644 index 0000000000..0e41f337f9 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/querier.go @@ -0,0 +1,16 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 + +package querytest + +import ( + "context" +) + +type Querier interface { + CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) + GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) +} + +var _ Querier = (*Queries)(nil) diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/query.sql.go b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/query.sql.go new file mode 100644 index 0000000000..8463eafce1 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/go/query.sql.go @@ -0,0 +1,96 @@ +// Code generated by sqlc. DO NOT EDIT. +// versions: +// sqlc v1.27.0 +// source: query.sql + +package querytest + +import ( + "context" + + "github.com/google/uuid" + "github.com/lib/pq" +) + +const createMemories = `-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest($1::uuid[], $2::text[], $3::text[]) +RETURNING + id, vampire_id, memory, victim, created_at, updated_at +` + +type CreateMemoriesParams struct { + Vampires []uuid.UUID + Memories []string + Victims []string +} + +func (q *Queries) CreateMemories(ctx context.Context, arg CreateMemoriesParams) ([]Memory, error) { + rows, err := q.db.QueryContext(ctx, createMemories, pq.Array(arg.Vampires), pq.Array(arg.Memories), pq.Array(arg.Victims)) + if err != nil { + return nil, err + } + defer rows.Close() + var items []Memory + for rows.Next() { + var i Memory + if err := rows.Scan( + &i.ID, + &i.VampireID, + &i.Memory, + &i.Victim, + &i.CreatedAt, + &i.UpdatedAt, + ); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Close(); err != nil { + return nil, err + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} + +const getMemories = `-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest($1::uuid[], $2::text[], $3::text[]) AS vampires (id, memory, victim) +` + +type GetMemoriesParams struct { + Vampires []uuid.UUID + Memories []string + Victims []string +} + +type GetMemoriesRow struct { + VampiresID uuid.UUID + VampiresMemory string + VampiresVictim string +} + +func (q *Queries) GetMemories(ctx context.Context, arg GetMemoriesParams) ([]GetMemoriesRow, error) { + rows, err := q.db.QueryContext(ctx, getMemories, pq.Array(arg.Vampires), pq.Array(arg.Memories), pq.Array(arg.Victims)) + if err != nil { + return nil, err + } + defer rows.Close() + var items []GetMemoriesRow + for rows.Next() { + var i GetMemoriesRow + if err := rows.Scan(&i.VampiresID, &i.VampiresMemory, &i.VampiresVictim); err != nil { + return nil, err + } + items = append(items, i) + } + if err := rows.Close(); err != nil { + return nil, err + } + if err := rows.Err(); err != nil { + return nil, err + } + return items, nil +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/query.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/query.sql new file mode 100644 index 0000000000..9f68d6a231 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/query.sql @@ -0,0 +1,9 @@ +-- name: CreateMemories :many +INSERT INTO memories (vampire_id, memory, victim) +SELECT + unnest(@vampires::uuid[], @memories::text[], @victims::text[]) +RETURNING + *; + +-- name: GetMemories :many +SELECT vampires.id::uuid, vampires.memory::text, vampires.victim::text FROM unnest(@vampires::uuid[], @memories::text[], @victims::text[]) AS vampires (id, memory, victim); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/schema.sql b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/schema.sql new file mode 100644 index 0000000000..f9e6714af4 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/schema.sql @@ -0,0 +1,12 @@ +CREATE TABLE vampires ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid () +); + +CREATE TABLE memories ( + id uuid PRIMARY KEY DEFAULT gen_random_uuid (), + vampire_id uuid REFERENCES vampires (id) NOT NULL, + memory text NOT NULL, + victim text NOT NULL, + created_at timestamp NOT NULL DEFAULT NOW(), + updated_at timestamp +); diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/sqlc.json b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/sqlc.json new file mode 100644 index 0000000000..36f98f9072 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/sqlc.json @@ -0,0 +1,13 @@ +{ + "version": "1", + "packages": [ + { + "path": "go", + "engine": "postgresql", + "name": "querytest", + "schema": "schema.sql", + "queries": "query.sql", + "emit_interface": true + } + ] +} diff --git a/internal/sql/catalog/public.go b/internal/sql/catalog/public.go index 19fd50722f..899008a387 100644 --- a/internal/sql/catalog/public.go +++ b/internal/sql/catalog/public.go @@ -72,7 +72,7 @@ func (c *Catalog) ResolveFuncCall(call *ast.FuncCall) (*Function, error) { if arg.HasDefault { defaults += 1 } - if arg.Mode == ast.FuncParamVariadic { + if arg.Mode == ast.FuncParamVariadic || arg.Type.Name == "anymultirange" { variadic = true defaults += 1 } From 97a4ecc8caf2ffec508d974f84dad637a6d4d58a Mon Sep 17 00:00:00 2001 From: Charith Ellawala Date: Fri, 6 Dec 2024 12:50:57 +0000 Subject: [PATCH 2/3] Exclude from managed Signed-off-by: Charith Ellawala --- .../testdata/unnest_multiple/postgresql/pgx/v4/exec.json | 5 +++++ .../testdata/unnest_multiple/postgresql/pgx/v5/exec.json | 5 +++++ .../testdata/unnest_multiple/postgresql/stdlib/exec.json | 5 +++++ 3 files changed, 15 insertions(+) create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json create mode 100644 internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json new file mode 100644 index 0000000000..6258471615 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json @@ -0,0 +1,5 @@ +{ + "contexts": [ + "managed-db" + ] +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json new file mode 100644 index 0000000000..6258471615 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json @@ -0,0 +1,5 @@ +{ + "contexts": [ + "managed-db" + ] +} diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json new file mode 100644 index 0000000000..6258471615 --- /dev/null +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json @@ -0,0 +1,5 @@ +{ + "contexts": [ + "managed-db" + ] +} From c63bfdec401990c0fd8ccd2490c2cb14f25be3a7 Mon Sep 17 00:00:00 2001 From: Charith Ellawala Date: Mon, 9 Dec 2024 14:32:45 +0000 Subject: [PATCH 3/3] Change exec.json Signed-off-by: Charith Ellawala --- .../testdata/unnest_multiple/postgresql/pgx/v4/exec.json | 2 +- .../testdata/unnest_multiple/postgresql/pgx/v5/exec.json | 2 +- .../testdata/unnest_multiple/postgresql/stdlib/exec.json | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json index 6258471615..70284f89f1 100644 --- a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v4/exec.json @@ -1,5 +1,5 @@ { "contexts": [ - "managed-db" + "base" ] } diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json index 6258471615..70284f89f1 100644 --- a/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/pgx/v5/exec.json @@ -1,5 +1,5 @@ { "contexts": [ - "managed-db" + "base" ] } diff --git a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json index 6258471615..70284f89f1 100644 --- a/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json +++ b/internal/endtoend/testdata/unnest_multiple/postgresql/stdlib/exec.json @@ -1,5 +1,5 @@ { "contexts": [ - "managed-db" + "base" ] }