运用Deek Seeker协助数据分析

我的数据源有两张表,一个是每日销售表(字段有日期、产品名称、实际销量),一个是每月目标表(字段有年度月份、产品名称、目标销量);我的需求是,按月、按年来统计每个产品的目标完成情况请问用PowerBl进行分析,应该如何建立数据模型?

在Power BI中分析按月/年的产品目标完成情况,需合理构建数据模型。以下是分步解决方案:


1. 数据准备与清洗

每日销售表处理
  • 添加月份字段 :在Power Query中使用Date.ToText([日期], "yyyy-MM"),生成与目标表匹配的"年度月份"字段(如"2023-01")。

  • 按产品+月份聚合实际销量:在Power Query中按"产品名称"和"年度月份"分组,对"实际销量"求和。

每月目标表处理
  • 确保"年度月份"格式与销售表一致。

  • 检查重复项:确保每个"产品+年度月份"组合唯一。


2. 创建维度表

日期表
  • 用DAX自动生成日期表:

    DAX

    复制

    复制代码

日期表 = CALENDAR(MIN('每日销售表'[日期]), MAX('每日销售表'[日期]))

复制

复制代码
- 添加列:年份(`YEAR([日期])`)、月份(`FORMAT([日期], "yyyy-MM")`)、季度等。

#### **产品表**
- 提取唯一产品列表:
```DAX
产品表 = DISTINCT(UNION(DISTINCT('每日销售表'[产品名称]), DISTINCT('每月目标表'[产品名称])))

3. 建立数据模型关系

  • 关系图

    • 日期表[日期] 1→N关联到 每日销售表[日期]

    • 产品表[产品名称] 1→N关联到 每日销售表[产品名称]每月目标表[产品名称]

    • 每月目标表[年度月份] 需通过桥接字段(如月份首日)关联到日期表,或直接与聚合后的销售表关联。


4. 创建关键度量值

实际销量(按月汇总)

DAX

复制

复制代码
总实际销量 = SUM('每日销售表'[实际销量])
目标销量

DAX

复制

复制代码
总目标销量 = SUM('每月目标表'[目标销量])
完成率

DAX

复制

复制代码
目标完成率 = DIVIDE([总实际销量], [总目标销量], 0)

5. 可视化与交互

  • 矩阵/表格:行字段为"产品名称",列字段为"日期表"的年份和月份,值显示完成率。

  • 折线图/柱状图:展示趋势对比(实际 vs 目标)。

  • 切片器:添加年份和产品筛选器。


6. 注意事项

  • 数据一致性:确保"产品名称"在两表中完全一致,可创建统一维度表。

  • 空值处理 :若某些月份无目标,用IF(ISBLANK([总目标销量]), "无目标", [目标完成率])标记。

  • 性能优化:对大表预先聚合,避免实时计算影响速度。


通过以上步骤,用户可灵活分析各产品在不同时间维度的目标达成情况,同时保证模型的扩展性和可维护性。

相关推荐
S1998_1997111609•X13 分钟前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK1 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
BU摆烂会噶2 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t3 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper3 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程
light blue bird3 小时前
主子端台二分法任务汇总组件
前端·数据库·.net·桌面端winform
DevilSeagull4 小时前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务
小李来了!4 小时前
Navicate/plsql连接Oracle数据库教程
数据库·oracle
苍煜4 小时前
慢SQL优化实战教学
java·数据库·sql
zhaoyong2225 小时前
MySQL 存储过程中字符集与排序规则不匹配导致查询性能下降的解决方案
jvm·数据库·python