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相关推荐

  1. mysql 之 sql管理数据 二

    2019独角兽企业重金招聘Python工程师标准>>> 1.创建一个指定 存储引擎 的表 create table mytb1(....) engine = memory; crea ...

  2. 使用DQL命令查询数据(二)

    使用DQL命令查询数据(二) SELECT语法 SELECT [ALL | DISTINCT] { * | table.* | [ table.field1 [ as alias1] [,table. ...

  3. (转)【mysql元数据库】使用information_schema.tables查询数据库和数据表信息 ---数据记录大小统计...

    转:https://www.cnblogs.com/ssslinppp/p/6178636.html https://segmentfault.com/q/1010000007268994?_ea=1 ...

  4. 4.MySQL的DQL查询数据

    4.1DQL (Data Query LANGUAGE):数据查询语言 所以的查询操作都用它, Select 简单和复杂的查询它都能做!5](5.png) 数据库中最核心的语言,最重要的语言 使用频率 ...

  5. mysql查询特定时间数据视频_mysql查询特定时间段内的数据

    参照文章(mysql查询时间段内数据)进行了操作. 先来建表语句: [sql] view plaincopySETFOREIGN_KEY_CHECKS=0;-- ------------------- ...

  6. mysql查询20-30的数据_20. mysql查询表的数据大小

    在需要备份数据库里面的数据时,我们需要知道数据库占用了多少磁盘大小,可以通过一些sql语句查询到整个数据库的容量,也可以单独查看表所占容量. 1.要查询表所占的容量,就是把表的数据和索引加起来就可以了 ...

  7. 数据库应用——DQL查询数据(连表查询 子查询 详细案例)

    DQL查询数据 DQL Select完整的语法 练习用的sql脚本 指定查询字段 where 条件子句 连表查询(重要) 三种join的比较 连表查询练习 自连接 分页和排序 子查询 分组和过滤 DQ ...

  8. Mysql单表查询和多表查询

    单表查询 一 单表查询的语法 #查询数据的本质:mysql会到你本地的硬盘上找到对应的文件,然后打开文件,按照你的查询条件来找出你需要的数据.下面是完整的一个单表查询的语法select * from, ...

  9. mySQL学习记录(局域网连接/基础查询/条件查询/常见函数/窗口函数/表连接/子查询/插修删建表)

    一些基础概念 DB 数据库 存储数据的容器 DBMS 数据库管理系统 又称数据库软件.产品如mysql/oracle/db2/sqlserver SQL 结构化查询语言 是所有的DBMS都使用的一种D ...

最新文章

  1. 自建WIN10 FTP无法访问的解决方法
  2. XP系统限制修改IP有新招
  3. 160 - 47 DueList.2
  4. Linux下如何抓取串口码流,linux alsa音频中采样率fs、比特率BCLK 、主时钟MCLK关系...
  5. 罗永浩推出新一代坚果手机,比AI亮眼的是AV能力
  6. 国内学者新研究:中医AI登场,自动开出药方
  7. LC 231 power of 2
  8. 【JAVA程序设计】从HelloWorld开始
  9. 不要网上乱拷贝代码了!一段网上找的代码把公司服务器崩了!
  10. 根据一个单词找所有的兄弟单词的思想如何处理
  11. Android4OpenCV实时人脸检测detectMultiScale报错
  12. 小米笔记本air13-3安装黑苹果macOS
  13. 新手如何做抖音直播带货?新号如何快速获取直播推荐流量?
  14. python123练习六+练习七
  15. 信号发生器的基本知识
  16. 发现微型计算机染有病毒后,??发现微型计算机染有病毒后,较为彻底的清除方法是(?? )...
  17. 『已解决』.NET报错:所生成项目的处理器框架“MSIL”与引用“wdapi_dotnet1021”的处理器架构“AMD64”不匹配
  18. python查找孪生素数_孪生素数-随心随性无为而为-51CTO博客
  19. vue 富文本vue-quill-editor 自定义字号大小和字体样式
  20. 学习笔记—网页设计基础知识(一)

热门文章

  1. Oracle_11g_R2安装手册(图文教程)
  2. 在VMware虚拟机中进行Ghost网刻不成功的几点提示
  3. 2021天津高考成绩查询时间26号几点,2021年天津高考成绩查询时间安排 什么时候出分...
  4. 双中心单电子积分计算氢分子离子H2+的轨道能量
  5. 围棋棋盘上的波粒二象性
  6. 测量一组对角矩阵的频率和质量
  7. python中的类属性和类方法_python面向对象之类属性和类方法的使用和实例
  8. class 第一个元素_第二章(第3节):网页元素定位和操作
  9. 【控制】《多智能体系统一致性协同演化控制理论与技术》纪良浩老师-第11章-连续时间多智能体系统牵制一致性
  10. 【控制】《多智能体系统一致性协同演化控制理论与技术》纪良浩老师-第6章-一阶时滞多智能体系统分组一致性