L指挥官 2021-07-05 11:17 采纳率: 33.3%
浏览 42
已采纳

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和名称不会变,
但是员工可能会换部门,项目可能会换项目负责人,又导致营业表要变更,
请问各位大佬,要如何设计营业表,以方便快捷的查出营业报表数据

  • 写回答

4条回答 默认 最新

  • 套你的猴子 2021-07-05 11:25
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。
  • ¥60 fail to initialize keyboard hotkeys through kernel.0000000000
  • ¥30 ppOCRLabel导出识别结果失败
  • ¥15 Centos7 / PETGEM
  • ¥15 csmar数据进行spss描述性统计分析
  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题