GraphQL API and utilities for the rpdata project
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

50 lines
1.9 KiB

-- name: SelectCharacterByID :one
SELECT * FROM data_character WHERE id = sqlc.arg(id)::text;
-- name: SelectCharacterByNick :one
SELECT * FROM data_character WHERE nicks <@ ARRAY[sqlc.arg(nick)::text];
-- name: SelectCharacterByName :one
SELECT * FROM data_character WHERE name = sqlc.arg(name)::text;
-- name: SelectCharacters :many
SELECT * FROM data_character
WHERE (sqlc.arg(filter_id)::bool = false OR id = ANY(sqlc.arg(ids)::text[]))
AND (sqlc.arg(filter_name)::bool = false OR name = ANY(sqlc.arg(names)::text[]))
AND (sqlc.arg(filter_nick)::bool = false OR nicks && (sqlc.arg(nicks)::text[]))
AND (sqlc.arg(filter_author)::bool = false OR author = sqlc.arg(author)::text)
AND (sqlc.arg(filter_search)::bool = false OR "ts_vector" @@ to_tsquery(sqlc.arg(search)::text))
LIMIT sqlc.arg(limit_size)::int;
-- name: InsertCharacter :exec
INSERT INTO data_character (id, nicks, name, short_name, author, description, ts_vector) VALUES (
sqlc.arg(id)::text, sqlc.arg(nicks)::text[], sqlc.arg(name)::text,
sqlc.arg(short_name)::text, sqlc.arg(author)::text, sqlc.arg(description)::text,
to_tsvector(
'english',
sqlc.arg(name)::text || ' ' || sqlc.arg(description)::text || ' ' || sqlc.arg(author)::text || ' '
|| immutable_array_to_string(
sqlc.arg(nicks)::text[], ' '
)
)
);
-- name: UpdateCharacter :exec
UPDATE data_character
SET name=sqlc.arg(name)::text,
short_name=sqlc.arg(short_name)::text,
description=sqlc.arg(description)::text
WHERE id=sqlc.arg(id)::text;
-- name: AddCharacterNick :exec
UPDATE data_character
SET nicks=append(nicks, sqlc.arg(nick)::text)
WHERE id=sqlc.arg(id)::text;
-- name: RemoveCharacterNick :exec
UPDATE data_character
SET nicks=array_remove(nicks, sqlc.arg(nick)::text)
WHERE id=sqlc.arg(id)::text;
-- name: DeleteCharacter :exec
DELETE FROM data_character WHERE id=$1;