当前位置: 首页 > wzjs >正文

新版网站上线前端网站开发项目经验

新版网站上线,前端网站开发项目经验,衡水专业做wap网站,wordpress footer 插件以下是 MySQL 中 DISTINCT 去重的核心注意事项详解 📌 DISTINCT 六大注意事项 1. 作用范围:所有 SELECT 字段 SELECT DISTINCT a, b FROM table; -- 对(a,b)组合整体去重⚠️ 误以为只作用于第一个字段: -- 错误理解:以为只对…

以下是 MySQL 中 DISTINCT 去重的核心注意事项详解


📌 DISTINCT 六大注意事项

1. 作用范围:所有 SELECT 字段
SELECT DISTINCT a, b FROM table;  -- 对(a,b)组合整体去重

⚠️ 误以为只作用于第一个字段

-- 错误理解:以为只对name去重
SELECT DISTINCT name, class FROM students;  

实际效果:对 (name, class) 组合去重(如 ('张三','一班')('张三','二班') 算不同记录)


2. NULL 值的特殊处理
INSERT INTO students (name, class, score) VALUES (NULL, '三班', 90);SELECT DISTINCT name FROM students;

结果

+--------+
| name   |
+--------+
| 张三   |
| 李四   |
| 王五   |
| NULL   |  -- NULL被视为独立值保留
+--------+

3. 性能陷阱(大数据量)
-- 当表有百万行时慎用
SELECT DISTINCT text_column FROM huge_table; 

优化方案

-- 先通过WHERE缩小范围再去重
SELECT DISTINCT text_column 
FROM huge_table 
WHERE create_time > '2023-01-01';-- 或添加索引(对text类型有限制)
ALTER TABLE huge_table ADD INDEX idx_text(text_column(20)); -- 前缀索引

4. 与 ORDER BY 的优先级
SELECT DISTINCT class 
FROM students 
ORDER BY score DESC; -- 错误!score不在SELECT中

正确写法

-- 方案1:排序字段必须在SELECT中
SELECT DISTINCT class, MAX(score) AS max_score 
FROM students 
GROUP BY class 
ORDER BY max_score DESC;-- 方案2:子查询
SELECT DISTINCT class FROM (SELECT class, score FROM students ORDER BY score DESC
) AS tmp;

5. 聚合函数中的 DISTINCT
-- 统计不重复的班级数量
SELECT COUNT(DISTINCT class) FROM students; -- 错误用法(语法无效):
SELECT DISTINCT COUNT(class) FROM students; 

6. 不可用于部分字段计算
-- 尝试计算不同班级的平均分(错误!)
SELECT DISTINCT class, AVG(score) FROM students; 

正确做法:必须配合 GROUP BY

SELECT class, AVG(score) 
FROM students 
GROUP BY class;  -- 这才是标准解法

⚠️ 高级注意点

7. 与 LIMIT 的配合问题
SELECT DISTINCT class FROM students LIMIT 2;

结果不确定性
返回的 2 条记录是随机的(除非指定 ORDER BY),不同执行可能结果不同。


8. 临时表空间占用
  • DISTINCT 操作会在内存/磁盘创建临时表存储唯一值
  • 当去重字段总数据量超过 tmp_table_size 时,性能急剧下降

查看阈值

SHOW VARIABLES LIKE 'tmp_table_size'; -- 默认16MB

🔍 对比 GROUP BY 去重

特性DISTINCTGROUP BY
是否可搭配聚合函数✅ (如SUM/AVG)
结果排序无序可按分组键排序
执行效率简单场景更快复杂聚合时更优
索引利用可使用索引必须用分组字段索引

最佳实践总结

  1. 小数据量:直接 DISTINCT 简洁高效
  2. 需要聚合计算:用 GROUP BY 替代
  3. 精确去重计数:优先 COUNT(DISTINCT column)
  4. 排序需求:必须显式写 ORDER BY
  5. 超大数据:先过滤再去重 + 合理索引

🚀 实战检验

订单表 orders 结构

CREATE TABLE orders (id INT PRIMARY KEY,product_id INT,user_id INT,amount DECIMAL(10,2),coupon_code VARCHAR(20) -- 允许为NULL
);

