MySQL:DML数据操作语言(添加,删除,修改),DDL数据查询语言(条件查询,分组查询,排序查询,分页查询)

news2024/11/19 23:30:39

目录

  • 1.DML(数据操作语言)
    • 1.添加数据
    • 2.修改数据
    • 3.删除数据
  • 2.DQL(数据查询语言)
    • 1.DQL-语法
    • 2.基本查询
    • 3.条件查询(WHERE)
      • 1.语法:
      • 2.条件:
      • 3.案例:
    • 4.聚合函数
      • 1.介绍
      • 2.常见聚合函数
      • 3.语法
      • 4.案例
    • 5.分组查询(GROUP BY)
      • 1.语法
      • 2.where与having区别
      • 3.案例
    • 6.排序查询(ORDER BY)
      • 1.语法
      • 2.排序方式
      • 3.案例
    • 7.分页查询(LIMIT)
      • 1.语法
      • 2.案例

1.DML(数据操作语言)

DML英文全称是Data Manipulation Lanquage(数据操作语言),用来对数据库中表的数据记录进行增删改操作。

1.添加数据

1.给指定字段添加数据

INSERT INTO 表名(字段名1,字段名2,...) VALUES (1,2,...);

2.给全部字段添加数据

INSERT INTO 表名 VALUES(1,2,...);

3.批量添加数据

INSERT INTO 表名(字段名1,字段名2,...) VALUES (1,2,...),(1,2,...),(1,2,...);
INSERT INTO 表名 VALUES (1,2,...),(1,2,...),(1,2,...);

注意:
①插入数据时,指定的字段顺序需要与值的顺序是一一对应的
字符串和日期型数据应该包含在引号中
③插入的数据大小,应该在字段的规定范围内.

2.修改数据

UPDATE 表名 SET 字段名1=1,字段名2=2,....[WHERE 条件];

注意:修改语句的条件可以有,也可以没有,如果没有条件,则会修改整张表的所有数据

3.删除数据

DELETE FROM 表名[WHERE 条件];

注意:

  • DELETE语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数据
  • DELETE语句不能删除某一个字段的值(可以使用UPDATE)。

2.DQL(数据查询语言)

DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记录。

1.DQL-语法

在这里插入图片描述

2.基本查询

1.查询多个字段:

SELECT 字段1,字段2,字段3 ... FROM 表名;
SELECT * FROM 表名;

2.设置别名:

SELECT 字段1 [AS 别名1],字段2 [AS 别名2]...FROM 表名;

关键字:AS

3.去除重复记录:

SELECT DISTINCT 字段列表 FROM 表名;

关键字:DISTINCT

3.条件查询(WHERE)

1.语法:

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

2.条件:

在这里插入图片描述
在这里插入图片描述

3.案例:

  1. 查询年龄小于22的员工
select *
from employee
where age < 22;
  1. 查询有身份证号的员工
select *
from employee
where idcard is not null;
  1. 查询年龄不等于88岁的员工
select *
from employee
where age <> 88;
  1. 查询年龄在15岁到25岁之间的员工信息
select *
from employee
where age between 15 and 25;
  1. 查询性别为女 且 年龄小于25岁的员工信息
select *
from employee
where gender = '女'
  and age < 25;
  1. 查询年龄等于21,45,88的员工信息
select *
from employee
where age in (21, 45, 88);
  1. 查询姓名为两个字的员工信息
select *
from employee
where name like '__';
  1. 查询身份证号最后一位是X的员工信息
select *
from employee
where idcard like '%X';

4.聚合函数

1.介绍

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

2.常见聚合函数

在这里插入图片描述

3.语法

SELECT 聚合函数(字段列表) FROM 表名;

4.案例

  1. 统计员工数量
select count(*)
from employee;
  1. 统计员工的平均年龄
select avg(age)
from employee;
  1. 统计员工的最大年龄
select max(age)
from employee;
  1. 统计员工的最小年龄
select min(age)
from employee;
  1. 统计北京地区的员工年龄之和
select sum(employee.age)
from employee
where work_address = '北京';

5.分组查询(GROUP BY)

1.语法

SELECT 字段列表 FROM表名[WHERE 条件] GROUP BY 分组字段名[HAVING 分组后过滤条件];

2.where与having区别

①执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤。
②判断条件不同: where不能对聚合函数进行判断,而having可以。

注意:

  • 执行顺序: where >聚合函数>having
  • 分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义

3.案例

  1. 根据性别分组,统计男性员工和女性员工的数量
select employee.gender, count(*)
from employee
group by gender;
  1. 根据性别分组,统计男性员工 和 女性员工的平均年龄
select employee.gender, avg(age)
from employee
group by gender;
  1. 查询年龄小于45的员工,根据工作地址分组,获取员工数量小于等于3的工作地址
