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.
125 lines
4.0 KiB
125 lines
4.0 KiB
-- name: GetItem :one
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.id = ?;
|
|
|
|
-- name: ListItemsByProject :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE pr.project_id = ?;
|
|
|
|
-- name: ListItemsAcquiredBetween :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.acquired_time >= ?
|
|
AND i.acquired_time <= ?
|
|
AND i.scope_id = ?
|
|
ORDER BY acquired_time DESC, created_time DESC;
|
|
|
|
-- name: ListItemsScheduledBetween :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.scheduled_date >= ?
|
|
AND i.scheduled_date <= ?
|
|
AND i.scope_id = ?
|
|
ORDER BY scheduled_date, created_time;
|
|
|
|
-- name: ListItemsCreatedBetween :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.created_time >= ?
|
|
AND i.created_time <= ?
|
|
AND i.scope_id = ?
|
|
ORDER BY created_time DESC;
|
|
|
|
-- name: ListItemsLooseBetween :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.created_time >= ?
|
|
AND i.created_time <= ?
|
|
AND i.scope_id = ?
|
|
AND i.scheduled_date IS NULL
|
|
AND i.acquired_time IS NULL
|
|
AND i.project_requirement_id IS NULL
|
|
ORDER BY created_time DESC;
|
|
|
|
-- name: ListItemsScheduledBetweenNoScope :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.scheduled_date >= ?
|
|
AND i.scheduled_date < ?;
|
|
|
|
-- name: ListItemsCreatedBetweenNoScope :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.created_time >= ?
|
|
AND i.created_time < ?;
|
|
|
|
-- name: ListItemsLooseBetweenNoScope :many
|
|
SELECT i.*, pr.project_id FROM item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
WHERE i.created_time >= ?
|
|
AND i.created_time < ?
|
|
AND i.scheduled_date IS NULL
|
|
AND i.acquired_time IS NULL;
|
|
|
|
-- name: GetItemStatProgressBetween :one
|
|
SELECT s.id, s.name, s.weight, SUM(isp.acquired), SUM(isp.required) FROM item i
|
|
LEFT JOIN item_stat_progress isp on i.id = isp.item_id
|
|
LEFT JOIN stat s on isp.stat_id = s.id
|
|
WHERE i.acquired_time >= ?
|
|
AND i.acquired_time < ?
|
|
AND i.scope_id = ?
|
|
GROUP BY stat_id;
|
|
|
|
-- name: ListItemStatProgress :many
|
|
SELECT isp.required, isp.acquired, s.id, s.name, s.weight FROM item_stat_progress isp
|
|
LEFT JOIN stat s ON s.id = isp.stat_id
|
|
WHERE item_id = ?;
|
|
|
|
-- name: ListItemStatProgressMulti :many
|
|
SELECT isp.item_id, isp.required, isp.acquired, s.id, s.name, s.weight FROM item_stat_progress isp
|
|
LEFT JOIN stat s ON s.id = isp.stat_id
|
|
WHERE item_id IN (?, ?, ?, ?, ?, ?, ?, ?);
|
|
|
|
-- name: InsertItem :execresult
|
|
INSERT INTO item (scope_id, project_requirement_id, name, description, created_time, created_user_id, acquired_time, scheduled_date)
|
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?);
|
|
|
|
-- name: UpdateItem :exec
|
|
UPDATE item
|
|
SET project_requirement_id = ?,
|
|
name = ?,
|
|
description = ?,
|
|
acquired_time = ?,
|
|
scheduled_date = ?,
|
|
created_user_id = ?
|
|
WHERE id = ?;
|
|
|
|
-- name: DeleteItem :exec
|
|
DELETE FROM item WHERE id = ?;
|
|
|
|
-- name: DeleteItemForRequirement :exec
|
|
DELETE FROM item WHERE project_requirement_id = ?;
|
|
|
|
-- name: ClearItemProjectRequirement :exec
|
|
UPDATE item SET project_requirement_id = NULL WHERE project_requirement_id = ?;
|
|
|
|
-- name: ClearItemProjectRequirementByProjectID :exec
|
|
UPDATE item i
|
|
LEFT JOIN project_requirement pr ON pr.id = i.project_requirement_id
|
|
SET i.project_requirement_id = NULL
|
|
WHERE pr.project_id = ?;
|
|
|
|
-- name: ReplaceItemStatProgress :exec
|
|
REPLACE INTO item_stat_progress (item_id, stat_id, acquired, required)
|
|
VALUES (?, ?, ?, ?);
|
|
|
|
-- name: DeleteItemStatProgress :exec
|
|
DELETE FROM item_stat_progress WHERE item_id = ? AND stat_id = ?;
|
|
|
|
-- name: ClearItemStatProgress :exec
|
|
DELETE FROM item_stat_progress WHERE item_id = ?;
|
|
|
|
-- name: CLearItemStatProgressByStat :exec
|
|
DELETE FROM item_stat_progress WHERE stat_id = ?;
|