MySQL_DQL语句(查询语句以及常用函数)

news2025/2/25 8:29:03

基础查询

不带条件的查询查询多个字段

  1. 语法:

    #查询指定字段的数据
    SELECT 字段1, 字段2, 字段3 ... FROM 表名 ;  
    #查询表中全部字段的数据
    SELECT * FROM 表名 ;
    
    • 案例:查询表中所有信息数据

      SELECT * FROM employee;
      
    • 案例:查询表中姓名和性别这两个字段的信息

      SELECT name,gender from employee;
      

查询字段设置别名

  1. 语法:

    SELECT 字段1 [ AS 别名1 ] , 字段2 [ AS 别名2 ] ... FROM 表名;
    SELECT 字段1 [ 别名1 ] , 字段2 [ 别名2 ] ... FROM 表名;
    
    • 案例:查询表中姓名和性别这两个字段的信息,并且给中文别名

      SELECT name AS '姓名',gender AS '性别' FROM employee;
      ​
      SELECT name '姓名1',gender '性别1' FROM employee;
      
    • 注意:AS 是可以省略的

去除重复记录

  1. 语法:使用一个关键字 DISTINCT

    SELECT DISTINCT 字段列表 FROM 表名;
    
    • 案例:查询员工的家庭住址(不要重复)

      SELECT DISTINCT address FROM employee; 
      

基础查询的案例

  1. 查询指定字段 name, age并返回

    SELECT name,age FROM employee;
    
  2. 查询返回所有字段

    SELECT * FROM employee;
    
  3. 查询所有员工的年龄,起别名

    SELECT age '年龄' FROM employee;
    
  4. 查询公司员工的家庭地址有哪些(不要重复)

    SELECT DISTINCT address FROM employee;
    

条件查询

  1. 语法:使用到 where 之后

    SELECT 字段列表 FROM 表名 WHERE 条件列表 ;
    

运算符

比较运算符

在这里插入图片描述

注意:

  • java 中的等于是使用 == 而 mysql 中的等于直接使用 =
  • BETWEEN … AND … 范围包含最小值和最大值
  • IN(…) 属于括号后的子集
  • LIKE % 表示通配符
  • is null 表示空,非空 is not null
逻辑运算符

在这里插入图片描述

  • 案例:查询年龄小于20并且idcard 非空的

    SELECT * FROM employee where age < 20 and idcard is not null;
    

条件查询案例

  • 查询年龄等于 18 的员工

    SELECT * FROM employee WHERE age = 18;
    
  • 查询年龄小于 20 的员工信息

    SELECT * FROM employee WHERE age < 20;
    
  • 查询年龄大于等于 20 的员工信息

    SELECT * FROM employee WHERE age >= 20;
    
  • 查询没有身份证号的员工信息

    SELECT * FROM employee WHERE idcard is null;
    
  • 查询有身份证号的员工信息

    SELECT * FROM employee WHERE idcard is not null;
    
  • 查询年龄不等于 18 的员工信息

    SELECT * FROM employee WHERE age != 18;
    
  • 查询年龄在15岁(包含) 到 20岁(包含)之间的员工信息

    SELECT * FROM employee WHERE age BETWEEN 15 AND 20;
    ​
    SELECT * FROM employee WHERE age >= 15 and age <= 20;
    ​
    SELECT * FROM employee WHERE age >= 15 && age <= 20;
    
  • 查询性别为女且年龄小于 23岁的员工信息

    SELECT * FROM employee WHERE age < 23 AND gender = '女';
    
  • 查询年龄等于18 或 20 或 40 的员工信息

    SELECT * FROM employee WHERE age in(18,20,40);
    ​
    SELECT * FROM employee WHERE age  = 18 or age = 20 or age = 40;
    
  • 查询姓名为两个字的员工信息 _ %

    SELECT * FROM employee WHERE name like '__';
    
  • 查询身份证号最后一位是X的员工信息

    SELECT * FROM employee WHERE idcard like '%X';
    SELECT * FROM employee WHERE idcard like '_________________X';
    

常用聚合函数

  1. 语法:SELECT 聚合函数(字段列表) FROM 表名 ;将一列数据作为一个整体,进行纵向运算。

