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和名称不会变,
但是员工可能会换部门,项目可能会换项目负责人,又导致营业表要变更,
还有一个情况,项目的1-6月是张三负责,7-12月又是李四负责,张三李四又不一定是同一个部门的,然后查询整年的数据时,就会非常麻烦,
请问各位大佬,要如何设计营业表,以方便快捷的查出营业报表数据

.