《快速念咒——MySQL自学入门指南》:第1章第4节:使用DISTINCT去重——再谈欢欣剂(中)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本节课我们介绍了用来去重的关键词——DISTINCT。可以看到,DISTINCT与ORDER BY和LIMIT的用法区别在于:它是紧跟在SELECT后,而非FROM后。所以DISTINCT去重的作用范围就是被检索出来的所有列。

但DISTINCT同样是以行为单位在进行调整,这一点与ORDER BY和LIMIT如出一辙。因为DISTINCT的去重对象并不是列中孤立的列值,而是重复行,或者说是重复的输出记录。

想象一下,如果DISTINCT是去掉每一列中的重复列值,那么这就会破坏数据横向的一一对应关系。不妨举个生活化的例子来讲:

“无糖薄荷”和“自动保存”是两家裁缝店,而它们都会提供黑色西服和红色西服:在这里插入图片描述

可如果DISTINCT的去重机制是去掉列中的重复值,那么可能出现的情况就会是:在这里插入图片描述
瞧,这就破坏了原本一一对应的数据关系,而且提供的信息也不完整。

本节内容除了DISTINCT以外,其实主键也是相当重要的内容。可以说它就是连接关联表的一座桥梁。因为关系型数据库之所以叫这个名字,很大程度上是因为它可以创建并使用关联表。关联表简单来讲就是用多张表来共同记录一个事件。它们彼此独立,但又相辅相成,从而实现数据共享。这一点我们以后会详谈~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值