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数据表字段说明的更多相关文章

  1. tp数据表字段缓存

    在维护一个tp写的项目,因为需要在产品表product中增加了一个字段status,但是不论如何就是无法给status赋值,查了资料才发现,原来是tp的数据表字段缓存在搞鬼. 在runtime> ...

  2. tp5.0 SHOW COLUMNS FROM 生成数据表字段缓存

    TP5.0 生成数据表字段缓存 =控制台执行以下命令= 1.生成指定数据库的所有表字段缓存 php think optimize:schema --db databaseName 2.生成指定数据表的 ...

  3. Mysql数据表字段设置了默认值,插入数据后默认字段的值却为null,不是默认值

    我将mysql的数据表的某个字段设置了默认值为1,当向该表插入数据的时候该字段的值不是默认值,而是null. 我的错误原因: 对数据库的操作我使用了持久化工具mybatis,插入数据的时候插入的是整个 ...

  4. 132_Power BI之建模必备要素&Power Query之数据表字段名称管理

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 近段时间比较忙,也没有看到很好的DAX素材,很久没有更新文章了,刚好有时间就来凑个热闹. 今天主题是Power ...

  5. laravel 同数据表字段比较查询和状态不正规排序

    今天写群组推荐接口,要求未满的群 ( 群最大人数字段maxusers, 群人数字段affiliations_count 都在群组表中),官方,热门(普通群0 ,官方1,热门2 ) 排序的群 同表字段比 ...

  6. phome_enewsclass 数据表字段解释(栏目主表)

    字段名 类型 解释 附加说明 classid smallint(6) 栏目ID   bclassid smallint(6) 父栏目ID   classname varchar(50) 栏目名称   ...

  7. 读取MySQL数据表字段信息

    TP5句式 $fieldinfo = Db::query('SHOW FULL COLUMNS FROM '.$table);//查出数据表所有字段信息Field 字段Comment 字段注释

  8. Mysql数据表字段扩充的小技巧

    在开发中,往往需求变更比开发速度要快,就会存在一些问题,比如突然要增加一个字段,我们需要 alter table 表名 add [column] 字段名 数据类型 [列属性] [位置]; 然后修改实体 ...

  9. phome_ecms_news 数据表字段解释(新闻系统模型-主表)

    http://www.phome.net/doc/manual/extend/html/dbdoc/index.html 字段名 类型 解释 附加说明 id int(11) 信息ID   classi ...

随机推荐

  1. [转帖]ssd固态硬盘的Trim命令是什么?

    ssd固态硬盘的Trim命令是什么?  收藏 分享 邀请 许多用户朋友在购买SSD的时候都会特别强调Trim,不过Trim是什么?做什么用的?   什么是Trim?   Trim指令也叫disable ...

  2. js框架总结

    参考地址 http://www.techweb.com.cn/network/system/2015-12-23/2245809.shtml https://www.cnblogs.com/mbail ...

  3. 再看case语句

    再看case语句,case语句只处理单条记录,而不是set 列名的使用,可以当做数值来使用: case when 后面简直是完美的的,什么东西都是能放的,只要是一个逻辑上的true/false的逻辑就 ...

  4. mysql 开发基础系列3

    日期类型 如果要用来表示年月日,通常用DATE 来表示. 如果要用来表示年月日时分秒,通常用DATETIME 表示. 如果只用来表示时分秒,通常用TIME 来表示. TIMESTAMP表示格式 :YY ...

  5. echarts 地图 离线json包分享

    最近,项目中需要用到地图,由于项目的特殊性,只能使用内网获取数据. 然而,echarts官网上的离线地图包(http://echarts.baidu.com/download-map.html)早在一 ...

  6. ACdream1093

    给你三种正多面体,正四面体,正六面体,正八面体.求从某一种正多面体中的某一点走到另一个点,且步数不超过k(1018)的方案数. 首先说明一下我交题的时候遇到的问题,起点和终点为同一点的时候,算不算走了 ...

  7. 【开发工具IDE】eclipse的SVN提交忽略target等多余文件

    这个build失败的解决方案就是不要把你项目的 target目录放在src repository 里面,还有 .project 和 .classpath最好也别放到src repository 里. ...

  8. 文件同步工具 lsyncd2.1.6 安装使用问题

    项目有文件实时同步备份的需求,做了一下调查,比较好的解决方法是使用lsyncd工具.这里主要记录一下遇到的问题及解决方法. lsyncd 的相关介绍和对比可见: lsyncd实时同步搭建指南——取代r ...

  9. Cryptography Reloaded UVALive - 4353(BigInteger)

    写写式子就出来了方程.. 然后解方程..不过数很大..用Java就好啦.. 就不贴呃的代码了...贴别人的..https://blog.csdn.net/qq_15714857/article/det ...

  10. 【刷题】BZOJ 4817 [Sdoi2017]树点涂色

    Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...