|
|
-- 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 = ?;
|