上一章我们装好了 NocoBase 并认识了界面。现在,我们要给工单系统搭骨架——定义数据模型。
数据模型就是系统的地基:先想清楚要存哪些数据、数据之间有什么关系,后面搭界面、配权限才能水到渠成。
如果你用过 Excel,理解数据表就很容易:
| Excel 概念 | NocoBase 概念 | 说明 |
|---|---|---|
| 工作表 | 数据表(Collection) | 一类数据的容器 |
| 列标题 | 字段(Field) | 描述数据的属性 |
| 每一行 | 记录(Record) | 一条具体的数据 |

比如我们要做的"工单表",就像一张 Excel 表格——每一列是一个字段(标题、状态、优先级……),每一行是一条工单记录。
不过,NocoBase 比 Excel 强大得多。它支持多种数据表类型,不同类型自带不同的能力:
| 表类型 | 适合场景 | 举例 |
|---|---|---|
| 普通表 | 大多数业务数据 | 工单、订单、客户 |
| 树表 | 有层级关系的数据 | 分类目录、部门组织架构 |
| 日历表 | 日期事件 | 会议、排班 |
| 文件表 | 附件管理 | 文档、图片 |
今天我们会用到普通表和树表,其他类型以后用到再学。
进入数据源管理:点击左下角 「数据源管理」 图标(齿轮旁边的数据库图标),你会看到「主数据源」——我们所有的表都建在这里。

我们直奔主题,先创建系统的核心——工单表。


tickets,数据表标题:工单
创建表时,系统会默认勾选一组系统字段,它们会自动记录每条数据的元信息:
| 字段 | 说明 |
|---|---|
| ID | 主键,分布式唯一标识 |
| 创建日期 | 记录的创建时间 |
| 创建人 | 谁创建了这条记录 |
| 最后修改日期 | 最后一次更新时间 |
| 最后修改人 | 最后一次更新的用户 |
这些系统字段保持默认即可,不需要手动管理。如果某些场景不需要,也可以取消勾选。
表创建好了,接下来添加字段。点击工单表的 「配置字段(Configure fields)」,你会看到刚才默认的系统字段已经在列表中了。


点击右上角的 「添加字段(Add field)」 按钮,会展开一个下拉字段类型列表——从中选择你要添加的字段类型。

我们先添加工单自身的字段,关联字段稍后再加。
1. 标题(单行文本)
每条工单都需要一个简短的标题来概括问题。点击 「添加字段」 → 选择 「单行文本」:

title,字段标题:标题
2. 描述(Markdown(Vditor))
用来详细描述问题,支持格式排版,方便贴图、贴代码。在「添加字段」→「Media」分类下有三种可选:
| 字段类型 | 特点 |
|---|---|
| Markdown | 基本 Markdown,简单样式 |
| Rich Text | 富文本,简单样式 + 附件上传 |
| Markdown(Vditor) | 功能最丰富,支持所见即所得、即时渲染、源码编辑三种模式 |
我们选 Markdown(Vditor)。

description,字段标题:描述
3. 状态(下拉菜单 - 单选)
工单从提交到完成,需要一个状态来跟踪进度。
status,字段标题:状态| 选项值 | 选项标签 | 颜色 |
|---|---|---|
| pending | 待处理 | Orange(日暮) |
| in_progress | 处理中 | Blue(拂晓蓝) |
| completed | 已完成 | Green(极光绿) |

先填好选项并保存。然后再次点击该字段的 「编辑(Edit)」,这时就能在「默认值」里选择 「待处理」 了。