在这里插入图片描述

案例

  • 统计企业员工数量

    SELECT COUNT(id) FROM employee
    
  • 统计企业员工的平均年龄

    SELECT AVG(age) FROM employee;
    
  • 统计企业员工的最大年龄

    SELECT MAX(age) FROM employee;
    
  • 统计企业员工的最小年龄

    SELECT MIN(age) FROM employee;
    
  • 统计家庭是杭州员工的年龄之和

    SELECT SUM(age) FROM employee WHERE address = '杭州';
    

分组查询

  1. 语法(GROUP BY )

    SELECT 字段列表 FROM 表名 [ WHERE 条件  ] GROUP BY 分组字段名 [ HAVING 分组后过滤条件 ];
    
  2. WHERE 和 HAVING 的区别

    • 执行时间不同,WHERE 是分组之前执行,不参与分组,HAVING 是分组之后执行
    • 判断条件不同,WHERE 是不能对聚合函数做判断的,HAVING 是可以的。
  3. 注意:

    • 分组之后,查询的字段一般为聚合函数和分组字段,查询其它其它字段没有意义;
    • 执行顺序:WHERE > 聚合函数 > HAVING
    • 可以支持多字段分组 GROUP BY COLUM1,COLUM2;

案例

  • 根据性别分组 , 统计男性员工 和 女性员工的数量

    SELECT gender,count(id) from employee GROUP BY gender;
    
  • 根据性别分组 , 统计男性员工 和 女性员工的平均年龄

    SELECT gender,avg(age) from employee GROUP BY gender;
    
  • 查询年龄小于45的员工 , 并根据家庭地址分组 , 获取员工数量大于等于3的家庭地址

        SELECT address,count(*) num
            FROM employee 
        WHERE age < 45
            GROUP BY address having num >= 3;
    
  • 统计各个家庭地址上班的男性及女性员工的数量

    SELECT gender,count(*) '数量',address
            FROM employee
            GROUP BY gender,address; 
    

排序查询

  1. 语法(ORDER BY)

    • 排序方式

      • 升序 ASC(默认就是升序)
      • 降序 DESC

      SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1 , 字段2 排序方式2 ;

案例

  • 根据年龄对公司的员工进行升序排序

    SELECT * FROM employee ORDER BY age ;
    SELECT * FROM employee ORDER BY age ASC;
    
  • 根据入职时间, 对员工进行降序排序

    SELECT * FROM employee ORDER BY entrydate DESC;
    
  • 根据年龄对公司的员工进行升序排序 , 年龄相同 , 再按照入职时间进行降序排序

    SELECT * FROM employee ORDER BY age ASC,entrydate DESC;
    

分页查询

  1. 语法(LIMIT)

    SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数 ;
    
  2. 注意:

    • 起始索引从0开始,起始索引 = (查询页码 -1 )* 每页显示的记录数

    • LIMIT 是MYSQL 中的实现

    • SQLServer中:

      下面示例会跳过前 10 行,获取接下来的 5 行数据,实现分页查询。

SELECT ProductId, ProductName, Price
FROM Products
ORDER BY ProductId
OFFSET 10 ROWS
FETCH NEXT 5 ROWS ONLY;
  • 如果只查第一页数据,起始索引是可以省略的,limit 5;

案例

  • 查询第1页员工数据, 每页展示 5 条记录

    SELECT * FROM employee limit 0,5;
    ​
    SELECT * FROM employee LIMIT 5;
    
  • 查询第2页员工数据, 每页展示 5 条记录

    #(查询页面 -1) * 页码显示数
    SELECT * FROM employee LIMIT 5,5;
    

执行优先级

        SELECT 
4           字段列表                            
        FROM
1           表名列表                            
        WHERE
2           条件列表                            
        GROUP BY
3           分组字段列表                         
        HAVING
            分组后条件列表                       
        ORDER BY
5           排序字段列表                        
        LIMIT
6           分页参数        
  • 案例验证

    • 查询年龄大于15的员工姓名、年龄,并根据年龄进行升序排序。

          SELECT emp.name eName,emp.age eAge from employee emp WHERE emp.age > 15 GROUP BY eAge HAVING eAge >20  order by eAge limit 2;
      
  • 执行先后

    from ... where ... group by ... having ... select ... order by ... limit
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/863163.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IntellIJ Idea 连接数据库-MySql

