JIRA数据库及常用SQL

1 JIRA数据库能实现的功能?

1 做效能数据分析,定义好规则后,可以通过帆软报表展示出来

参考JIRA之质量效能指标  和 JIRA效能指标统计与展示

2 项目日常管理,数据收集

大部分情况下,我们都可以通过筛选器进行项目过程中数据的分析。 但是少数情况,筛选器无法过滤出来的,我们就可以考虑直接读取数据库信息来分析。

3 项目成员考核指标数据分析

参考软件企业各角色绩效考核指标设计,比如 考核测试人员的测试用例产出率,测试阶段有效bug数等,就可以通过读取数据库等方式来分析

4 项目管理运行标准化分析

当公司产研规模比较大的时候,管理制度的统一就显得尤为重要。 那么制定了项目管理规则后,如果来检查过程中的执行规范性呢? 一方面就可以通过周期性读取项目空间数据库  另一方面可以通过JIRA api 实现的脚本来定期检查分析

2 JIRA数据库常用SQL?

我写过两个脚本 1 是分析项目效能数据的  2 是定期检查项目运行情况的,这里我列举了一些查询的案例,供参考。

2.1 查询问题所属 epic

select d.Stringvalue

from jiraissue a ,issuelink b, customfieldvalue d

where

b.LINKTYPE='10200'

and b.SOURCE=a.ID

and b.DESTINATION=c.id

and d.issue=a.id

and d.customfield='10004'


2.2 按项目查询所有 backlog

select

p.pname as `project`,

c.SUMMARY,

c.description,

(select iss.pname from issuestatus iss where c.issuestatus=iss.id) as `status`,

(select cfv.TEXTVALUE from customfieldvalue cfv where cfv.CUSTOMFIELD='12000' and

cfv.ISSUE=c.id limit 1) as `AC`,

(select d.Stringvalue from jiraissue a ,issuelink b, customfieldvalue d where

b.LINKTYPE='10200' and b.SOURCE=a.ID and b.DESTINATION=c.id and d.issue=a.id and

d.customfield='10004') as `EPIC`,

(select format(cfv.NUMBERVALUE,1) from customfieldvalue cfv where

cfv.CUSTOMFIELD='10006' and cfv.ISSUE=c.id limit 1) as `storypoint`,

(select sp.`name` from customfieldvalue cfv, AO_60DB71_SPRINT sp where

cfv.CUSTOMFIELD='10001' and cfv.ISSUE=c.id and cfv.STRINGVALUE=sp.id order by sp.id

desc limit 1 ) as `sprint`

from

jiraissue c, project p

where

p.id in ('12900','12901','12902','12903','12904')

and c.PROJECT=p.id

and c.issuetype='10001'

2.3 查询进行中的冲刺的故事详情

select

a.id,

a.issuenum, -- issue key

a.assignee, -- 经办人

a.summary, -- 概要

a.RESOLUTIONDATE, -- 解决结果

sp.`NAME` as sprint, --冲刺名称

(select pname from issuestatus c where c.id=a.issuestatus) as issuestatus, --问题状态

(select TRUNCATE(b.numbervalue,1) from customfieldvalue b where b.issue=a.id and

b.customfield ='10006') storypoint –故事点数

from

jiraissue a,

customfieldvalue cf,

AO_60DB71_SPRINT sp

where

a.project = '12203'

and a.issuetype='10001 -- 问题类型=Story

and a.ID = cf.ISSUE

and cf.STRINGVALUE = sp.ID

and cf.CUSTOMFIELD='10001'

and sp.id in (

    select sp.id

    from AO_60DB71_SPRINT sp

    where FROM_UNIXTIME(sp.START_DATE/1000) < NOW()  AND

    FROM_UNIXTIME(sp.END_DATE/1000) >now()

)

2.4 查询一月未登录用户

Select

a.user_key,c.display_name,

FROM_UNIXTIME(attr.attribute_value/1000,'%Y-%m-%d'),

m.parent_name

from

app_user a , cwd_user c, cwd_user_attributes attr, cwd_membership m

where

