状态表:数据模型中的实用工具
1. 状态表模板
状态表以网格形式呈现,首行列出所有状态,首列重复这些状态。网格中每个单元格的值表示从该行状态到该列状态是否存在有效的转换。首列的状态集标记为“初始状态”,首行的状态集标记为“目标状态”,以此展示转换流程的顺序。
阅读状态表时,先确定首列的初始状态,再找到期望的最终状态,然后查看交叉单元格的值。例如,在模板中,标记为“状态 C”的行中有两个包含“是”的单元格,表示从状态 C 到状态 B 以及从状态 C 到状态 D 的转换都是允许的。
如果状态有明显的顺序,可按其在解决方案中出现的顺序(从上到下、从左到右)在表中列出。若状态根据用户操作可能以不同顺序出现,则需自行判断最易理解的顺序。
每个单元格可简单填写“是”(表示转换有效)或“否”(表示转换无效)。也可以用引发转换的事件或允许转换发生的条件代替“是”。例如,“从 A 到 B 的转换”就是导致从状态 A 转换到状态 B 的事件。
若需要关于转换的额外要求信息、状态转换事件难以描述,或者多个事件导致相同转换,则可以用唯一的 ID (如 REQ001、REQ002 等)代替“是”作为参考。这些要求会在表外进一步详细说明转换情况,以提供必要的额外信息。若空间允许,直接在单元格中填写状态转换事件更便于阅读。
通常,状态表可在如 Microsoft Excel 等工具中创建,这些工具的电子表格自带网格。
2. 示例
以贷款申请系统的状态表为例,申请人与抵押贷款经纪人合作时,经纪人可能会告知申请人“您的贷款申请正在审核中”或“您的贷款申请正在放款中”。
该状态表能让你考虑贷款