广告位联系
返回顶部
分享到

DQL命令查询数据实现方法介绍

Mysql 来源:互联网 作者:佚名 发布时间:2022-09-26 21:00:03 人浏览
摘要

一、SELECT语法-排序 1 2 3 4 5 6 7 8 9 SELECT [ALL | DISTINCT] { * | table.* | [ table.field1 [ as alias1] [, table.field2 [as alias2]][, ]] } FROM table_name [ as table_ alias ] [ left|out|inner join table_name2 ] //多表连接查询

一、SELECT语法-排序

1

2

3

4

5

6

7

8

9

SELECT   [ALL | DISTINCT]

{  * |  table.* | [ table.field1 [ as  alias1] [, table.field2 [as  alias2]][, …]] }

FROM  table_name  [ as  table_ alias  ]

    [ left|out|inner  join  table_name2 ]    //多表连接查询

    [ WHERE  … ]    //指定结果需满足的条件

    [ GROUP BY …]   //指定结果按照哪几个字段来分组

    [ HAVING …] //过滤分组的记录必须满足的次要条件

    [ ORDER BY… ]   //指定查询记录按一个或者多个条件排序

    [ LIMIT  {   [ offset,] row_count    |   row_count OFFSET offset   }] ;  //分页查询

排序可以是升序(ASC)或者降序(DESC),如果不指定ASC或DESC,结果集默认按ASC升序排序:

如以下

1

2

3

4

5

//把成绩都降低10%后加5分,再查询及格成绩,并按照成绩从高到低排序。

SELECT studentno AS 学生编号,(studentresult*0.9+5 ) AS 综合成绩

FROM `result`

WHERE (`studentresult`*0.9+5) >=60

ORDER BY studentresult DESC;

1

2

3

4

5

6

//把成绩都降低10%后加5分,再查询及格成绩,并按照成绩从高到低排序,如果成绩

//相同,再按照课程编号进行排序。

SELECT studentno AS 学生编号,(studentresult*0.9+5 ) AS 综合成绩

FROM `result`

WHERE (`studentresult`*0.9+5) >=60

ORDER BY studentresult DESC,subjectno;

二、SELECT语法-分页查询

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

SELECT   [ALL | DISTINCT]

{  * |  table.* | [ table.field1 [ as  alias1] [, table.field2 [as  alias2]][, …]] }

FROM  table_name  [ as  table_ alias  ]

    [ left|out|inner  join  table_name2 ]    //多表连接查询

    [ WHERE  … ]    //指定结果需满足的条件

    [ GROUP BY …]   //指定结果按照哪几个字段来分组

    [ HAVING …] //过滤分组的记录必须满足的次要条件

    [ ORDER BY… ]   //指定查询记录按一个或者多个条件排序

    [ LIMIT  {   [ offset,] row_count    |   row_count OFFSET offset   }] ;  //分页查询

    offset://偏移量

    row_count://显示的记录数

    LIMIT //LIMIT 子句:MySQL查询语句中使用LIMIT子句限制结果集

    如:SELECT studentno,studentresult

        FROM result

        WHERE subjectno=1 AND YEAR(examdate)=2019

        ORDER BY studentresult DESC

        LIMIT 5 //限制显示的结果集的行数,只显示5条

三、SELECT语法-分组查询

1

2

3

4

5

6

7

8

9

10

11

12

13

14

SELECT   [ALL | DISTINCT]

{  * |  table.* | [ table.field1 [ as  alias1] [, table.field2 [as  alias2]][, …]] }

FROM  table_name  [ as  table_ alias  ]

    [ left|out|inner  join  table_name2 ]    //多表连接查询

    [ WHERE  … ]    //指定结果需满足的条件

    [ GROUP BY …]   //指定结果按照哪几个字段来分组

    [ HAVING …] //过滤分组的记录必须满足的次要条件

    [ ORDER BY… ]   //指定查询记录按一个或者多个条件排序

    [ LIMIT  {   [ offset,] row_count    |   row_count OFFSET offset   }] ;  //分页查询

GROUP BY作用:使用GROUP BY关键字对查询结果分组

    对所有的数据进行分组统计

    分组的依据字段可以有多个,并依次分组

    与HAVING结合使用,进行分组后的数据筛选

GROUP BY子句经常和聚合函数结合使用完成分组统计功能

四、WHERE与HAVING对比

WHERE子句

用来筛选 FROM 子句中指定的操作所产生的行

GROUP BY子句

用来分组 WHERE 子句的输出

HAVING子句

用来从分组的结果中筛选行

五、子查询

基本语法:

SELECT … FROM 表名 WHERE 字段X 比较运算符(子查询)

1.外层查询称为父查询,圆括号中的查询称为子查询。

2.执行SQL语句时,先执行子查询,返回所有来自子查询的结果,再执行外围的父查询,返回查询的最终结果。

3.将子查询和比较运算符联合使用,必须保证子查询返回的值不能多于一个。

1、IN子查询

IN后面的子查询可以返回多条记录。

1

SELECT … FROM 表名 WHERE 字段X IN(子查询)

2、EXISTS子查询

EXISTS 子查询:带有EXISTS的子查询不返回任何记录的数据,只返回逻辑值“True”或“False”。

有结果为“True”,执行语句;无结果为“False”,不执行语句。