select employee.work_address, count(*)
from employee
where age < 45
group by work_address
having count(*) <= 3;

6.排序查询(ORDER BY)

1.语法

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

2.排序方式

  • ASC:升序(默认值)
  • DESC:降序

注意:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。

3.案例

  1. 根据年龄对公司的员工进行升序排序
select *
from employee
order by age asc;
  1. 根据入职时间,对员工进行降序排序
select *
from employee
order by entrydate desc;

  1. 根据年龄对公司的员工进行升序排序,年龄相同,再按照入职时间进行降序排序
select *
from employee
order by age asc, entrydate desc;

7.分页查询(LIMIT)

1.语法

SELECT 字段列表 FROM 表名 LIMIT 起始索引,查询记录数;

注意:

  • 起始索引从0开始 起始索引 = ( 查询页码 − 1 ) ∗ 每页显示记录数 起始索引=(查询页码-1)*每页显示记录数 起始索引=(查询页码1)每页显示记录数
  • 分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT
  • 如果查询的是第一页数据,起始索引可以省略,直接简写为limit 10。

2.案例

  1. 查询第1页员工数据,每页展示10条记录
select * from employee limit 0,10;
  1. 查询第2页员工数据,每页展示10条记录
select * from employee limit 10,10;

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

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

相关文章

VS2019 C++安装最基本的组件

我是C初学者&#xff0c; 我只想用最基本的C编写程序&#xff0c;不需要MFC。 所以下载了一个离线安装版本放在这里&#xff0c;我自己用的现成的文件。 使用以下命令行创建&#xff1a; 1.C基本组件 不含MFC, 带ATL库 共(1.96G) vs2019.exe --layout d:\vs2019 --lang zh-CN …

C#用string.Replace方法批量替换某一类字符串

目录 一、关于字符串及其操作常识 二、String.Replace 方法 1.重载 2.Replace(Char, Char) 3.Replace(String, String) &#xff08;1&#xff09;实例&#xff1a; &#xff08;2&#xff09;生成结果&#xff1a; 4.Replace(String, String, StringComparison) 5.…

matlab绘图修改坐标轴数字字体大小及坐标轴自定义间隔设置

一、背景 在matlab使用plot函数绘图后&#xff0c;生成的图片坐标轴数字字体大小及间隔可能并不符合我们的要求&#xff0c;因此需要自定义修改&#xff0c;具体方法如下 二、修改坐标轴数字字体大小 只需添加以下命令即可&#xff1a; set(gca,FontName,Times New Roman,F…

DAPP和APP的区别在哪?

随着科技的飞速发展&#xff0c;我们每天都在与各种应用程序打交道。然而&#xff0c;你是否真正了解DAPP和APP之间的区别呢&#xff1f;本文将为你揭示这两者的核心差异&#xff0c;让你在自媒体平台上脱颖而出。 一、定义与起源 APP&#xff0c;即应用程序&#xff0c;通常指…

C++并发编程实战第2版笔记

文章目录 p19 某个线程只可以join()一次p22 只有当joinable()返回true时才能调用detach()P21 在std::thread对象析构前&#xff0c;必须明确是等待还是分离线程P25 移动语义P25 将类的成员函数设定为线程函数p41 std::mutex和类模板std::lock_guard<> p19 某个线程只可以…

多传感器融合SLAM数学学习历程

多传感器融合SLAM数学学习历程 >>> 流形和流形空间&#xff08;姿态&#xff09; https://blog.csdn.net/professor_Xie/article/details/131911894 fast-lio 带着问题 看知识 欧式空间和流形空间的区别和联系? 基本结构&#xff1a;欧式空间是我们熟悉的传统三维…

胖东来热度持续上升的原因是什么?

胖东来超市胖东来超市是一家知名的连锁超市&#xff0c;以其优质的服务和丰富的商品而闻名。在这个充满竞争的市场中&#xff0c;胖东来超市始终保持着良好的业绩和口碑。那胖东来爆火的原因是什么呢&#xff1f; 1.人性化服务&#xff1a;胖东来超市坚信零售不仅仅是商品的销售…

Linux动态分配IP与正向解析DNS

目录 一、DHCP分配 1. 动态分配 1.1 服务端服务安装 1.2 修改服务端dhcp配置 1.3 修改客户端dhcp&#xff0c;重启查询网卡信息 2. 根据mac固定分配 2.1 修改服务器端dhcp服务配置 2.2 客户端自动获取&#xff0c;查看网卡信息 二、时间同步 1. 手动同步 2. 自动同…

【MySQL】表设计与范式设计

文章目录 一、数据库表设计一对一一对多多对多 二、范式设计第一范式第二范式第三范式BC范式第四范式 一、数据库表设计 一对一 举个例子&#xff0c;比如这里有两张表&#xff0c;用户User表 和 身份信息Info表。 因为一个用户只能有一个身份信息&#xff0c;所以User表和In…

