118 lines
5.6 KiB
PL/PgSQL
118 lines
5.6 KiB
PL/PgSQL
CREATE OR REPLACE FUNCTION "public"."get_review_files_with_details"("p_keyword" text=NULL::text, "p_typeid" _int4=NULL::integer[], "p_evaluations_status" int4=NULL::integer, "p_date_from" date=NULL::date, "p_date_to" date=NULL::date, "p_sort_order" text='created_at_desc'::text, "p_page" int4=1, "p_page_size" int4=10, "p_document_ids" _int4=NULL::integer[], "p_user_id" int4=NULL::integer)
|
|
RETURNS TABLE("id" int4, "status" varchar, "path" varchar, "file_name" varchar, "file_code" varchar, "file_type_name" varchar, "file_type_id" int4, "file_size" int4, "upload_time" timestamptz, "created_at" timestamptz, "evaluations_status" int4, "audit_status" int4, "created_by_user_id" int4, "issue_count" int8, "total_score" numeric, "pass_count" int8, "warning_count" int8, "fail_count" int8, "manual_count" int8, "issues" jsonb) AS $BODY$
|
|
DECLARE
|
|
offset_val integer;
|
|
sort_column text;
|
|
sort_direction text;
|
|
BEGIN
|
|
offset_val := (p_page - 1) * p_page_size;
|
|
|
|
-- 如果p_user_id为NULL,直接返回0
|
|
IF p_user_id IS NULL THEN
|
|
RETURN;
|
|
END IF;
|
|
|
|
SELECT
|
|
CASE
|
|
WHEN p_sort_order = 'upload_time_asc' THEN 'created_at'
|
|
WHEN p_sort_order = 'upload_time_desc' THEN 'created_at'
|
|
WHEN p_sort_order = 'issue_count_asc' THEN 'issue_count'
|
|
WHEN p_sort_order = 'issue_count_desc' THEN 'issue_count'
|
|
ELSE 'created_at' -- 默认排序字段
|
|
END,
|
|
CASE
|
|
WHEN p_sort_order LIKE '%_asc' THEN 'ASC'
|
|
ELSE 'DESC'
|
|
END
|
|
INTO sort_column, sort_direction;
|
|
|
|
RETURN QUERY EXECUTE format('
|
|
WITH doc_agg AS (
|
|
SELECT
|
|
er.document_id,
|
|
COUNT(*) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = false) AS issue_count,
|
|
SUM(ep.score) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = true) AS total_score,
|
|
COUNT(*) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = true) AS pass_count,
|
|
COUNT(*) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = false AND (ep.suggestion_message_type = ''warning'' OR ep.suggestion_message_type = ''info'')) AS warning_count,
|
|
COUNT(*) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = false AND ep.suggestion_message_type = ''error'') AS fail_count,
|
|
COUNT(*) FILTER (WHERE ep.post_action = ''manual'') AS manual_count,
|
|
jsonb_agg(
|
|
jsonb_build_object(
|
|
''severity'', ep.suggestion_message_type,
|
|
''message'', er.evaluated_results->>''message''
|
|
)
|
|
) FILTER (WHERE (er.evaluated_results->>''result'')::boolean = false) AS issues
|
|
FROM evaluation_results er
|
|
JOIN evaluation_points ep ON er.evaluation_point_id = ep.id
|
|
GROUP BY er.document_id
|
|
)
|
|
SELECT
|
|
d.id,
|
|
d.status,
|
|
d.path,
|
|
d.name AS file_name,
|
|
d.document_number AS file_code,
|
|
dt.name AS file_type_name,
|
|
d.type_id AS file_type_id,
|
|
d.file_size,
|
|
d.upload_time::timestamptz,
|
|
d.created_at,
|
|
d.evaluations_status,
|
|
d.audit_status,
|
|
d.user_id AS created_by_user_id,
|
|
COALESCE(agg.issue_count, 0) AS issue_count,
|
|
COALESCE(agg.total_score, 0) AS total_score,
|
|
COALESCE(agg.pass_count, 0) AS pass_count,
|
|
COALESCE(agg.warning_count, 0) AS warning_count,
|
|
COALESCE(agg.fail_count, 0) AS fail_count,
|
|
COALESCE(agg.manual_count, 0) AS manual_count,
|
|
agg.issues
|
|
FROM documents d
|
|
LEFT JOIN document_types dt ON d.type_id = dt.id
|
|
LEFT JOIN doc_agg agg ON d.id = agg.document_id
|
|
WHERE
|
|
($1 IS NULL OR (d.name ILIKE ''%%'' || $1 || ''%%'' OR d.document_number ILIKE ''%%'' || $1 || ''%%'')) AND
|
|
($2 IS NULL OR d.type_id = ANY($2)) AND
|
|
($3 IS NULL OR d.evaluations_status = $3) AND
|
|
($4 IS NULL OR d.created_at >= $4) AND
|
|
($5 IS NULL OR d.created_at < ($5 + INTERVAL ''1 day'')) AND
|
|
($8 IS NULL OR d.id = ANY($8)) AND
|
|
($9 d.user_id = $9)
|
|
ORDER BY %I %s
|
|
LIMIT $6 OFFSET $7
|
|
', sort_column, sort_direction)
|
|
USING p_keyword, p_typeid, p_evaluations_status, p_date_from, p_date_to, p_page_size, offset_val, p_document_ids, p_user_id;
|
|
END;
|
|
$BODY$
|
|
LANGUAGE plpgsql VOLATILE
|
|
COST 100
|
|
ROWS 1000;
|
|
|
|
-- 同时创建或更新 count_review_files 函数
|
|
CREATE OR REPLACE FUNCTION "public"."count_review_files"("p_keyword" text=NULL::text, "p_typeid" _int4=NULL::integer[], "p_evaluations_status" int4=NULL::integer, "p_date_from" date=NULL::date, "p_date_to" date=NULL::date, "p_document_ids" _int4=NULL::integer[], "p_user_id" int4=NULL::integer)
|
|
RETURNS int4 AS $BODY$
|
|
DECLARE
|
|
total_count integer;
|
|
BEGIN
|
|
-- 如果p_user_id为NULL,直接返回0
|
|
IF p_user_id IS NULL THEN
|
|
RETURN 0;
|
|
END IF;
|
|
|
|
SELECT COUNT(*)
|
|
INTO total_count
|
|
FROM documents d
|
|
WHERE
|
|
(p_keyword IS NULL OR (d.name ILIKE '%' || p_keyword || '%' OR d.document_number ILIKE '%' || p_keyword || '%')) AND
|
|
(p_typeid IS NULL OR d.type_id = ANY(p_typeid)) AND
|
|
(p_evaluations_status IS NULL OR d.evaluations_status = p_evaluations_status) AND
|
|
(p_date_from IS NULL OR d.created_at >= p_date_from) AND
|
|
(p_date_to IS NULL OR d.created_at < (p_date_to + INTERVAL '1 day')) AND
|
|
(p_document_ids IS NULL OR d.id = ANY(p_document_ids)) AND
|
|
d.user_id = p_user_id;
|
|
|
|
RETURN total_count;
|
|
END;
|
|
$BODY$
|
|
LANGUAGE plpgsql STABLE
|
|
COST 100; |