mysql表格设计问题

部门表tableDepart有 ID(员工ID),NAME (部门姓名)
员式表tableUser有** ID(员工ID),NAME (员工姓名),DID(部门ID)**。
项目表tableProject有 ID(项目ID),NAME (项目名称),UID(负责人的员工ID)
营业表tableMoney有 ID,MONTH(月份),PID(项目ID),MONEY(月营业额)
现求营业报表,字段有 部门,项目负责人,项目名称,月份,营业额
Mysql语句如下:
select d.NAME as departName,c.NAME as userName,b.NAME as projectName,d.MONTH,d.MONEY
from tableMoney a,tableProject b,tableUser c,tableDepart d
where a.PID=b.ID and b.UID=c.ID and c.DID = d.ID
这样做的话,多表联合,数据量一大就比较费时间,
如果还要查询某个员工名称的,某个部门ID,某个项目名称的,也比较费时间
我现在为了方便统计报表,营业表tableMoney设计为如下
ID,MONTH(月份),MONEY(月营业额),
PID(项目ID),PNAME(项目名称),
UID(负责人的员工ID),UAME (员工姓名),
DID(员工ID),DNAME (部门姓名)
这样查询报表,只需要查询tableMoney一张表即可,速度快很多,
通常部门的ID和名称,项目的ID和名称不会变,
但是员工可能会换部门,项目可能会换项目负责人,又导致营业表要变更,
请问各位大佬,要如何设计营业表,以方便快捷的查出营业报表数据

世上没有两全法,要解决一个问题必然会出现另一个问题。如果你不想udpate这条数据,那就在员工变更时,营业表新增一条最新的数据,需要的时候就查询最后添加的数据就行了。这样也保留了以前的记录,方便追踪项目。

这是一个比较麻烦的问题,可以考虑在员工换部门时更新营业报表对应的数据。

感觉你才是大佬

数据库你要反范式设计,增加了修改删除的业务逻辑,万一没改全,就出幺蛾子了,就问问自己有没有这个必要,
这种程度的连表,数据量大的话,加索引看执行计划,也是可以优化查询时间的,再一个,你自己预估下项目数据能多少,100w出头也不太影响查询效率