[我的] SQL查询语法,需要进行foreach处理

时间:2016-05-25 07:10:43

标签: mysql sql tsql

我有一个SQL查询任务,我可以在C#或linqpad中做好,但更喜欢它在SQL中,所以标准的报告工具可以做到这一点。

End DB是MySQL下的bugzilla

  
    

问题是我需要遍历bug_activity寻找特定的更改以考虑父记录"有效",如何?     例如伪逻辑如

  
  if bug_status went to IN BACKLOG
  then bug_status went to ASSIGNED 
  and this happened 2016-03-01 to 206-03-31 
  then consider valid record
  
    

我不确定如何做到这一点,因为网页示例仅显示DECLARE和LOOP,但循环如何适应" select,from,where"代码。

  
set @BugID = 64252;

select
     bugs_activity.bug_id,
--   profiles.realname,
--   profiles.login_name,
     bugs_activity.bug_when,
     fielddefs.name, 
     bugs_activity.added
--   bugs_activity.removed
from
     bugs_activity,
     profiles,
     fielddefs

-- Real world 'Where xx' will have more logic and result in a number of bugzilla records 
-- Each bugzilla record has its own 'bugs_activity'
-- Logic needs to look at each buzilla records historyto filter results 
-- Want to end up with a filtered record set and a total number of records
Where  bug_id = @BugID AND bugs_activity.who = profiles.userid AND bugs_activity.fieldid = fielddefs.id

bug_activity的示例

bug_id bug_when name added
64252 26/01/2016 6:51:30 AM status_whiteboard ID:103138574 
64252 26/01/2016 6:52:10 AM cc xxx@abc.com 
64252 28/01/2016 9:49:10 AM bug_status IN BACKLOG 
64252 28/01/2016 9:49:10 AM cf_escalation_notes Effort: 2
Reproduced by support 
64252 28/01/2016 9:49:10 AM assigned_to def@abc.com 
64252 2/05/2016 4:33:05 PM bug_status ASSIGNED 

1 个答案:

答案 0 :(得分:1)

SELECT 
  bug_id,
  SUM(CASE WHEN bug_status='IN BACKLOG' THEN 1 ELSE 0 END) as backlogCount,
  SUM(CASE WHEN bug_status='ASSIGNED' THEN 1 ELSE 0 END) as assignedCount
FROM bugs_activity
WHERE action_date BETWEEN '2016-03-01' AND '206-03-31'
GROUP BY bug_id
HAVING backlogCount>0 AND assignedCount>0

select返回在此期间处于“IN BACKLOG”和“ASSIGNED”状态的bug_ids。您可以在FROM部分使用上述查询,而不是bugs_activity

更新:

添加SELECT部分​​

  MAX(CASE WHEN bug_status='IN BACKLOG' THEN action_date ELSE NULL END) as backlogDate,
  MAX(CASE WHEN bug_status='ASSIGNED' THEN action_date ELSE NULL END) as assignedDate

然后在HAVING部分AND backlogDate<assignedDate