mysql 查询 distinct_MYSQL查询数据(二)SELECT | DISTINCT
MySQL SELECT语句简介
SELECT语句允许您从表或视图获取数据。像电子表格一样,表由行和列组成。通常,您需要查看表中的数据。这时候你可以使用mysql数据库中的select语句进行查询数据。
让我们来看看SELECT语句的语法:SELECT
column_1, column_2, ...
FROM
table_1
[INNER | LEFT |RIGHT] JOIN table_2 ON conditions
WHERE
conditions
GROUP BY column_1
HAVING group_conditions
ORDER BY column_1
LIMIT offset, length;
该SELECT语句由几个子句组成,如下面的列表所述:SELECT后面以逗号分隔的字段名称或星号(*),表示要返回的列。
FROM指定要查询数据的表或视图。
JOIN基于某些连接条件从其他表获取数据。
WHERE过滤结果集中的行。
GROUP BY将数据分组并对每个组应用聚合函数。
HAVING基于GROUP BY子句定义的组筛选组。
ORDER BY指定用于排序字段。
LIMIT约束返回的行数。
SELECT和FROM查询语句中必须的。其他部分是可选的。
MySQL SELECT语句示例
SELECT语句允许您通过在SELECT子句中指定逗号分隔的列的列表来查询表的部分数据。例如,如果您只想查看员工的名字,姓氏和职位,您可以使用以下查询:
SELECT
lastname, firstname, jobtitle
FROM
employees;
如果要获取表中所有列的employees数据,你可以列出该SELECT子句中的所有列名称,也可以只需使用星号(*),星号(*)表示查询表中的所以列。SELECT * FROM employees;
上面SQL查询语句返回表employees中的所有列和行。
在测试中我们可以使用星号(*)代替表中的所以列,但实际上,您应该列出要明确获取数据的列,原因如下:星号(*)会返回没用的字段数据。它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。
如果您明确指定列,则结果集更可预测,更易于管理。想象一下,如果有人为表添加了很多列,当你使用星号(*)时,你会得到一个不同于你期望的结果集。
使用星号(*)可能会向未经授权的用户公开敏感信息。
MySQL DISTINCT子句
当从表中查询数据时,您可能会得到重复的行。为了删除这些重复行,可以在SELECT语句中使用DISTINCT 子句。
使用DISTINCT 子句的语法如下:SELECT DISTINCT
columns
FROM
table_name
WHERE
where_conditions;
有些员工拥有相同的姓氏 Bondur,Firrelli等等。
要删除重复的姓氏,请将DISTINCT 语句添加到SELECT语句中 ,如下所示:
当我们使用DISTINCT子句时,重复的姓氏在结果集中被去除。
MySQL DISTINCT与NULL
如果一个列(字段)具有NULL值,并且您在该列(字段)中使用了DISTINCT 子句,那么MySQL将保留一个NULL值并消除另一个值,因为DISTINCT 子句将所有NULL值视为相同的值。
例如,在customers表中,我们有许多数据行的 state列为NULL。当我们使用DISTINCT 子句查询客户的state时,我们将看到state的唯一NULL值,mysql语句如下:SELECT DISTINCT
state
FROM
customers;
在MySQL DISTINCT中使用多列
您可以对多个列使用DISTINCT子句。在这种情况下,MySQL使用所有列的组合来确定结果集中行的唯一性。
DISTINCT子句与GROUP BY子句
如果在SELECT语句中使用了GROUP BY子句而没有不使用聚合函数,则GROUP BY子句的作用类似于DISTINCT 子句。
以下语句使用GROUP BY子句来查询customers表中客户的唯一state。SELECT
state
FROM
customers
GROUP BY state;
您也可以通过使用以下DISTINCT子句来实现类似的结果。
一般来说,DISTINCT 子句是特殊情况下的GROUP BY子句。DISTINCT 子句和GROUP BY子句之间的区别是GROUP BY子句对结果集进行排序,而DISTINCT 子句不排序。
如果将ORDER BY添加到 DISTINCT子句的语句中,则结果集将进行排序,并且与使用GROUP BY子句的语句返回结果相同。SELECT DISTINCT
state
FROM
customers
ORDER BY state;
SELECT DISTINCT
state
FROM
customers
ORDER BY state;
MySQL DISTINCT与聚合函数
您可以使用带有聚合函数的DISTINCT(如SUM,AVG和COUNT)子句,在删除重复数据之后,MySQL将聚合函数应用于结果集中。
例如,要计算美国客户的唯一state,请使用以下查询:SELECT
COUNT(DISTINCT state)
FROM
customers
WHERE
country = 'USA';
SELECT DISTINCT
state
FROM
customers
ORDER BY state;
带有LIMIT的MySQL DISTINCT
在使用带有LIMIT的DISTINCT子句的情况下,MySQL只返回LIMIT范围内的唯一不重复的结果集。
以下mysql语句查询customers表中的前5个非空的唯一state。
SELECT DISTINCT
state
FROM
customers
WHERE
state IS NOT NULL
LIMIT 5;
mysql 查询 distinct_MYSQL查询数据(二)SELECT | DISTINCT相关推荐
- mysql 之 sql管理数据 二
2019独角兽企业重金招聘Python工程师标准>>> 1.创建一个指定 存储引擎 的表 create table mytb1(....) engine = memory; crea ...
- 使用DQL命令查询数据(二)
使用DQL命令查询数据(二) SELECT语法 SELECT [ALL | DISTINCT] { * | table.* | [ table.field1 [ as alias1] [,table. ...
- (转)【mysql元数据库】使用information_schema.tables查询数据库和数据表信息 ---数据记录大小统计...
转:https://www.cnblogs.com/ssslinppp/p/6178636.html https://segmentfault.com/q/1010000007268994?_ea=1 ...
- 4.MySQL的DQL查询数据
4.1DQL (Data Query LANGUAGE):数据查询语言 所以的查询操作都用它, Select 简单和复杂的查询它都能做!5](5.png) 数据库中最核心的语言,最重要的语言 使用频率 ...
- mysql查询特定时间数据视频_mysql查询特定时间段内的数据
参照文章(mysql查询时间段内数据)进行了操作. 先来建表语句: [sql] view plaincopySETFOREIGN_KEY_CHECKS=0;-- ------------------- ...
- mysql查询20-30的数据_20. mysql查询表的数据大小
在需要备份数据库里面的数据时,我们需要知道数据库占用了多少磁盘大小,可以通过一些sql语句查询到整个数据库的容量,也可以单独查看表所占容量. 1.要查询表所占的容量,就是把表的数据和索引加起来就可以了 ...
- 数据库应用——DQL查询数据(连表查询 子查询 详细案例)
DQL查询数据 DQL Select完整的语法 练习用的sql脚本 指定查询字段 where 条件子句 连表查询(重要) 三种join的比较 连表查询练习 自连接 分页和排序 子查询 分组和过滤 DQ ...
- Mysql单表查询和多表查询
单表查询 一 单表查询的语法 #查询数据的本质:mysql会到你本地的硬盘上找到对应的文件,然后打开文件,按照你的查询条件来找出你需要的数据.下面是完整的一个单表查询的语法select * from, ...
- mySQL学习记录(局域网连接/基础查询/条件查询/常见函数/窗口函数/表连接/子查询/插修删建表)
一些基础概念 DB 数据库 存储数据的容器 DBMS 数据库管理系统 又称数据库软件.产品如mysql/oracle/db2/sqlserver SQL 结构化查询语言 是所有的DBMS都使用的一种D ...
最新文章
- 自建WIN10 FTP无法访问的解决方法
- XP系统限制修改IP有新招
- 160 - 47 DueList.2
- Linux下如何抓取串口码流,linux alsa音频中采样率fs、比特率BCLK 、主时钟MCLK关系...
- 罗永浩推出新一代坚果手机,比AI亮眼的是AV能力
- 国内学者新研究:中医AI登场,自动开出药方
- LC 231 power of 2
- 【JAVA程序设计】从HelloWorld开始
- 不要网上乱拷贝代码了!一段网上找的代码把公司服务器崩了!
- 根据一个单词找所有的兄弟单词的思想如何处理
- Android4OpenCV实时人脸检测detectMultiScale报错
- 小米笔记本air13-3安装黑苹果macOS
- 新手如何做抖音直播带货?新号如何快速获取直播推荐流量?
- python123练习六+练习七
- 信号发生器的基本知识
- 发现微型计算机染有病毒后,??发现微型计算机染有病毒后,较为彻底的清除方法是(?? )...
- 『已解决』.NET报错:所生成项目的处理器框架“MSIL”与引用“wdapi_dotnet1021”的处理器架构“AMD64”不匹配
- python查找孪生素数_孪生素数-随心随性无为而为-51CTO博客
- vue 富文本vue-quill-editor 自定义字号大小和字体样式
- 学习笔记—网页设计基础知识(一)
热门文章
- Oracle_11g_R2安装手册(图文教程)
- 在VMware虚拟机中进行Ghost网刻不成功的几点提示
- 2021天津高考成绩查询时间26号几点,2021年天津高考成绩查询时间安排 什么时候出分...
- 双中心单电子积分计算氢分子离子H2+的轨道能量
- 围棋棋盘上的波粒二象性
- 测量一组对角矩阵的频率和质量
- python中的类属性和类方法_python面向对象之类属性和类方法的使用和实例
- class 第一个元素_第二章(第3节):网页元素定位和操作
- 【控制】《多智能体系统一致性协同演化控制理论与技术》纪良浩老师-第11章-连续时间多智能体系统牵制一致性
- 【控制】《多智能体系统一致性协同演化控制理论与技术》纪良浩老师-第6章-一阶时滞多智能体系统分组一致性