Files
leaudit-platform-frontend/sql/update_get_review_files_with_details.sql
T

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;