CSS移动端实现卡片悬浮投影_利用box-shadow设置层次感

ROLLUP生成的NULL是层级聚合占位符而非空值,需用GROUPING()函数区分;窗口函数不能替代GROUP BY,须先聚合再计算;递归CTE适用于动态树形结构;导出时应统一处理NULL以避免前端解析异常。GROUP BY + ROLLUP 能直接出多级汇总,但要注意 NULL 含义SQL 多级分类统计最常踩的坑,是以为 ROLLUP 生成的 NULL 就是"空值",其实它是层级聚合的占位符。比如按 region → city → store 三级分组,ROLLUP(region, city, store) 会产出 4 层结果:明细行、store 小计、city 小计、region 小计,每层缺失维度用 NULL 标识。实操建议:用 GROUPING() 函数区分真 NULL 和聚合占位符,例如 GROUPING(city) = 1 表示该行是 city 级汇总(city 列值为 NULL,但不是数据缺失)别直接 WHERE city IS NOT NULL 过滤------会把 city 小计也干掉ROLLUP 在 MySQL 8.0+、PostgreSQL 9.5+、SQL Server 全支持,但 SQLite 不支持,Oracle 需用 GROUPING SETS窗口函数不能替代 GROUP BY,但能补全层级占比和排名有人想用 SUM(sales) OVER (PARTITION BY region) 直接算大区占比,却发现结果行数没变------对,窗口函数不压缩行,它是在原表每行上追加计算列。真正做多级报表,得先 GROUP BY 得到聚合结果集,再套窗口函数加工。典型场景:在三级分组结果(region/city/store)上,算每个 store 占所属 city 的比例:用 SUM(sales) OVER (PARTITION BY region, city) 做分母给每个 city 内的 store 按销售额排名:RANK() OVER (PARTITION BY region, city ORDER BY sales DESC)注意 ORDER BY 在窗口定义里影响排序逻辑,但不会改变输出行顺序------最终排序还得靠外层 ORDER BY递归 CTE 解决动态层级(如无限级类目树),但性能要盯死如果分类是树形结构(比如电商类目:电子 > 手机 > 苹果 > iPhone 15),且层级深度不确定,ROLLUP 就失效了------它只认固定列数。这时得用递归 CTE 把树摊平成"路径+层级"二维表,再聚合。关键点:递归部分必须有终止条件,常见写法是 WHERE parent_id != id 或限制最大深度(LEVEL <= 5)防止死循环PostgreSQL 用 WITH RECURSIVE,MySQL 8.0+ 支持,SQL Server 用 WITH + UNION ALL,旧版 MySQL 只能靠应用层拼树越深、节点越多,递归中间结果集越大;建议在 category 表的 parent_id 和 id 上建索引报表导出时 NULL 和空字符串混用,前端解析容易崩SQL 层聚合后,经常要导出 CSV 或喂给 BI 工具。这时候 ROLLUP 产生的 NULL、字段默认值 ''、以及真实业务空数据,在 Excel 或 Tableau 里可能全显示成空白,但底层类型不同,排序/过滤行为不一致。稳妥做法:用 COALESCE(region, '[全部]') 统一替换聚合行标识,比留 NULL 更直观避免在聚合字段上用 IFNULL 或 ISNULL 直接转空字符串------这会让 GROUPING() 失效,无法区分层级导出前加个 SELECT ... FROM (...) AS t ORDER BY GROUPING(region) DESC, region, ...,确保汇总行排在最上面或最下面层级深、维度多、数据量大时,ROLLUP 和递归 CTE 的执行计划很容易飘,上线前一定用真实数据集 explain 一下;临时表或物化视图不是银弹,但比每次跑全量递归靠谱。

相关推荐
小白学大数据6 分钟前
基于大模型的Python智能爬虫:语义识别与数据清洗实践
开发语言·爬虫·python·数据分析
Cloud_Shy6188 分钟前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(附录 B 高级 VS Code 功能)
vscode·python·jupyter·数据分析·excel
进击切图仔13 分钟前
从零手写 RAG
python·huggingface·rag
Dxy123931021619 分钟前
Python请求方式介绍:JSON、表单及其他常见数据传输格式
数据库·python·json
西洼工作室26 分钟前
个人开发者接入阿里云号码认证服务AliCloud-NirvanaPns实现一键登录
python·阿里云·uni-app·全栈·认证授权
半城抹茶1 小时前
TradingAgents-CN 项目目录文档
python
光影6271 小时前
Selenium自动化测试---实战踩坑实录
python·selenium·测试工具·百度
HappyAcmen1 小时前
2.lcut返回列表用法
python
Json____1 小时前
Python练习题集-文件处理、数据管理与网络编程实战小项目15个
python·编程·编程学习·练习题·python学习
星空椰1 小时前
Python 使用飞书 API 获取部门直属用户列表(递归获取所有部门 + 导出 Excel)
python·飞书