142 lines
No EOL
4.4 KiB
SQL
142 lines
No EOL
4.4 KiB
SQL
-- name: GetImageByID :one
|
|
SELECT image_id, storage_type, image_path
|
|
FROM images
|
|
WHERE image_id = $1;
|
|
|
|
-- name: CreateImage :one
|
|
INSERT INTO images (storage_type, image_path)
|
|
VALUES ($1, $2)
|
|
RETURNING image_id, storage_type, image_path;
|
|
|
|
-- name: GetUserByID :one
|
|
SELECT user_id, avatar_id, passhash, mail, nickname, disp_name, user_desc, creation_date
|
|
FROM users
|
|
WHERE user_id = $1;
|
|
|
|
-- name: ListUsers :many
|
|
SELECT user_id, avatar_id, passhash, mail, nickname, disp_name, user_desc, creation_date
|
|
FROM users
|
|
ORDER BY user_id
|
|
LIMIT $1 OFFSET $2;
|
|
|
|
-- name: CreateUser :one
|
|
INSERT INTO users (avatar_id, passhash, mail, nickname, disp_name, user_desc, creation_date)
|
|
VALUES ($1, $2, $3, $4, $5, $6, $7)
|
|
RETURNING user_id, avatar_id, nickname, disp_name, user_desc, creation_date;
|
|
|
|
-- name: UpdateUser :one
|
|
UPDATE users
|
|
SET
|
|
avatar_id = COALESCE(sqlc.narg('avatar_id'), avatar_id),
|
|
disp_name = COALESCE(sqlc.narg('disp_name'), disp_name),
|
|
user_desc = COALESCE(sqlc.narg('user_desc'), user_desc),
|
|
passhash = COALESCE(sqlc.narg('passhash'), passhash),
|
|
WHERE user_id = sqlc.arg('user_id')
|
|
RETURNING user_id, avatar_id, nickname, disp_name, user_desc, creation_date;
|
|
|
|
-- name: DeleteUser :exec
|
|
DELETE FROM users
|
|
WHERE user_id = $1;
|
|
|
|
-- name: GetTitleByID :one
|
|
SELECT title_id, title_names, studio_id, poster_id, signal_ids,
|
|
title_status, rating, rating_count, release_year, release_season,
|
|
season, episodes_aired, episodes_all, episodes_len
|
|
FROM titles
|
|
WHERE title_id = $1;
|
|
|
|
-- name: ListTitles :many
|
|
SELECT title_id, title_names, studio_id, poster_id, signal_ids,
|
|
title_status, rating, rating_count, release_year, release_season,
|
|
season, episodes_aired, episodes_all, episodes_len
|
|
FROM titles
|
|
ORDER BY title_id
|
|
LIMIT $1 OFFSET $2;
|
|
|
|
-- name: UpdateTitle :one
|
|
UPDATE titles
|
|
SET
|
|
title_names = COALESCE(sqlc.narg('title_names'), title_names),
|
|
studio_id = COALESCE(sqlc.narg('studio_id'), studio_id),
|
|
poster_id = COALESCE(sqlc.narg('poster_id'), poster_id),
|
|
signal_ids = COALESCE(sqlc.narg('signal_ids'), signal_ids),
|
|
title_status = COALESCE(sqlc.narg('title_status'), title_status),
|
|
release_year = COALESCE(sqlc.narg('release_year'), release_year),
|
|
release_season = COALESCE(sqlc.narg('release_season'), release_season),
|
|
episodes_aired = COALESCE(sqlc.narg('episodes_aired'), episodes_aired),
|
|
episodes_all = COALESCE(sqlc.narg('episodes_all'), episodes_all),
|
|
episodes_len = COALESCE(sqlc.narg('episodes_len'), episodes_len)
|
|
WHERE title_id = sqlc.arg('title_id')
|
|
RETURNING *;
|
|
|
|
-- name: GetReviewByID :one
|
|
SELECT review_id, user_id, title_id, image_ids, review_text, creation_date
|
|
FROM reviews
|
|
WHERE review_id = $1;
|
|
|
|
-- name: CreateReview :one
|
|
INSERT INTO reviews (user_id, title_id, image_ids, review_text, creation_date)
|
|
VALUES ($1, $2, $3, $4, $5)
|
|
RETURNING review_id, user_id, title_id, image_ids, review_text, creation_date;
|
|
|
|
-- name: UpdateReview :one
|
|
UPDATE reviews
|
|
SET
|
|
image_ids = COALESCE(sqlc.narg('image_ids'), image_ids),
|
|
review_text = COALESCE(sqlc.narg('review_text'), review_text)
|
|
WHERE review_id = sqlc.arg('review_id')
|
|
RETURNING *;
|
|
|
|
-- name: DeleteReview :exec
|
|
DELETE FROM reviews
|
|
WHERE review_id = $1;
|
|
|
|
-- name: ListReviewsByTitle :many
|
|
SELECT review_id, user_id, title_id, image_ids, review_text, creation_date
|
|
FROM reviews
|
|
WHERE title_id = $1
|
|
ORDER BY creation_date DESC
|
|
LIMIT $2 OFFSET $3;
|
|
|
|
-- name: ListReviewsByUser :many
|
|
SELECT review_id, user_id, title_id, image_ids, review_text, creation_date
|
|
FROM reviews
|
|
WHERE user_id = $1
|
|
ORDER BY creation_date DESC
|
|
LIMIT $2 OFFSET $3;
|
|
|
|
-- name: GetUserTitle :one
|
|
SELECT usertitle_id, user_id, title_id, status, rate, review_id
|
|
FROM usertitles
|
|
WHERE user_id = $1 AND title_id = $2;
|
|
|
|
-- name: ListUserTitles :many
|
|
SELECT usertitle_id, user_id, title_id, status, rate, review_id
|
|
FROM usertitles
|
|
WHERE user_id = $1
|
|
ORDER BY usertitle_id
|
|
LIMIT $2 OFFSET $3;
|
|
|
|
-- name: CreateUserTitle :one
|
|
INSERT INTO usertitles (user_id, title_id, status, rate, review_id)
|
|
VALUES ($1, $2, $3, $4, $5)
|
|
RETURNING usertitle_id, user_id, title_id, status, rate, review_id;
|
|
|
|
-- name: UpdateUserTitle :one
|
|
UPDATE usertitles
|
|
SET
|
|
status = COALESCE(sqlc.narg('status'), status),
|
|
rate = COALESCE(sqlc.narg('rate'), rate),
|
|
review_id = COALESCE(sqlc.narg('review_id'), review_id)
|
|
WHERE user_id = $1 AND title_id = $2
|
|
RETURNING *;
|
|
|
|
-- name: DeleteUserTitle :exec
|
|
DELETE FROM usertitles
|
|
WHERE user_id = $1 AND ($2::int IS NULL OR title_id = $2);
|
|
|
|
-- name: ListTags :many
|
|
SELECT tag_id, tag_names
|
|
FROM tags
|
|
ORDER BY tag_id
|
|
LIMIT $1 OFFSET $2; |