一、查询语法

select
字段列表
from
表名列表
where
条件列表
group by
分组列表
having
分组后条件
order by
排序字段
limit
分页限定

(提供一个表来操作操作)

-- 删除 stu 表
drop table if exists stu; -- 创建stu表
create table stu(
id int, -- 编号
name varchar(20), -- 姓名
age int, -- 年龄
sex varchar(5), -- 性别
address varchar(100), -- 地址
math double(5,2), -- 数学成绩
english double(5,2), -- 英语成绩
hire_date date -- 入学时间
); -- 添加数据
insert into stu(id,name,age,sex,address,math,english,hire_date)
VALUES
(1,'马运',55,'男','杭州',66,78,'1995-09-01'),
(2,'马花腾',45,'女','深圳',98,87,'1998-09-01'),
(3,'马斯克',55,'男','香港',56,77,'1999-09-02'),
(4,'柳白',20,'女','湖南',76,65,'1997-09-05'),
(5,'柳青',20,'女','湖南',86,NULL,'1998-09-01'),
(6,'刘德花',57,'男','香港',99,99,'1998-09-01'),
(7,'张雪有',22,'女','香港',99,99,'1998-09-01'),
(8,'德玛西亚',18,'男','南京',65,56,'1998-09-02');

二、基础查询

  1. 查询多个字段

select 字段列表 from 表名;
select * from 表名; -- 查询所有数据

  

-- 查询 name age 两列
SELECT
name, -- 姓名
age -- 年龄
FROM
 stu; -- 查询所有列的数据, 列名列表可以用 * 代替
select * from stu;
-- (通常情况下 企业中是不允许使用 * 的 不便于理解 与 注释)

  2、去除重复记录

select distinct 字段列表 from 表名;

-- 去除重复记录
select DISTINCT address from stu;

  3. 起别名

as: (as 也可以省略)
-- 查询姓名,数学成绩 ,英语成绩
select name, math as 数学成绩, english as 英语成绩 from stu;

三、条件查询

  1、 条件查询语法

select 字段列表 from 表名 where 条件列表;

  2、条件

  

  代码实例:

-- ====================条件查询================

-- 1. 查询年龄大于20岁的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age > 20; -- 2. 查询年龄大于等于20岁的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age >= 20; -- 3. 查询年龄大于等于20岁 并且 年龄小于等于30岁 的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age >= 20 && age <= 20; -- && 与 AND 含义一样 -- 4. 查询入学日期在’1998-09-01’到 ’1999-09-01’之间的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
hire_date BETWEEN '1998-09-01' AND '1999-09-01'; -- 5. 查询年龄等于18岁的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age = 18; -- 6. 查询年龄不等于18岁的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age != 18; -- 7. 查询年龄等于18岁 或者 年龄小于20岁 或者 年龄等于22岁的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
age = 18 OR age < 20 || age = 22; -- OR 与 || 含义一样 -- 8. 查询英语成绩为null 的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
english is NULL;

  3、模糊查询(like)

   通配符
(1)_: 代表单个任意字符
(2)%:代表任意个数字符

  

-- =============模糊查询 like ==========
/*
通配符
(1)_: 代表单个任意字符
(2)%:代表任意个数字符
*/ -- 1. 查询姓’马’的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
name LIKE '马%'; -- 2. 查询第二个字是’花’的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
name like '_花%'; -- 3. 查询名字中包含'德'的学员信息
select
name 姓名,
age 年龄,
sex 性别,
address 地址,
math 数学成绩,
english 英语成绩,
hire_date 入学时间
FROM
stu
WHERE
name like '%德%';

四、 排序查询

  1、 排序查询语法(中括号表示可以省略)

select 字段列表 from 表名 order by 排序字段名1 [排序方式1],排序字段名2 [排序方式2] ...;

  2、 排序方式

   ·ASC :升序排列(默认值)

   ·DESC :降序排列

  (当有多个排序条件时,当前边条件值一样时,才根据第二条件进行排序)