前言&#xff1a;可以用mariaDB工具&#xff0c;在本地创建服务器主机和数据库&#xff0c;而后用intellIJ Idea尝试连接 MariaDB创建数据库练习 1.IntellIJ Idea打开界面右侧Database工具&#xff0c;选择MySQL数据库。 2.填写数据库账号密码&#xff0c;地址端口号&#xff…

树莓派安装Ubuntu系统(无屏幕)

树莓派安装ubuntu系统 前言 软件需要: 1.方案一 win32diskimager-1.0.0-install.exe SDFormatterha Ubuntu镜像&#xff08;可以官网下载也可以清华源&#xff09; 方案二: 树莓派镜像烧录器 树莓派镜像烧录器直达下载 硬件需要: 64GB内存卡&#xff08;推荐Sanddisk Ultra&am…

程序员自由创业周记#6:劝退

程序员自由创业周记#6&#xff1a;劝退 photo-1547496614-154dee7fd157 这是一位程序员进行独立开发创业的记录&#xff0c;将分享创业过程中的所思所想以及收支明细。 劝退 如果一位程序员问我要不要进行独立开发创业&#xff0c;我100%会建议他不要冲动&#xff0c;因为这条路…

话题暴涨2344%,“妆面减负”成大势,小红书数据发掘潮流新趋势

Less is more&#xff0c;简约风吹遍时尚界&#xff0c;小红书上继Clean fit穿搭风热度高涨后&#xff0c;Clean makeup的妆容也逐渐走红&#xff0c;成为当下年轻人争相更风的时髦新趋势。 2023时尚新趋势&#xff0c;Clean fit→Clean makeup Clean makeup&#xff0c;即轻妆…

腾讯云轻量应用服务器端口怎么打开?图文方法来了

腾讯云轻量应用服务器端口放行在哪设置&#xff1f;在防火墙中可以开启端口号&#xff0c;腾讯云轻量应用服务器端口怎么开通&#xff1f;在轻量服务器管理控制台的防火墙中开启端口&#xff0c;如果是CVM云服务器在安全组中开通&#xff0c;腾讯云服务器网以轻量应用服务器开通…

MySQL数据库-基础篇

基础篇 一、SQL 分类 DDL-数据库操作 查询 创建表 数据类型 数值类型 字符串类型 日期类型 添加 修改 删除字段 修改表名 删除表 小结 DML-数据增删改 添加数据 修改数据 删除数据 小结 DQL-数据查询数据 基本查询 条件查询 聚合函数 分组查询 排序查询 分页查…

图片转表格方法分享,几个步骤轻松转换

在日常工作和学习中&#xff0c;我们经常会遇到需要将图片中的表格转换为可编辑的电子表格的情况。这时候&#xff0c;我们通常会手动一个一个地输入表格中的数据&#xff0c;费时费力&#xff0c;还容易出错。但是&#xff0c;其实有一些简单的方法可以帮助我们快速地将图片转…

关于npoi插入一条斜向上得线记录一下