a.lower_user_name=c.lower_user_name

AND c.id=attr.user_id

and a.id=m.child_id

and attr.attribute_name ='login.lastLoginMillis'

and DATEDIFF(CURDATE(),FROM_UNIXTIME(attr.attribute_value/1000))>=30

and m.parent_name in ('jira-software-users')

2.5  查询指定冲刺下所有的故事和任务

SELECT DISTINCT jiraissue.id, jiraissue.issuenum,jiraissue.assignee, jiraissue.summary

From incr_z_table_jiraissue AS jiraissue,

incr_z_table_customfieldvalue AS customfieldvalue,

incr_z_table_ao_60db71_sprint AS sprint

WHERE (jiraissue.issuetype = '10001' --故事类型

Or jiraissue.issuetype = '10002') --  任务类型

AND customfieldvalue.CUSTOMFIELD = 10004 -- 代表sprint的customfield

AND sprint.id = {0} -- 冲刺号

AND customfieldvalue.stringvalue = cast(sprint.id as VARCHAR) -- customfield是1004 而且 对应的sprint号是 1735的

AND customfieldvalue.issue = jiraissue.id --符合以上条件的两张表里的issue 相同的数据

AND jiraissue.log_time =

(

    select max(log_time)

    FROM incr_z_table_jiraissue AS jiraissue

)

2.6  查询指定故事下所有的子任务

SELECT DISTINCT jiraissue1.id, jiraissue1.issuenum,jiraissue1.assignee,jiraissue1.timeoriginalestimate

From incr_z_table_jiraissue AS jiraissue1,

incr_z_table_issuelink AS issuelink, incr_z_table_jiraissue AS jiraissue2

where jiraissue1.issuetype = '10003' -- 子类型是子任务

AND issuelink.LINKTYPE = 10100  -- 链接类型是父子链接

AND jiraissue1.id = issuelink.destination -- 链接目标对象

AND issuelink.source = jiraissue2.id

AND jiraissue2.id = {0}  -- 父故事or任务的issue id

and jiraissue1.log_time =

(

    select max(jiraissue.log_time)

    FROM incr_z_table_jiraissue as jiraissue

)

and jiraissue2.log_time =

(

    select max(jiraissue.log_time)

    FROM incr_z_table_jiraissue as jiraissue

)

2.7  查询指定项目所有的冲刺

SELECT DISTINCT sprint.id, sprint.name, FROM_UNIXTIME(sprint.START_DATE/1000), FROM_UNIXTIME(sprint.END_DATE/1000),FROM_UNIXTIME(sprint.complete_date/1000), sprint.closed, sprint.started

From incr_z_table_jiraissue AS jiraissue,

incr_z_table_customfieldvalue AS customfieldvalue,

incr_z_table_ao_60db71_sprint AS sprint

where jiraissue.project = {0} -- 输入项目参数

AND customfieldvalue.CUSTOMFIELD = 10004 --代表sprint的customfield

AND customfieldvalue.stringvalue = cast(sprint.id as VARCHAR)

AND  customfieldvalue.issue = jiraissue.id

AND jiraissue.issuetype = '10001'

AND sprint.id in (

select sprint.id

From incr_z_table_ao_60db71_sprint AS sprint

where FROM_UNIXTIME(sprint.START_DATE/1000) <NOW() AND  sprint.closed = FALSE and sprint.started = true

)

AND sprint.closed = FALSE and sprint.started = true

AND FROM_UNIXTIME(sprint.START_DATE/1000) <NOW()

2.8 本周bug新建数

SELECT 'Bug Created' AS `Catalog`, count(1) AS `NUM` FROM jiraissue WHERE issuetype = '10401' AND project in ('12203','12100','12703','12802','12800','12936','12944') AND CREATED BETWEEN @startdate AND @enddate;

2.9 任务按时完成率

SELECT b.total,b.num,TRUNCATE (b.num / b.total, 2) AS `ratio`

FROM