-- =================  排序查询
-- 1. 按照年龄升序排序
select * from stu ORDER BY age asc; -- 2. 按照数学二成绩降序排序
select * from stu order by math desc; -- 3. 按照数学成绩降序排序,如果数学成绩一样则按照英语成绩排序
select * from stu order by math desc , english asc ;

五、分组查询

  1、 聚合函数

    概念:将一列数据作为一个整体,进行纵向计算

    分类:(使用 count 统计数量时,通常使用 count(*)  *号会统计到任意行不全为null值的行,且会选择统计速度最快的一列)

        

    语法:(注意:null 值不参与所有聚合函数的运算)

select 聚合函数名(列名) from 表名;

    代码演示:

-- ==============聚合函数==========

-- 1. 统计班里有多少学生?
select count(name) from stu; -- 2.查询数学成绩最高分
select max(math) from stu; -- 3.查询数学成绩最低分
select min(math) from stu; -- 4.查询数学成绩总分
select sum(math) from stu; -- 5.查询数学成绩平均分
select avg(math) from stu;

  2、 分组查询

    语法:(注意:分组之后,查询的字段列表为聚合函数和分组字段 ,查询其他字段无任何意义)

select 字段列表 from 表名 [where 分组前条件限定] group by 分组字段名 [having 分组后条件过滤];

    where 和 having 的区别:

      执行时机不一样:where 是分组之前进行限定,不满足where条件,则不参与分组,而 having 是分组之后对结果进行过滤

      可判断的条件不一样: where 不能对聚合函数进行判断,having 可以

    执行顺序:where > 聚合函数 > having

    代码演示:

-- ===========分组查询 ========

 -- 注意:分组之后,查询的字段列表为聚合函数和分组字段 ,查询其他字段无任何意义
-- 1. 查询男女同学各自的数学平均分
select sex,avg(math) from stu group by sex; -- 2. 查询男女同学各自的数学平均分,以及各自人数
select sex,avg(math),count(*) from stu group by sex; -- 3. 查询男女同学各自的数学平均分,以及各自人数,要求分数低于70分的不参与分组
select sex,avg(math),count(*) from stu where math >= 70 group by sex; -- 4. 查询男女同学各自的数学平均分,以及各自人数,要求分数低于70分的不参与分组,分组之后人数大于2个
select sex,avg(math),count(*) from stu where math >= 70 group by sex having count(*) > 2;

六、 分页查询

  1、 语法:

select 字段列表 from 表名 limit 起始索引, 查询条目数;

  起始索引: 从0开始

  计算公式: 起始索引 = (当前页码 - 1)* 每页显示的条数

    (分页查询 limit 是MySQL数据库的方言)

    (Oracle 分页查询使用 rownumber)

    (SQL Server 分页查询使用 top)

  代码演示:

--  ==============分页查询 =============

-- 1. 从0开始查询,查询3条数据
select * from stu limit 0,3; -- 2. 每页显示3条数据,查询第1页数据
select * from stu limit 0,3; -- 3. 每页显示3条数据,查询第2页数据
select * from stu limit 3,3; -- 4. 每页显示3条数据,查询第3页数据
select * from stu limit 6,3; -- 公式总结 起始索引 = (要查询的页码数 - 1)* 每页要显示的数据条数