无限创意与自由协作:现可在 Splashtop 上使用 Wacom Bridge 的通用版本

2024年1月9日 加利福尼亚州库比蒂诺和俄勒冈州波特兰 数字笔技术的全球领导者 Wacom 和高性能远程访问解决方案供应商 Splashtop 宣布正式发布 Wacom Bridge 的通用版本&#xff0c;目前可在几个特定国家的 Splashtop Enterprise 和 Splashtop Business Access Performance 产…

AppDesigner滤波器幅度仿真——IIR和FIR二十余种

1、AppDesigner简介 MATLAB Designer为滤波器设计提供了直观而高效的工具。通过该系统&#xff0c;用户可以通过简单的操作&#xff0c;选择不同的滤波器类型和模块&#xff0c;调整输入参数指标&#xff0c;即可实现滤波器的设计和幅值的绘制。这种图形化的设计方式使得即便对…

Hana 实时数据同步优化(3)

简述 CloudCanal 近期对 Hana 源端链路做了新一轮优化&#xff0c;优化点主要来自用户实际场景使用&#xff0c;这篇文章简要做下分享。 本轮优化主要包含: 新增任务级增量表新增增量表定时清理能力新增增量表表结构自动演进能力任务延迟判定优化Hana 1.x 的兼容产品化和文档…

ROS-urdf集成gazebo

文章目录 一、URDF与Gazebo基本集成流程二、URDF集成Gazebo相关设置三、URDF集成Gazebo实操四、Gazebo仿真环境搭建 一、URDF与Gazebo基本集成流程 1.创建功能包 创建新功能包&#xff0c;导入依赖包: urdf、xacro、gazebo_ros、gazebo_ros_control、gazebo_plugins 2.编写URD…

linux部署apache服务部署静态网站

第一步&#xff1a;配置IP地址 第二步&#xff1a;创建挂载点 配置yum仓库 mkdir -p /media/cdrom 挂载 mount /dev/cdrom /media/cdrom 安装服务 安装yum源 启用httpd服务程序并将其加入到开机启动项中 建立网站数据保存目录&#xff0c;并创建首页文件 mkdir /home/wwwroo…

源码搭建教学:连锁餐饮APP开发实战

连锁餐饮APP&#xff0c;对于很多从事餐饮行业的人来说不会陌生&#xff0c;同样这个项目本身就有着很高的热度。今天&#xff0c;小编将深入为大家讲述一下此系统的前后端开发、数据库设计、用户界面设计等方面&#xff0c;让您深入了解全栈开发的方方面面。 一、项目准备与规…

【排序】对各种排序的总结

文章目录 前言1. 排序算法的复杂度及稳定性分析2. 排序算法的性能测试2.1 重复率较低的随机值排序测试2.2 重复率较高的随机值排序测试 前言 本篇是基于我这几篇博客做的一个总结&#xff1a; 《简单排序》&#xff08;含&#xff1a;冒泡排序&#xff0c;直接插入排序&#x…

git 中的概念

git 中的概念 在使用 Git 版本控制的过程中&#xff0c;有些概念我们必须有所了解&#xff0c;这样才能更有效率也更有意义的学下去。 有清楚且正确的概念认知&#xff0c;不但有助于我们学习如何操作 Git 命令&#xff0c;更重要的是&#xff0c;学习 Git 的相关知识也会更加…

字符串处理(将字符串中符合十六进制数据格式的数字和字符按照其对应的十进制数值进行累加) C语言xdoj704

题目描述&#xff1a; 输入由数字和字符构成的字符串&#xff08;不包含空格&#xff09;&#xff0c;将字符串中符合十六进制数据格式的数字和字符按照其对应的十进制数值进行累加&#xff0c;并输出累加结果&#xff0c;如果字符串中不含有任何满足十六进制格式的字符&#x…

云服务器租用价格表,阿里云腾讯云华为云2024年优惠对比

作为多年站长使市面上大多数的云厂商的云服务器都使用过&#xff0c;很多特价云服务器都是新用户专享的&#xff0c;本文有老用户特价云服务器&#xff0c;阿腾云atengyun.com有多个网站、小程序等&#xff0c;国内头部云厂商阿里云、腾讯云、华为云、UCloud、京东云都有用过&a…

休息一会 sleep

文章目录 休息一会 sleep休息5分钟1小时后提醒我时分秒搭配使用倒计时计时器结合脚本更多信息 休息一会 sleep … note:: 莫听穿林打叶声&#xff0c;何妨吟啸且徐行。 苏轼 Linux sleep命令可以用来将目前动作延迟一段时间。 sleep的官方定义为&#xff1a; sleep - delay …