mysql如何设计任务和任务进度表

设计任务和任务进度表需分离主信息与动态进度,确保数据清晰可扩展。2. 任务表存储基本信息,进度表记录历史变更,便于统计分析。3. 通过关联查询获取最新进度,可冗余current_progress字段但以进度表为准。4. 建议扩展项目、里程碑、审计日志及子任务支持,提升系统灵活性。

mysql如何设计任务和任务进度表

在MySQL中设计任务和任务进度表时,关键是要保证数据结构清晰、可扩展,并能准确反映任务的生命周期和进度变化。以下是常见的表结构设计思路和示例。

1. 任务表(task)

作用:存储任务的基本信息,如任务名称、描述、负责人、创建时间、状态等。

示例结构:

CREATE TABLE task (
    id BIGINT PRIMARY KEY AUTO_INCREMENT,
    title VARCHAR(255) NOT NULL COMMENT ‘任务标题’,
    description TEXT COMMENT ‘任务描述’,
    assignee_id BIGINT COMMENT ‘负责人ID’,
    status ENUM(‘pending’, ‘running’, ‘paused’, ‘completed’, ‘cancelled’) DEFAULT ‘pending’ COMMENT ‘任务状态’,
    priority TINYINT DEFAULT 3 COMMENT ‘优先级:1-高,3-中,5-低’,
    start_time DATETIME COMMENT ‘计划开始时间’,
    end_time DATETIME COMMENT ‘计划结束时间’,
    created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
    INDEX idx_assignee (assignee_id),
    INDEX idx_status (status),
    INDEX idx_start_end (start_time, end_time)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

2. 任务进度表(task_progress)

作用:记录任务的进度变更历史,支持按时间查看进度变化,适合做统计分析。

示例结构:

CREATE TABLE task_progress (
    id BIGINT PRIMARY KEY AUTO_INCREMENT,
    task_id BIGINT NOT NULL COMMENT ‘关联任务ID’,
    progress_percent DECIMAL(5,2) NOT NULL DEFAULT 0.00 COMMENT ‘进度百分比,0.00~100.00’,
    remark VARCHAR(500) COMMENT ‘进度说明’,
    recorded_by BIGINT COMMENT ‘记录人ID’,
    recorded_at DATETIME DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (task_id) REFERENCES task(id) ON DELETE CASCADE,
    INDEX idx_task_progress (task_id, recorded_at),
    INDEX idx_recorded_by (recorded_by)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

3. 设计要点说明

为什么分开两张表?

飞书多维表格 飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

飞书多维表格 26 查看详情 飞书多维表格 任务主信息稳定,而进度是动态变化的,拆分有利于维护历史记录。 避免频繁更新任务表导致锁竞争或日志膨胀。 支持查看“谁在什么时候把任务推进到了多少”。

如何获取当前任务进度?

从 task_progress 表中取每个任务最新的那条记录:

SELECT tp.task_id, tp.progress_percent, tp.recorded_at, tp.remark
FROM task_progress tp
INNER JOIN (
  SELECT task_id, MAX(recorded_at) AS max_time
  FROM task_progress
  GROUP BY task_id
) latest ON tp.task_id = latest.task_id AND tp.recorded_at = latest.max_time;

是否可以在 task 表中加一个 current_progress 字段?

可以,但建议仅作为冗余字段用于快速查询,真实数据仍以 task_progress 为准,通过触发器或应用层同步更新。

4. 扩展建议

加入项目字段(project_id)实现多项目管理。 增加里程碑字段(milestone)标记关键节点。 对 task_progress 的修改做审计日志(如操作IP、设备等)。 如果任务有子任务,可设计 task_child 表或使用树形结构。基本上就这些,结构清晰、易于维护,适合中小规模的任务系统。

以上就是mysql如何设计任务和任务进度表的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/634146.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月12日 09:40:39
下一篇 2025年11月12日 09:41:51

相关推荐

  • js如何实现多重原型继承

    javascript没有直接的多重继承机制,因为它基于原型链的单一继承模型,为避免语言复杂性和“菱形继承问题”,采用mixin模式和对象组合来模拟多重继承。1. mixin模式通过将多个源类的方法复制到目标类原型上实现行为复用,但存在命名冲突、instanceof失效、无法使用super调用等问题;…

    2025年12月20日 好文分享
    000
  • js怎么让原型链上的属性不可删除

    要让javascript原型链上的属性不可删除,必须使用object.defineproperty()方法将属性的configurable特性设置为false;2. delete操作符仅能删除对象自身的属性,无法删除继承的原型属性,且对configurable为false的属性无效;3. 通过con…

    2025年12月20日 好文分享
    000
  • js怎么让原型链上的属性不可修改

    要让原型链上的属性不可修改,必须使用object.defineproperty()设置writable: false和configurable: false;2. 这只能防止直接修改或删除原型上的属性,无法阻止实例通过赋值创建同名属性来遮蔽原型属性;3. 若原型属性是对象,需用object.free…

    2025年12月20日 好文分享
    000
  • 如何调试事件循环相关的问题?

    调试事件循环问题的核心是理解javascript单线程与任务队列机制,明确宏任务(如settimeout)先执行、微任务(如promise)紧随其后清空的顺序;2. 使用浏览器performance面板录制并分析主线程火焰图,定位超过50毫秒的长任务,识别是脚本执行、频繁dom操作还是渲染瓶颈;3.…

    2025年12月20日 好文分享
    000
  • js如何实现原型链的属性代理

    要实现原型链上的属性代理,核心是利用javascript原型链的查找机制,在原型对象上通过object.defineproperty定义getter和setter来拦截属性访问。1. 确定目标原型对象,如myclass.prototype;2. 选择要代理的属性名,如’myvalue&#…

    2025年12月20日 好文分享
    000
  • js如何实现原型链的过滤查找

    核心思路是通过object.getprototypeof()沿原型链向上遍历,每层用reflect.ownkeys()获取所有自有属性名,并用过滤函数筛选符合条件的属性;2. 实现时需注意私有字段无法被反射获取,且应使用hasownproperty区分自有与继承属性;3. 常见陷阱包括混淆in与ha…

    2025年12月20日 好文分享
    000
  • 浏览器渲染和事件循环的执行顺序是什么

    浏览器渲染和事件循环,这两者之间的关系就像是舞蹈中的双人舞,既相互独立,又紧密配合。简单来说,渲染负责“画”出网页,事件循环负责“听”用户的指令并做出反应。 解决方案 浏览器渲染和事件循环的执行顺序可以概括为以下几个步骤,但要注意,这并非一个绝对线性的过程,而是循环往复、相互穿插的: 解析 HTML…

    2025年12月20日 好文分享
    000
  • javascript闭包怎么管理应用配置

    闭包能有效管理应用配置是因为它提供了数据封装与受控访问。1. 使用闭包可将配置私有化,仅通过暴露的方法进行读写,防止全局污染;2. 通过返回包含get、set、getall和reset等方法的对象,实现对配置的安全操作;3. 支持默认配置与初始配置的合并,提升灵活性;4. 可结合配置验证、环境区分和…

    2025年12月20日 好文分享
    000
  • js怎么判断属性来自原型还是自身

    要判断javascript对象的属性是否为自身属性而非继承自原型链,应使用hasownproperty方法。1. 使用对象的hasownproperty()方法可直接判断属性是否为自身所有,返回true表示是自身属性,false表示来自原型链或不存在;2. 为避免对象自身hasownproperty…

    2025年12月20日 好文分享
    000
  • Vuex Mutations 正确使用指南:过滤 State 中的数组数据

    本文旨在帮助开发者正确理解和使用 Vuex mutations 来处理 state 中的数组数据,尤其是在需要过滤数据时。我们将探讨为什么直接在 mutation 中修改 state 可能不是最佳实践,并介绍如何使用 getters 来更有效地实现数据过滤。同时,我们也会强调代码规范的重要性,以提升…

    2025年12月20日
    000
  • js如何判断原型链是否有循环引用

    判断javascript原型链是否存在循环引用的核心方法是使用set记录已访问对象,在遍历__proto__链时若遇到重复对象则说明存在循环;2. 具体实现通过while循环结合object.getprototypeof逐级向上检查,利用set的唯一性检测重复引用,若到达null则无循环,否则存在循…

    2025年12月20日 好文分享
    000
  • MutationObserver的回调属于微任务吗?

    mutationobserver的回调属于微任务,会在当前宏任务结束后、浏览器渲染前执行。2. 它能批量处理dom变化,确保在最新且稳定的dom状态中回调,提升性能并避免布局抖动。3. 潜在挑战包括可能阻塞主线程、引发无限循环及调试复杂,需谨慎编写回调逻辑。4. 适用于动态内容加载、响应式组件、性能…

    2025年12月20日 好文分享
    000
  • js如何检测原型链的终点

    javascript中,原型链的终点是null,因为object.prototype的原型被设计为null,从而避免无限递归并为属性查找提供明确的终止条件;通过反复调用object.getprototypeof()方法可追溯原型链,直到返回null即停止,例如使用while循环遍历currentpr…

    2025年12月20日 好文分享
    000
  • js如何判断对象的原型是否被代理

    无法直接判断javascript对象的原型是否被代理,但可通过间接方法推测:①通过object.getownpropertydescriptor和object.getprototypeof比较属性描述符与原型是否匹配;②在原型上定义临时属性并访问,观察get行为是否被拦截;③比较对象tostring…

    2025年12月20日 好文分享
    000
  • js如何判断对象的原型是否可删除

    javascript中无法直接删除对象的原型,因为原型是对象内部的[[prototype]]链接,而非普通属性;2. delete操作符只能删除对象自身的可配置属性,无法触及内部原型链接;3. 改变原型应使用object.setprototypeof(obj, prototype)或设置__prot…

    2025年12月20日 好文分享
    000
  • javascript闭包怎么实现函数节流

    函数节流和函数防抖的区别是:1. 节流保证在一定时间间隔内至少执行一次函数;2. 防抖则只在事件停止触发一段时间后执行最后一次调用。节流适用于如窗口滚动、调整大小等高频触发但需定期响应的场景,而防抖更适合搜索输入等需要等待用户操作结束的场景。闭包在节流中的作用是通过保存上次执行时间戳或定时器id,避…

    2025年12月20日 好文分享
    000
  • JavaScript可选链操作符 (?.) 的行为深度解析:短路机制与链式应用

    本文深入探讨JavaScript可选链操作符 (?.) 的行为特性,特别是其短路机制在链式调用中的作用。通过实例分析,揭示了当表达式链中某个环节为 null 或 undefined 时,?. 如何阻止后续属性访问错误,并导致整个表达式短路并返回 undefined,而非仅仅作用于紧邻的属性。理解其短…

    2025年12月20日
    000
  • javascript怎么实现数组分页

    javascript数组分页的核心思路是通过计算起始和结束索引,使用slice()方法截取指定页码的数据;2. 需要处理边界情况,如无效页码或超出总页数时返回空数组或最后一页数据;3. 分页能提升用户体验与性能,避免一次性渲染大量数据导致页面卡顿;4. 常见实现方式是slice(),优于手动循环;5…

    2025年12月20日 好文分享
    000
  • javascript数组如何实现优先级队列

    使用数组实现优先级队列的核心原因是其内存连续性和索引计算的直观性,能通过数学公式直接定位父子节点,提升缓存命中率并简化操作;2. 优先级队列常见于任务调度、图算法(如dijkstra和prim)、事件模拟、霍夫曼编码和网络数据包处理等需按重要性排序的场景;3. 处理相同优先级元素时,标准堆不保证顺序…

    2025年12月20日 好文分享
    000
  • JavaScript可选链操作符(?.)的深度解析与行为探究

    JavaScript中的可选链操作符(?.)提供了一种安全访问对象深层属性的方式。其核心机制在于“短路评估”:当操作符左侧表达式为null或undefined时,整个表达式会立即停止求值并返回undefined,而非抛出错误。本文将深入探讨?.的这一特性,特别是当其被连续使用时,如何影响表达式的执行…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信