部门表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月又是李四负责,张三李四又不一定是同一个部门的,然后查询整年的数据时,就会非常麻烦,
请问各位大佬,要如何设计营业表,以方便快捷的查出营业报表数据
mysql表格设计问题,营业表(部门表,员工表,项目表)
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
悬赏问题
- ¥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组件网页下拉菜单自动选择问题