(

SELECT count(DISTINCT a.id) AS `total`, count((((DATEDIFF(duedate, resolutiondate) >=- 1 or DUEDATE is null) and resolutiondate<=@enddate) ) OR NULL ) AS `num`

FROM jiraissue a , issuelink b , customfieldvalue cf  , AO_60DB71_SPRINT sp

WHERE a.project in ('12203','12100','12703','12802','12800','12936','12944')  and a.issuetype='10202'

AND a.ID=b.DESTINATION and b.LINKTYPE='10100'

AND b.SOURCE = cf.ISSUE  AND cf.CUSTOMFIELD = '10001'  AND cf.STRINGVALUE = sp.ID

AND sp.id IN

(

SELECT sp.id FROM AO_60DB71_SPRINT sp WHERE FROM_UNIXTIME(sp.START_DATE / 1000) < @curdate AND FROM_UNIXTIME(sp.END_DATE / 1000) > @curdate

)

) b;

2.10  各状态任务统计

select c.pname as `issuestatus`, count(a.id) as `NUM`

FROM jiraissue a , issuelink b , customfieldvalue cf  , AO_60DB71_SPRINT sp,issuestatus c

WHERE a.project in ('12203','12100','12703','12802','12800','12936','12944')  and a.issuetype='10202'

AND a.ID=b.DESTINATION and b.LINKTYPE='10100'

AND b.SOURCE = cf.ISSUE  AND cf.CUSTOMFIELD = '10001'  AND cf.STRINGVALUE = sp.ID

  and a.issuestatus=c.ID

AND sp.id IN

(

SELECT sp.id FROM AO_60DB71_SPRINT sp WHERE FROM_UNIXTIME(sp.START_DATE / 1000) < @curdate AND FROM_UNIXTIME(sp.END_DATE / 1000) > @curdate

)

group BY c.pname;

2.11 各项目按时完成率

SELECT b.project,b.Sprint, b.total,TRUNCATE (b.num / b.total, 2) AS `ratio`

FROM

(

SELECT p.pname as `Project`,sp.`NAME` as `Sprint`,count(DISTINCT a.id) AS `total`, count((((DATEDIFF(duedate, resolutiondate) >=- 1  and resolutiondate<=@enddate)or DUEDATE is null) ) OR NULL ) AS `num`

FROM jiraissue a , issuelink b , customfieldvalue cf  , AO_60DB71_SPRINT sp, project p

WHERE a.project in ('12203','12100','12703','12802','12800','12936','12944')  and a.issuetype='10202'

AND a.ID=b.DESTINATION and b.LINKTYPE='10100'

AND b.SOURCE = cf.ISSUE  AND cf.CUSTOMFIELD = '10001'  AND cf.STRINGVALUE = sp.ID

  AND a.PROJECT=p.ID

AND sp.id IN

(

SELECT sp.id FROM AO_60DB71_SPRINT sp WHERE FROM_UNIXTIME(sp.START_DATE / 1000) < @curdate AND FROM_UNIXTIME(sp.END_DATE / 1000) > @curdate

)

  group by a.project,sp.`NAME`

) b

order BY ratio desc;

2.12 任务和故事周转时长

SELECT j.project, j.task_cycle, b.story_cycle

FROM

(

SELECT p.pname AS `project`, FORMAT( avg( TIMESTAMPDIFF(DAY, CREATED, RESOLUTIONDATE) ),1 ) AS `task_cycle`

FROM jiraissue a, project p

WHERE

issuetype in ('10202') AND a.PROJECT = p.id and a.project in ('12203','12100','12703','12802','12800','12936','12944')  AND RESOLUTIONDATE BETWEEN @startdate AND @enddate

GROUP BY p.pname

) j,

(

SELECT p.pname as `project`, FORMAT( avg( TIMESTAMPDIFF(DAY, a.startdate, a.RESOLUTIONDATE) ), 1 ) AS `story_cycle`

FROM

(

select a.id,a.project, FROM_UNIXTIME(min(sp.START_DATE)/1000) as `startdate`, a.RESOLUTIONDATE

from jiraissue a, customfieldvalue cf, AO_60DB71_SPRINT sp

where a.ID = cf.ISSUE AND cf.STRINGVALUE = sp.ID AND cf.CUSTOMFIELD = '10001' and a.project in ('12203','12100','12703','12802','12800','12936','12944')  AND RESOLUTIONDATE BETWEEN @startdate AND @enddate

group by a.id,a.project, a.RESOLUTIONDATE

) a, project p

where p.ID=a.project

group BY a.project

) b