DQL—查询操作的更多相关文章

  1. Statement执行DQL语句(查询操作)

    import java.sql.Connection; import java.sql.ResultSet; import java.sql.Statement; import org.junit.T ...

  2. 6.1课堂笔记—DML(数据操作语言),DQL查询语句

    一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...

  3. Mysql 数据库操作之DDL、DML、DQL语句操作

    Mysql 数据库操作之DDL.DML.DQL语句操作 设置数据库用户名密码 l  Show databases 查看数据库列表信息 l  查看数据库中的数据表信息 ,格式: use 数据库名: sh ...

  4. SQL中的DQL查询语句

    目录 1. DQL:查询语句 排序查询 聚合函数 分组查询 分页查询 2. 约束 3. 多表之间的关系 4. 范式 DQL:查询语句 1. 排序查询 语法:order by 子句 order by 排 ...

  5. (四)DQL查询数据(最重点)

    4.1   DQL Data Query Language 数据查询语言 1   所有的查询操作都用它  Select 2   简单的查询,复杂的查询它都能做 3   数据库中最核心的语言,最重要的语 ...

  6. [C#] 进阶 - LINQ 标准查询操作概述

    LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ...

  7. MongoDB的查询操作

    1. 前言 在这篇博文中,我们将学习如何查询mongoDB中的数据.当我们把数据存储在mongoDB以后,我们需要把数据查询出来.毕竟CRUD操作中,查询操作在我们系统中是我们应用比较频繁的操作.我们 ...

  8. Django 1.10 中文文档------3.2.2 查询操作making queries

    3.2.2 查询操作 6.15章节包含所有模型相关的API解释. 后面的内容基于如下的一个博客应用模型: from django.db import models class Blog(models. ...

  9. InfluxDB学习之InfluxDB的HTTP API查询操作

    在 InfluxDB学习 的上一篇文章:InfluxDB学习之InfluxDB的HTTP API写入操作 中,我们介绍了使用InfluxDB的HTTP API进行数据写入操作的过程,本文我们再来介绍下 ...

  10. mongDB-- 3. 查询操作

    1. 准备工作 (1)启动mongo 进入mongo安装目录的bin/ 目录 , ./mongod (2)启动mongo客户端 ./mongo (3) 查看所有库 show dbs; (4) 切换到l ...

随机推荐

  1. oeasy教您玩转vim - 16 跳到某行

    跳到某行 回忆上节课内容 上下行 向 下 是 j 向 上 是 k 上下行首 向 下 到行首非空字符 + 向 上 到行首非空字符 - 这些 motion 都可以加上 [count] 来翻倍 首尾行 首行 ...

  2. VBA:用代码操作代码

    Sub auto_open() Call runtimer '打开文档时自动运行 End Sub Sub runtimer() Application.OnTime Now + TimeValue(& ...

  3. java面试一日一题:垃圾回收器如何组合使用

    问题:请讲下java中垃圾回收器如何组合使用 分析:该问题主要考察对垃圾回收器的深度理解 回答要点: 主要从以下几点去考虑, 1.垃圾回收器有哪些种类,每种的特点 2.组合使用怎么理解 在上篇文章&l ...

  4. java面试一日一题:1.6/7/8Java内存区域有什么不同吗

    问题:请讲下在JDK6 JDK7 JDK8中java内存区域有什么不同吗 分析:该问题主要考察对JVM运行时区域的了解,首先要了解最基本的内存区域划分,然后再去掌握其中的变化,再延申一点,为什么要这样 ...

  5. 【Java】JDBC Part5.1 Hikari连接池补充

    Hikari Connection Pool Hikari 连接池 HikariCP 官方文档 https://github.com/brettwooldridge/HikariCP Maven依赖 ...

  6. 如何解决单IP爬取网站的单IP受限问题

    由于最近博导承接了一项国家科技项目,需要对大量的网站进行爬取,但是现在的很多网站都使用了反爬手段,比如限制一个session的不同网页的访问时间间隔,甚至更有甚者直接对IP地址也做了限制.对于限制se ...

  7. NoSQL之事务和相关特性

    NoSQL 简介 NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL". 在现代的计算系统上每天网络上都会产生庞大的数据量. 这些数据有很大一部分是由关 ...

  8. 一个好用的消息推送服务【Server 酱】

    今天给大家介绍一个好用的消息推送服务Server 酱 Server 酱简介 Server 酱是什么 「Server 酱」,英文名「ServerChan」,是一款「手机」和「服务器」.「智能设备」之间的 ...

  9. 【主席树】P3834 【模板】可持久化线段树 2

    P3834 [模板]可持久化线段树 2 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) #include <bits/stdc++.h> using namespace ...

  10. 8. 从0学ARM-内联汇编、混合汇编、ATPCS规则

    一.gcc 内联汇编 内联汇编即在C中直接使用汇编语句进行编程,使程序可以在C程序中实现C语言不能完成的一些工作,例如,在下面几种情况中必须使用内联汇编或嵌入型汇编. 程序中使用饱和算术运算(Satu ...