问题
如何高效获取使用过不同优惠券的用户ID列表(含NULL)?

👉 写出你的解决方案:
SELECT _______________________________
FROM orders;

答案(折叠)

-- 方案1:基础写法
SELECT DISTINCT user_id, coupon_code 
FROM orders 
WHERE coupon_code IS NOT NULL; -- 若需包含NULL则去掉WHERE-- 方案2:大数据量优化(添加联合索引)
ALTER TABLE orders ADD INDEX idx_user_coupon(user_id, coupon_code);
SELECT DISTINCT user_id, coupon_code FROM orders;

文章转载自:

http://PHgBkIK8.gLxdk.cn
http://e23Dp7pa.gLxdk.cn
http://ZmAK8TCr.gLxdk.cn
http://sBben8mR.gLxdk.cn
http://j1nnV1BK.gLxdk.cn
http://W8iZ3K0a.gLxdk.cn
http://xOQXTzr1.gLxdk.cn
http://5cZIVHnY.gLxdk.cn
http://kYi6jx9g.gLxdk.cn
http://lE6F1chp.gLxdk.cn
http://oG1TsJEH.gLxdk.cn
http://d5BFMhqH.gLxdk.cn
http://8i8ZhZAc.gLxdk.cn
http://9snQDmoG.gLxdk.cn
http://hopKBdGD.gLxdk.cn
http://6ustOEJV.gLxdk.cn
http://IBa6Nvif.gLxdk.cn
http://Nd1Eo6Wd.gLxdk.cn
http://5bO3RjvK.gLxdk.cn
http://qSjeUj8M.gLxdk.cn
http://doiGCSao.gLxdk.cn
http://fodKslXW.gLxdk.cn
http://JyKDHrjX.gLxdk.cn
http://KlX051k2.gLxdk.cn
http://AGSAgsry.gLxdk.cn
http://nPJgfz1R.gLxdk.cn
http://Z8mkNYac.gLxdk.cn
http://erXz7ATL.gLxdk.cn
http://xgY0IGsP.gLxdk.cn
http://ORbVLdyY.gLxdk.cn
http://www.dtcms.com/wzjs/673386.html

相关文章:

  • 做临时工有哪些网站wordpress 4 漏洞
  • 06627网页制作和网站建设试卷广告软文案例
  • 摄影网站上的照片做后期嘛成都网站原创
  • 物流公司官方网站物流专线wordpress添加发布视频教程
  • 只用网站开发VS就安装那些就够了公众号怎么弄好看的模板
  • 景安一个空间怎么做多个网站用什么程序做视频网站
  • 自己建网站流程网站建设与维护参考文献
  • 建设银行湖南省分行官方网站网站设置关于我们怎么做
  • 网络建站如何建成阿里巴巴外贸圈app
  • 微信小程序开发大赛谷歌seo优化推广
  • 网站备份网络营销推广三板斧
  • html婚纱网站源码网络营销的基本特征有哪些
  • 做婚庆网站有哪些wordpress 下雪插件
  • 做效果图展板网站阿里巴巴国际站工作怎么样
  • 示范专业网站建设中建豪城建设有限公司网站
  • 2018如何做网站外链广西网站建设推广服务
  • 给公司建立网站不可以做到的是武昌区建设局网站
  • 新建网站seo优化怎么做茌平网站制作
  • 网站 昆明wordpress删除自豪的
  • 石油大学网页设计与网站建设长沙网站排名优化
  • 建设部网站官网施工合同文本wordpress调节字体大小
  • html5网站开发参考文献烟台好的网站设计公司
  • 昭阳区住房和城乡建设管理局网站南京市溧水区建设局网站
  • 英文在线购物网站建设如何制作自己的视频网站
  • 深圳的网站建设公司三把火鲜花网站开发背景
  • 网站建设哪儿好安阳市网站制作公司
  • 好的做蛋糕网站中国建设网站的公司
  • 品网站建设公司开发公司对施工单位管理措施
  • metro风格网站模板怎么用phpstudy做网站
  • 河南省住房城乡建设门户网站做网站推广怎么做