首次创建时还没有选项数据,所以默认值选不了——需要保存后再回来设置。
为什么用下拉单选?因为状态是固定的几个值,下拉菜单可以防止用户随意填写,保证数据规范。
4. 优先级(下拉菜单 - 单选)
区分工单的紧急程度,方便处理人员按优先级排序。
priority,字段标题:优先级| 选项值 | 选项标签 | 颜色 |
|---|---|---|
| low | 低 | |
| medium | 中 | |
| high | 高 | Orange(日暮) |
| urgent | 紧急 | Red(薄暮) |
到这里,工单表有了 4 个基础字段。但是——工单应该有个"分类"吧?比如"网络问题""软件故障"?
如果把分类做成下拉菜单,当然也行。但你很快会发现:分类可能有子分类("硬件问题"下面还有"显示器""键盘""打印机"),下拉菜单就不够用了。
我们需要另一张表来专门管理分类。而且这张表,用 NocoBase 的树表来建最合适。
树表是一种特殊的数据表,它自带父子关系——每条记录可以有一个"父节点"。这天然适合有层级结构的数据:
如果用普通表,你需要自己手动建一个"父分类"字段来实现这种关系。而树表会自动帮你处理好,还支持树形展示、添加子记录等操作,省心很多。
回到数据源管理,点击 「创建数据表」
这次选择 「树表」(不是普通表!)

数据表名称:categories,数据表标题:工单分类

注意创建后,表里除了系统字段外,还会自动出现 「Parent」 和 「Children」 两个关系字段——这就是树表的特殊能力。通过 Parent 可以访问父节点,通过 Children 可以访问所有子节点,不需要你手动添加。

点击 「配置字段」 进入字段列表,可以看到系统字段和自动生成的 Parent、Children 字段。 点击右上角 「添加字段」:
字段一:分类名称
name,字段标题:分类名称字段二:颜色
color,字段标题:颜色
颜色字段可以让每个分类有自己的标识色,后面在界面上展示时会更直观。

到这里,两张数据表的基础字段就配好了。接下来我们把它们关联起来。
关系字段初次接触可能有点抽象。 如果你觉得不太好理解,可以先跳到 第 3 章:搭建页面,在实际的页面操作中感受一下数据是怎么展示的,再回来补上关联字段。
工单需要关联到分类、提交人和处理人。这类字段叫做关系字段——它不像"标题"那样直接存一段文字,而是存了另一张表里某条记录的 ID,通过这个 ID 找到对应的记录。
用一条具体的工单来看——左边是工单的各个属性,其中"分类"和"提交人"存的不是文字,而是一个 ID。系统通过这个 ID,从右边的表里精准找到对应的记录:

你在界面上看到的是名称("网络问题""张三"),背后就是通过 ID 关联的。多条工单可以指向同一个分类或同一个用户——这种关系叫做多对一。
回到工单表的「配置字段」→「添加字段」,选择 「多对一」。

创建时你会看到这些配置项:
| 配置项 | 说明 | 怎么填 |
|---|---|---|
| 源数据表 | 当前表(自动填好) | 不用改 |
| 目标数据表 | 要关联到哪张表 | 选择对应的表 |
| 外键 | 存在当前表里的关联列名 | 填一个有意义的名字 |
| 目标数据表标识字段 | 默认 id | 保持默认即可 |
| ON DELETE | 目标记录被删除时的处理方式 | 保持默认即可 |

外键默认会自动生成一个随机名(如
f_xxxxx),建议改成有意义的名字,方便日后维护。命名用小写字母加下划线(如category_id),不用大小写混合。
按这个方式依次添加三个字段:
5. 分类 → 工单分类表
分类category_id6. 提交人 → 用户表
记录是谁提交了这条工单。NocoBase 内置了用户表,直接关联即可。
提交人submitter_id

7. 处理人 → 用户表
记录谁在负责处理这条工单。
处理人assignee_id
回顾一下我们搭建的完整数据模型:

}o--|| 表示多对一关系:左边"多",右边"一"。
这一章我们完成了数据建模——整个工单系统的骨架:
我们学到了几个重要概念:
你可能注意到,后续的截图中已经有数据了——这些测试数据是我们为了演示效果提前录入的,别着急。在 NocoBase 中,数据的增删改查都是通过前端页面完成的。第 3 章我们会搭建表格来展示数据,第 4 章会搭建表单来录入数据,一步步揭晓。
骨架搭好了,但现在只有空表。下一章,我们要搭建页面,让数据真正能展示出来。
我们下章见!