在使用hssf可以直接按照行列插入。 HSSFWorkbook book new HSSFWorkbook();HSSFSheet sheet1 (HSSFSheet)book.CreateSheet("Sheet1");HSSFPatriarch patriarch (HSSFPatriarch)sheet1.CreateDrawingPatriarch();HSSFClientAnchor a1 new HSSFClientAnchor(255, …

k8s service

1、认识Service 程序在容器中、容器在Pod中&#xff0c;可以通过pod的ip来访问应用程序&#xff0c;但是podIP会随着创建销毁而改变。由此&#xff0c;Service出现&#xff1a; Service会对提供同一个服务的多个pod进行聚合&#xff0c;并且提供一个统一的入口地址。通过访问…

摄影照片后期处理工具:Athentech Perfectly Clear Complete

Athentech Perfectly Clear Complete 是一款强悍便捷的LR图像清晰化滤镜插件&#xff0c;可以让你想要更好的处理照片&#xff0c;Perfectly Clear完美清晰掌握了智能图像校正的技术原理 &#xff0c;可以在很短的时间里创造出高质量的照片&#xff0c;所以你可以回到做你真正的…

ISO/IEC技术标准-RFID

ISO/IEC技术标准规定了RFID有关技术特征、技术参数和技术规范&#xff0c;主要包括ISO/IEC 18000(空中接口参数)、ISO/IEC 10536(密耦合、非接触集成电路卡)、ISO/IEC 15693(疏耦合、非接触集成电路卡)和ISO/IEC 14443(近耦合、非接触集成电路卡)等。ISO/IEC的RFID技术标准构成…

nginx的rewrite功能和案例介绍

一.定义 二.作用 1.调整用户浏览的url&#xff0c;模板更规范 2.提升搜索引擎网站给予用户的体验&#xff0c;可以将动态的url伪装成静态地址提供服务 3.在网站更换新域名后&#xff0c;可以通过旧域名访问到新域名 4.便于根据特殊变量1、客户信息进行url调整 三.区分地址…

第四篇:组件更新:完整的 DOM diff 流程是怎样的?(上)

上一节课我们梳理了组件渲染的过程&#xff0c;本质上就是把各种类型的 vnode 渲染成真实 DOM。我们也知道了组件是由模板、组件描述对象和数据构成的&#xff0c;数据的变化会影响组件的变化。组件的渲染过程中创建了一个带副作用的渲染函数&#xff0c;当数据变化的时候就会执…

判断时间段是否重叠

1、逻辑公式 时间段1&#xff1a;start1&#xff08;开始时间&#xff09;&#xff0c;end1&#xff08;结束时间&#xff09; 时间段2&#xff1a;start2&#xff08;开始时间&#xff09;&#xff0c;end2&#xff08;结束时间&#xff09; 重叠条件为&#xff1a;start1 <…

ad+硬件每日学习十个知识点(30)23.8.10 (SDIO端口扩展器TXS02612RTWR,模数转换器ADC121C027)

文章目录 1.cpu->SDIO端口扩展器->SD卡槽->SD卡(当然也可以反向读取)2.SDIO端口扩展器介绍3.SDIO端口扩展器TXS02612RTWR4.SD卡槽5.什么是模数转换器&#xff1f;6.I2C模数转换器ADC121C0277.模数转换方案 1.cpu->SDIO端口扩展器->SD卡槽->SD卡(当然也可以反…

win11(不符合要求)安装方法

win11&#xff08;不符合要求&#xff09;安装方法&#xff1a; 注意&#xff01;这样安装win11可能会导致文件丢失&#xff0c;请备份重要文件&#xff08;会删除c盘很多文件&#xff0c;可以在c盘Windows.old文件夹恢复。 第一步、下载win11ISO镜像&#xff1a;恰到好处系统…

【C++】开源:spdlog跨平台日志库配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍spdlog日志库配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下…

虚拟机安装国产操作系统的方法

1.这里以银河麒麟为例&#xff0c;其他以liunx为基础的国产操作系统都是一样的方法。 2.下载操作系统如下&#xff08;选第一个就行&#xff09;&#xff1a; 任选其一下载&#xff1a; 3.安装虚拟机软件(这里以virtualbox为例&#xff0c;vmare也是一样都可以) 4.打开虚拟机…

Django配置(部署环境较乱,暂时启用)

django配置 web服务器中部署项目及WSGI简介 web服务器 WSGI 在IIS中部署django项目 安装 wfastcgi &#xff1a;pip install wfastcgi安装IIS&#xff1a; 以上选择项勾选后确定 将CGI文件复制到项目中&#xff0c; 将项目复制到IIS默认目录中 部署IIS 添加变量信息如下…

Apache Paimon 流式数据湖 V 0.4 与后续展望

摘要&#xff1a;本文整理自阿里云开源大数据表存储团队负责人、阿里巴巴高级技术专家&#xff0c;Apache Flink PMC&#xff0c;Paimon PPMC 李劲松&#xff08;之信&#xff09;在 Apache Paimon Meetup 的分享。本篇内容主要分为四个部分&#xff1a; 1. 湖存储上的难点 2. …