Redmine数据表字段说明
Redmine数据表结构
issues
tracker_id 跟踪标签的id,外键到trakers表
project_id 外键到项目project
subject 主题
description 问题描述
due_data 期望完成时间
category_id 类别,外键到issue_categories表
status_id 状态,外键到issue_statuses表
assigned_to_id 指派给的用户id,外键到user表
priority_id 优先级,没找到这个表
fixed_version_id 周版本的id,外键到version表
author_id 作者的id,外键到user表
created_on 创建时间,有时候不用这个创建时间而是用journals的创建时间是为了获取修改时间
updated_on 更新时间
start_date 问题开始日期
estimated_hours 预计工时
parent_id 父任务id,外键到另一个issue
root_id 任务关系树根节点的id
创建脚本:
CREATE TABLE `issues` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`tracker_id` int(11) NOT NULL DEFAULT '0',
`project_id` int(11) NOT NULL DEFAULT '0',
`subject` varchar(255) NOT NULL DEFAULT '',
`description` text,
`due_date` date DEFAULT NULL,
`category_id` int(11) DEFAULT NULL,
`status_id` int(11) NOT NULL DEFAULT '0',
`assigned_to_id` int(11) DEFAULT NULL,
`priority_id` int(11) NOT NULL DEFAULT '0',
`fixed_version_id` int(11) DEFAULT NULL,
`author_id` int(11) NOT NULL DEFAULT '0',
`lock_version` int(11) NOT NULL DEFAULT '0',
`created_on` datetime DEFAULT NULL,
`updated_on` datetime DEFAULT NULL,
`start_date` date DEFAULT NULL,
`done_ratio` int(11) NOT NULL DEFAULT '0',
`estimated_hours` float DEFAULT NULL,
`parent_id` int(11) DEFAULT NULL,
`root_id` int(11) DEFAULT NULL,
`lft` int(11) DEFAULT NULL,
`rgt` int(11) DEFAULT NULL,
`is_private` tinyint(1) NOT NULL DEFAULT '0',
`closed_on` datetime DEFAULT NULL,
`deleted` tinyint(1) DEFAULT '0',
`acp_id` int(11) DEFAULT NULL,
`cache_timestamp` int(11) DEFAULT '0',
`is_kanban_node` tinyint(1) DEFAULT '0',
`standard_status` int(11) DEFAULT '1',
`qa_kanban_status` int(11) DEFAULT NULL,
`last_status_change_type` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `index_issues_on_acp_id` (`acp_id`),
KEY `issues_project_id` (`project_id`),
KEY `index_issues_on_status_id` (`status_id`),
KEY `index_issues_on_category_id` (`category_id`),
KEY `index_issues_on_assigned_to_id` (`assigned_to_id`),
KEY `index_issues_on_fixed_version_id` (`fixed_version_id`),
KEY `index_issues_on_tracker_id` (`tracker_id`),
KEY `index_issues_on_priority_id` (`priority_id`),
KEY `index_issues_on_author_id` (`author_id`),
KEY `index_issues_on_created_on` (`created_on`),
KEY `index_issues_on_root_id_and_lft_and_rgt` (`root_id`,`lft`,`rgt`),
KEY `index_issues_is_kanban_node` (`is_kanban_node`)
) ENGINE=InnoDB AUTO_INCREMENT=48760 DEFAULT CHARSET=utf8
journals
每一次更新issue都会生成一条journal和对应的journal_detail
journalized_id 对应的issue_id,但不是外键
journalized_type 把所有数据取出来去重后,发现这个字段只有一个值,Issue
user_id User的外键
created_on 生成journal的时间
创建脚本:
CREATE TABLE `journals` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`journalized_id` int(11) NOT NULL DEFAULT '0',
`journalized_type` varchar(30) NOT NULL DEFAULT '',
`user_id` int(11) NOT NULL DEFAULT '0',
`notes` text,
`created_on` datetime NOT NULL,
`private_notes` tinyint(1) NOT NULL DEFAULT '0',
`is_auto_flow` tinyint(1) DEFAULT '0',
PRIMARY KEY (`id`),
KEY `journals_journalized_id` (`journalized_id`,`journalized_type`),
KEY `index_journals_on_user_id` (`user_id`),
KEY `index_journals_on_journalized_id` (`journalized_id`),
KEY `index_journals_on_created_on` (`created_on`)
) ENGINE=InnoDB AUTO_INCREMENT=204197 DEFAULT CHARSET=utf8
journal_details
journal_id 外键到journal
prop_key 对issue改动了什么属性,比如"status_id"
property 改动的属性名
old_value 属性旧值
value 属性新值
issue_statuses
name 新建、完成、关闭等
is_closed 只有完成这里是1
is_default 一般id为1的是默认状态
position 列表位置,一般跟id一致
projects
不同用户会有不同的project权限
name 中文名
description 描述,可为空
is_public 一般为1
parent_id 父项目的id
created_on 创建时间
updated_on 更新时间
identifier 项目的英文标识
status 都是1, 暂不清楚其他值的含义
lft、rgt
nested set is the way Redmine stores trees in SQL.
相当于此节点的左右范围,并不是左右节点
parent.lft<child.lft and child.rgt>parent.rgt
如何遍历这种树:Modified Preorder Tree Traversal
trackers
不同project里有不同的跟踪标签,以project_trackers表关联
name 中文名
position 列表位置
custom_fields
比如“跟进者”就是一个自定义字段,实际的值是存在custom_values表中的
type 修饰对象的类型,如果是Project的自定义对象,值为ProjectCustomField;如果是Issue的,值为IssueCustomField
name 中文名
field_format 该字段的格式,可以是list、bool、date、issue_status、user等值,比如跟进者的字段格式就是user
possible_value 可能的值,一般list、bool格式的这个字段会有值,其他多为空值
is_required 是否必填
is_for_all 有一些自定义字段不是对所有人都开放的
searchable 一般list格式的这个字段会是1
default_value 默认值
editable 是否可修改
custom_values
相当于issue或project与custom_fields的关联表
customized_type 可以是Project或Issue
customized_id 修饰对象的id,如果是Issue,那就是issue的id
custom_field_id 外键到custom_field
value 实际的值
Redmine数据表字段说明的更多相关文章
- tp数据表字段缓存
在维护一个tp写的项目,因为需要在产品表product中增加了一个字段status,但是不论如何就是无法给status赋值,查了资料才发现,原来是tp的数据表字段缓存在搞鬼. 在runtime> ...
- tp5.0 SHOW COLUMNS FROM 生成数据表字段缓存
TP5.0 生成数据表字段缓存 =控制台执行以下命令= 1.生成指定数据库的所有表字段缓存 php think optimize:schema --db databaseName 2.生成指定数据表的 ...
- Mysql数据表字段设置了默认值,插入数据后默认字段的值却为null,不是默认值
我将mysql的数据表的某个字段设置了默认值为1,当向该表插入数据的时候该字段的值不是默认值,而是null. 我的错误原因: 对数据库的操作我使用了持久化工具mybatis,插入数据的时候插入的是整个 ...
- 132_Power BI之建模必备要素&Power Query之数据表字段名称管理
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 近段时间比较忙,也没有看到很好的DAX素材,很久没有更新文章了,刚好有时间就来凑个热闹. 今天主题是Power ...
- laravel 同数据表字段比较查询和状态不正规排序
今天写群组推荐接口,要求未满的群 ( 群最大人数字段maxusers, 群人数字段affiliations_count 都在群组表中),官方,热门(普通群0 ,官方1,热门2 ) 排序的群 同表字段比 ...
- phome_enewsclass 数据表字段解释(栏目主表)
字段名 类型 解释 附加说明 classid smallint(6) 栏目ID bclassid smallint(6) 父栏目ID classname varchar(50) 栏目名称 ...
- 读取MySQL数据表字段信息
TP5句式 $fieldinfo = Db::query('SHOW FULL COLUMNS FROM '.$table);//查出数据表所有字段信息Field 字段Comment 字段注释
- Mysql数据表字段扩充的小技巧
在开发中,往往需求变更比开发速度要快,就会存在一些问题,比如突然要增加一个字段,我们需要 alter table 表名 add [column] 字段名 数据类型 [列属性] [位置]; 然后修改实体 ...
- phome_ecms_news 数据表字段解释(新闻系统模型-主表)
http://www.phome.net/doc/manual/extend/html/dbdoc/index.html 字段名 类型 解释 附加说明 id int(11) 信息ID classi ...
随机推荐
- Fastqc使用说明
用FastQC检查二代测序原始数据的质量 2013-01-28 21:28:10| 分类: Bioinformatics | 标签:bioinformatics deep-seq |举报 | ...
- 关于2013年1月21日的DNS故障分析文章
首页 资讯 小组 资源 注册 登录 首页 最新文章 业界 开发 IT技术 设计 创业 IT职场 访谈 在国外 经典回顾 更多 > - 导航条 - 首页 最新文章 业界 - Googl ...
- 静态属性加载到jvm时候就存放在数据共享区,而不是等new后出现
静态属性加载到jvm时候就存放在数据共享区,而不是等new后出现.他的生命周期是 jvm结束 才会消失,一般的方法属性是对象结束后 就会消失.
- BZOJ3244 NOI2013树的计数(概率期望)
容易发现的一点是如果确定了每一层有哪些点,树的形态就确定了.问题变为划分bfs序. 考虑怎样划分是合法的.同一层的点在bfs序中出现顺序与dfs序中相同.对于dfs序中相邻两点依次设为x和y,y至多在 ...
- ibatis解决sql注入问题
原文: http://blog.csdn.net/scorpio3k/article/details/7610973 对于ibaits参数引用可以使用#和$两种写法,其中#写法会采用预编译方式,将转义 ...
- HTML的标签元素分类的区别
HTML ,即Hyper Text Markup Language 超文本标记语言: 文本:纯字符,如window中的txt文本 超文本:在纯文本中嵌入样式,图片,音频,视频,链接等内容 HTML的基 ...
- 【BZOJ4709】【Jsoi2011】柠檬
Description 传送门 题意简述:将序列划分成任意多段,从每一段选出一个数\(x\),获得\(在这一段出现的次数x*(x在这一段出现的次数)\)的贡献.求总贡献最大值. Solution ...
- 洛谷 P3190 [HNOI2007]神奇游乐园 解题报告
P3190 [HNOI2007]神奇游乐园 Description 给你一个 \(m * n\) 的矩阵,每个矩阵内有个权值\(V(i,j)\) (可能为负数),要求找一条回路,使得每个点最多经过一次 ...
- Linux内核分析实验六
Linux内核分析实验六 进程控制块PCB——task_struct(进程描述符) 为了管理进程,内核必须对每个进程进行清晰的描述,进程描述符提供了内核所需了解的进程信息. struct task_s ...
- 单点登录(十七)----cas4.2.x登录mongodb验证方式成功后返回更多信息更多属性到客户端
我们在之前已经完成了cas4.2.x登录使用mongodb验证方式登录成功了.也解决了登录名中使用中文乱码的问题. 单点登录(十三)-----实战-----cas4.2.X登录启用mongodb验证方 ...