子查询有返回结果: EXISTS子查询结果为TRUE,执行外层查询;

子查询无返回结果: EXISTS子查询结果为FALSE, 外层查询不执行;

1

SELECT …… FROM 表名 WHERE EXISTS(子查询);

六、多表连接查询

1、内连接

内连接使用比较运算符根据每个表的通用列中的值匹配两个表中的行。

1

2

SELECT   字段列表   FROM   表1  INNER JOIN  表2 ON    表1.通用字段名=表2.通用字段名

SELECT   字段列表 FROM   表1 ,表2 WHERE    表1.通用字段名=表2.通用字段名

需要注意的是:

如果两个表中有相同的字段名,必须在列名前加表名。否则将出现 错误代码:1052 Column ‘studentno’ in field

list is ambiguous

1

2

3

4

5

6

7

8

9

10

查询学生的学号、姓名和成绩,并按照成绩降序排列

//第一种写法

SELECT s.studentno,s.studentname,r.studentresult FROM

student AS s INNER JOIN  result AS r

ON s.studentno=r.studentno ORDER BY r.studentresult DESC

//第二种写法

SELECT s.studentno,s.studentname,r.studentresult FROM

student AS s,result AS r

WHERE s.studentno=r.studentno

ORDER BY r.studentresult DESC

2、多表内连接

1

2

3

ELECT   字段列表 FROM   表1 join 表2 on 表1.通用字段名=表2.通用字段名

join 表3 on 表1.通用字段名=表3.通用字段名

join 表4 on 表4.通用字段名=表3.通用字段名;

3、左外连接

左表(表1)的记录将会全部表示出来,而右表(表2)只会显示符合匹配条件的记录。如图:

匹配,返回到结果集

无匹配,NULL值返回到结果集

1

SELECT 字段列表 FROM 表1 LEFT JOIN 表2 ON 表1.通用字段名=表2.通用字段名

4、右外连接

右外连接:右表(表2)的记录将会全部表示出来,而左表(表1)只会显示符合匹配条件的记录。如图:

匹配,返回到结果集

无匹配,NULL值返回到结果集

1

SELECT 字段列表 FROM 表1 RIGHT JOIN 表2 ON 表1.通用字段名=表2.通用字段名

5、自连接

自连接查询其实等同于连接查询,需要两张表,只不过它的左表(父表)和右表(子表)都是自己。做自连接查询的时候,是自己和自己连接,分别给父表和子表取两个不同的别名,然后附上连接条件。

1

2

3

SELECT  c1.cname AS "父名称",c2.cname AS  "子名称"

FROM tbl_category AS c1, tbl_category  AS c2

WHERE c1.cid = c2.pid;

6、不同的SQL JOIN对比

如图片:


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_55787308/article/details/126958821
相关文章
  • 深入了解MySQL中的慢查询
    一、什么是慢查询 什么是MySQL慢查询呢?其实就是查询的SQL语句耗费较长的时间。 具体耗费多久算慢查询呢?这其实因人而异,有些公司慢
  • MySQL中with rollup的用法及说明

    MySQL中with rollup的用法及说明
    MySQL with rollup的用法 当需要对数据库数据进行分类统计的时候,往往会用上groupby进行分组。 而在groupby后面还可以加入withcube和withrollup等关
  • mysql分组统计并求出百分比的方法

    mysql分组统计并求出百分比的方法
    mysql分组统计并求出百分比 1、mysql 分组统计并列出百分比 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 SELECT point_id, pname_cn, play_
  • 30种SQL语句优化的方法总结
    1)对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。 2)应尽量避免在 where 子句中使用!=或操作符
  • 达梦数据库获取SQL实际执行计划的方法

    达梦数据库获取SQL实际执行计划的方法
    环境说明: 操作系统:银河麒麟V10 数据库:DM8 相关关键字:DM数据库、SQL实际执行计划 一、set autotrace trace disql下执行set autotrace trace开启
  • MySQL数据库约束的介绍

    MySQL数据库约束的介绍
    基本介绍 约束用于确保数据库的数据满足特定的商业规则 在mysql中,约束包括:not null,unique,primary key,foreign key 和check5种 1.primary key(主键
  • MySQL索引的介绍

    MySQL索引的介绍
    1. MySQL 索引的最左前缀原则 左前缀原则是联合索引在使用时要遵循的原则,查询索引可以使用联合索引的一部分,但是必须从最左侧开始。
  • windows下Mysql多实例部署的操作方法
    当存在多个项目的时候,需要同时部署时,且只有一台服务器时,哪么就需要部署Mysql多个实例,原理很简单,多个mysql服务运行使用不同的
  • MySQL客户端/服务器运行架构介绍

    MySQL客户端/服务器运行架构介绍
    之前对MySQL的认知只限于会写些SQL,本篇开始进行对MySQL进行深入的学习,记录和整理下自己对MySQL不熟悉的地方。如果有需要可以关注我的
  • mysql8.0主从复制搭建与配置方案

    mysql8.0主从复制搭建与配置方案
    mysql主从搭建 环境:ubuntu20.04.1,mysql:8.0.22。 主:192.168.87.3 备:192.168.87.6 安装数据库 1 2 3 sudo apt-get install mysql-server sudo apt-get install mysql
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计