一旦开始分配主题,不可避免地会出现分配过时的情况。
我们着手找出它们。
因此,这里是查询,以防它对其他人有用。
有 2 个子查询需要自定义:
SonarSourcers(别问我为什么不直接用“staff”)teams
-- 目标:显示过时分配,
-- 其中过时是指自分配以来 7 天,
-- 并且没有来自 SonarSourcers 的公开活动/“常规”帖子
-- 并且 SonarSourcer 的帖子不是最后一个帖子
WITH
-- 查找所有已分配的主题
assigned_topics AS (
SELECT a.topic_id
, assigned_to_type
, assigned_to_id
FROM assignments a
JOIN topics t ON a.topic_id = t.id
JOIN posts p on p.topic_id = t.id
LEFT JOIN post_custom_fields pcf ON pcf.post_id=p.id AND pcf.name='is_accepted_answer'
WHERE active = true
AND a.updated_at < current_date - INTEGER '7'
AND t.closed = false
AND pcf.id IS NULL
-- AND a.updated_at > '2022-01-01'
ORDER BY t.updated_at desc
),
-- 在每个已分配的主题上,查找最后一个分配(可能有多个)
last_assignment AS (
SELECT max(p.post_number) AS assignment_post, p.topic_id, max(p.created_at) as d
FROM posts p
JOIN assigned_topics ON p.topic_id=assigned_topics.topic_id
WHERE p.action_code in ('assigned', 'assigned_group', 'assigned_group_to_post', 'assigned_to_post')
GROUP BY p.topic_id, p.created_at
),
-- 查找为公司工作的用户
SonarSourcers AS (
SELECT u.id AS user_id
FROM groups g
INNER JOIN group_users gu ON g.id=gu.group_id
INNER JOIN users u ON u.id = gu.user_id
WHERE g.name='sonarsourcers'
),
-- 查找每个人的主要团队
teams AS (
SELECT distinct on (user_id) -- 有些用户有两个组。狭窄(任意)到 1
ss.user_id, g.id as group_id
FROM SonarSourcers ss
JOIN group_users gu on gu.user_id=ss.user_id
JOIN groups g on g.id = gu.group_id
WHERE -- 消除一些重复的组
g.id not in (10, 11, 12, 13, 14 -- 信任级别组
, 1, 2, 3 -- 内置组
, 41 -- SonarSourcers
, 47 -- SonarCloud - 我们想要的是小队
, 53 -- .NET Scanner Guild
)
),
-- 查找来自 SonarSourcer 的已分配主题的最后一个帖子
last_staff_post AS (
SELECT p.id AS post
, p.topic_id
, max(p.created_at) AS last_staff_post
, la.d AS last_assignment_date
FROM posts p
JOIN last_assignment la ON p.topic_id=la.topic_id
JOIN SonarSourcers ss ON ss.user_id=p.user_id
WHERE post_type = 1 -- regular
GROUP BY p.topic_id, p.id,la.d
),
-- 查找主题中的最后一个公开帖子
last_post AS (
SELECT p.topic_id as topic_id, max(p.id) as post_id
FROM posts p
JOIN assigned_topics at ON at.topic_id = p.topic_id
JOIN users u ON p.user_id=u.id
WHERE post_type = 1 -- regular
GROUP BY p.topic_id
),
-- 消除 SonarSourcers 的帖子,以消除我们显然在等待用户的帖子
last_post_trust_level_limit AS (
SELECT lp.topic_id
FROM users u
JOIN posts p ON u.id=p.user_id
JOIN last_post lp ON p.id = lp.post_id
WHERE u.trust_level < 4
),
-- 整合所有内容
stale_topics AS (
SELECT lsp.topic_id
, max(lsp.last_assignment_date) as "Assignment date"
, max(lsp.last_staff_post) as "Last Staff Post"
, CASE WHEN at.assigned_to_type = 'User' THEN u.id END AS user_id
, CASE WHEN at.assigned_to_type = 'Group' THEN g.id ELSE teams.group_id END AS group_id
FROM last_staff_post lsp
JOIN assigned_topics at ON lsp.topic_id=at.topic_id
JOIN last_post_trust_level_limit lptll ON lsp.topic_id = lptll.topic_id
FULL OUTER JOIN users u ON assigned_to_id=u.id
FULL OUTER JOIN teams on teams.user_id=u.id
FULL OUTER JOIN groups g ON assigned_to_id=g.id
WHERE lsp.last_staff_post <= lsp.last_assignment_date + interval '7 days'
GROUP BY at.assigned_to_id, lsp.topic_id, at.assigned_to_type, u.id, g.id, teams.group_id
)
SELECT count(topic_id), user_id, group_id
FROM stale_topics
GROUP BY user_id, group_id
ORDER BY group_id