WHERE j.project = b.project;

2.13 人员未按时完成任务排名

SELECT (SELECT u.display_name FROM cwd_user u, app_user b WHERE a.ASSIGNEE = b.user_key AND b.lower_user_name = u.lower_user_name ORDER BY u.directory_id DESC LIMIT 1 ) AS `ASSIGNEE`

  ,COUNT(a.id) as `total`,count( DATEDIFF(duedate, resolutiondate) <- 1 or null) as `num`

  ,TRUNCATE(count( DATEDIFF(duedate, resolutiondate) <- 1 or null) /COUNT(a.id),2) as `ratio`

FROM jiraissue a , issuelink b , customfieldvalue cf  , AO_60DB71_SPRINT sp

WHERE a.project in ('12203','12100','12703','12802','12800','12936','12944')  and a.issuetype='10202'

AND a.ID=b.DESTINATION and b.LINKTYPE='10100'

AND b.SOURCE = cf.ISSUE  AND cf.CUSTOMFIELD = '10001'  AND cf.STRINGVALUE = sp.ID

AND sp.id IN

(

SELECT sp.id FROM AO_60DB71_SPRINT sp WHERE FROM_UNIXTIME(sp.START_DATE / 1000) < @curdate AND FROM_UNIXTIME(sp.END_DATE / 1000) > @curdate

)

group by ASSIGNEE

having num >0

order by ratio desc;

2.14 项目缺陷密度

 SELECT project.pname AS `project`, sp2. NAME AS `sprint`, x.bugs / x.storypoint AS `bug/storypoint`

FROM

(

SELECT sp1.project, sp1.SprintId AS `SprintId`,

(SELECT sum( TRUNCATE (storypoint.numbervalue, 1) ) storypoint

FROM jiraissue a, customfieldvalue storypoint, customfieldvalue cf

WHERE a.issuetype in ('10001') AND a.RESOLUTIONDATE<=@enddate AND a.id = storypoint.issue

AND storypoint.customfield = '10006' AND a.ID = cf.ISSUE AND cf.STRINGVALUE = sp1.SprintId AND cf.CUSTOMFIELD = '10001'

) AS `storypoint`,

(SELECT count(1)  FROM jiraissue WHERE jiraissue.project = sp1.project AND jiraissue.CREATED BETWEEN sp1.start_Date AND if(sp1.end_Date<@curdate,sp1.end_date,@curdate) AND jiraissue.issuetype = '10401' ) AS `bugs`

FROM

(

SELECT DISTINCT a.PROJECT, sp.id AS `SprintId`, FROM_UNIXTIME( sp.START_DATE / 1000, '%Y/%m/%d') AS `start_Date`,FROM_UNIXTIME( sp.END_DATE / 1000,'%Y/%m/%d') AS `end_date`

FROM jiraissue a, customfieldvalue cf, AO_60DB71_SPRINT sp

WHERE a.ID = cf.ISSUE

AND cf.STRINGVALUE = sp.ID AND cf.CUSTOMFIELD = '10001' AND FROM_UNIXTIME(sp.START_DATE / 1000) <= @curdate AND FROM_UNIXTIME(sp.END_DATE / 1000) >= @curdate

) sp1

) x, project, AO_60DB71_SPRINT sp2

WHERE x.project = project.id AND sp2.id = x.sprintid and project.id in ('12203','12100','12703','12802','12800','12936','12944')

ORDER BY `bug/storypoint` DESC;

3 JIRA数据库地图

不同版本可能会存在差异,仅供参考

百度网盘地址贴上来,文章就被禁用了,所以需要excel版本的数据库地图 可以留言邮箱给我。

如果失效了,就参考如下截图










最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容