MySql数据库从0-1学习-第二天DML和DQL学习

DML

对数据库表中的数据进行增删改操作

Insert 语法

//指定字段添加数据
insert into 表名(字段名1,字段名2) values (值1,值2);
//全部字段添加数据:
insert into 表名 values(值1,值2...);
//批量添加数据(指定字段)
insert into 表名(字段名1,字段名2) values(值1,值2),(值1,值2);
//批量添加数据(全部字段)
insert into 表名 values(值1,值2),(值1,值2);

update 语法

//修改数据,如果没有where 语句 会更新整张表的数据
update 表名 set 字段1=值1,字段2=值2... where 语句;

delete 语法

//删除语句,如果没有where语句,会删除整张表的数据
delete  from 表名 where语句;

DQL

对数据库中的数据进行查询

查询语法

  • 基本查询
  • 条件查询
  • 分组查询
  • 排序查询
  • 分页查询
select 字段列表
from表名列表
where 条件列表
group by分组字段列表
having分组后条件列表
limit分页参数

基本查询

//查询多个字段
select 字段1,字段2 from 表名;
//查询所有的字段
select * from 表名;
//查询多个字段,并设置别名(as 关键字可省略)
select 字段1 as 别名1, 字段2 as 别名2 from 表名;
//去除重复记录
select distinct 字段列表 from 表名;

条件查询

select 字段列表 from 表名 where 条件列表;
比较运算符功能
>大于
>=大于等于
<小于
<=小于等于
=等于
<>或!=不等于
between…and…在某个范围之内(含最小/最大值)
in(…)在in之后的列表中的值,多选一
like 占位符模糊匹配(_匹配单个字符,%匹配多个字符)
is null是null
逻辑运算符功能
and或&&并且(多个条件同时成立)
or 或
not 或!非.不是
查询示例
//查询名为张三的用户,从tb_user表中
select * from tb_user where name='张三';
//查询id小于等于5的用户,从tb_user表中
select * from tb_user where id<=5;
//查询没有分配职位的用户,从tb_user表中
select * from tb_user where job is null;
//查询有职位的用户,从tb_user表中
select * from tb_user where job is not null;
//查询用户密码不是'123456'的用户,从tb_user表中
select * from tb_user where password !='123456';
//效果同上
select * from tb_user where password <>'123456';
//查询用户入职日期从2021-01-02到2023-01-01的用户,从tb_user表中
select * from tb_user where join_time >=2021-01-01 and join_time <=2023-01-01;
//效果同上
select * from tb_user where join_time between 2021-01-01 and 2023-01-01;
//查询用户入职日期从2021-01-02到2023-01-01的用户,并且性别为女的,从tb_user表中
select * from tb_user where join_time >=2021-01-01 and join_time <=2023-01-01 and gender=1;
//效果同上
select * from tb_user where join_time between 2021-01-01 and 2023-01-01 and gender=1;
//效果同上
select * from tb_user where join_time between 2021-01-01 and 2023-01-01 && gender=1;
//查询职位是2,3,4的用户,从tb_user表中
select * from tb_user where job=2 or job =3 or job =4;
//效果同上
select * from tb_user where job in(2,3,4);
//查询姓名为两个字的用户,从tb_user表中
select * from tb_user where name like '__';
//查询姓名姓张的用户,从tb_user表中
select * from tb_user where name like '张%';

分组查询

学习分组查询前,需要先了解聚合函数

聚合函数
  • 介绍: 将一列数据作为一个整体,进行纵向计算
  • 语法: select 聚合函数(字段列表) from 表名;
函数功能
count统计数量
max最大值
min最小值
avg求平均值
sum求和
示例
//统计用户数量,从tb_user表中(不对null值字段进行统计)
select count(字段1)  from tb_user;
//效果同上
select count(*)  from tb_user;
//统计入职最早的用户,从tb_user表中
select min(join_time) from tb_user;
//统计入职最晚的用户,从tb_user表中
select max(join_time) from tb_user;
//统计用户id的平均值,从tb_user表中
select avg(id) from tb_user;
//统计用户id的和,从tb_user表中
select sum(id) from tb_user;
分组查询
//分组查询语法([ ]代表是可选项)
select 字段列表 from 表名  [where 条件] group by 分组字段名 [having 分组后过滤条件];
//根据性别分组,分别统计各自的数量,从tb_user表中
//(分组查询的返回字段有两类,一个是分组字段,一个是聚合字段)
select gender,count(*) from tb_user group by  gender;
//先查询入职日期在'2021-01-01'(包含)以前的用户,并对结果进行职位分组,获取员工数量大于等于2的职位
select job,count(*) from tb_user where join_time <= '2021-01-01' group by job having count(*) >=2;

排序查询

排序方式有两种

  • DESC 降序
  • ASC 升序(默认值)
select 字段列表 from 表名 [where 条件] [group by 分组字段] order by 字段1 排序方式1, 字段2 排序方式2

示例代码

//对入职时间升序排序查询(asc可省略)
select * from tb_user order by join_time asc;
//对入职时间降序排序查询
select * from tb_user order by join_time desc;
//对入职时间升序排序查询(asc可省略),如果时间相同的,根据更新时间降序排序select * from tb_user order by join_time asc, update_time desc;

分页查询

select 字段列表  from 表名 limit 起始索引,查询记录数;
示例代码
//从起始数据0开始查询,每页展示五条记录
select * from tb_user limit 0,5;
//查询第一页的数据,每页展示五条记录
select * from tb_user limit 0,5;
//查询第二页的数据,每页展示五条记录
select * from tb_user limit 1*5,5;
//查询第三页的数据,每页展示五条记录
select * from tb_user limit 2*5,5;
//根据姓名,性别,入职时间范围,分页查询
select * from tb_user where name like '%张%' and gender='男' and join_time between '2021-01-01' and '2023-01-01' limit 0,5;

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

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

相关文章

HJ61 放苹果(递归,苹果多的情况+盘子多的情况)

当苹果数 < 盘子数&#xff0c;有空盘&#xff0c;则忽略一个盘子&#xff0c;在n-1个放苹果&#xff0c;一直递推到n1&#xff0c;有一种摆法苹果数 > 盘子数&#xff0c;可以看作没有空盘。则可以选择忽略一个盘子&#xff0c;如上边做法。还可以选择每个盘子放一个苹果…

react ant design 通过函数弹出 modal窗口

在React Ant Design中&#xff0c;可以通过调用Modal组件的方法来动态弹出和关闭Modal窗口。具体步骤如下&#xff1a; 1、首先&#xff0c;在组件中引入Modal组件&#xff1a; import { Modal } from antd;2、在组件中定义一个函数来弹出Modal窗口&#xff1a; const showM…

GlusterFS分布式存储

目录 前言 一、GlusterFS分布式存储概述 1、GFS概念 2、GFS特点 3、GFS术语 4、GFS构成 5、GFS工作流程 6、后端存储如何定位文件 7、GlusterFs的卷类型 7.1 Distributed Volume&#xff08;分布式卷&#xff09; 7.2 Striped Volume&#xff08;条带卷&#xff09…

Pgsql怎样找到表中某个字段值重复的记录并删除冗余记录,只保留一条

背景 今天发现某个黄页爬取的数据有部分重复了&#xff0c;原本我用的公司详情页的url进行md5来作为主键做upsert入&#xff0c;但后面在核验数据时发现有些详情url虽是同一间公司的&#xff0c;但路由上有细微差别导致写入了重复的公司数据&#xff0c;所以要想办法清理掉重复…

线性变换在人工智能领域的深度实践与应用探索

线性变换&#xff0c;作为数学中的一种基本工具&#xff0c;在人工智能领域中发挥着举足轻重的作用。其强大的表示能力和灵活的运算特性使得线性变换成为机器学习、深度学习等多个子领域的核心组成部分。本文将详细探讨线性变换在人工智能领域中的实践应用&#xff0c;旨在揭示…

redis分布式锁介绍及代码示例

Redis 分布式锁是一种利用 Redis 实现的分布式系统中的锁机制&#xff0c;用于在分布式环境下控制多个客户端对共享资源的访问。它通过 Redis 的原子性操作来确保在分布式系统中的不同节点上&#xff0c;同一时刻只有一个客户端能够获取到锁&#xff0c;从而保证了对共享资源的…

自动化测试selenium

目录 什么是自动化测试 什么是selenium selenium工作原理 selenium环境搭建 1.查看chrome浏览器版本 2.下载chrome浏览器驱动 3.配置系统环境变量PATH 4.验证环境是否搭建成功 selenium相关API 1.定位元素 CSS选择器定位 xpath定位元素 标签定位元素 2.操作测试对…

2024年华为OD机试真题-孙悟空吃蟠桃-Python-OD统一考试(C卷)

题目描述: 孙悟空爱吃蟠桃,有一天趁着蟠桃园守卫不在来偷吃。已知蟠桃园有N颗桃树,每颗树上都有桃子,守卫将在H小时后回来。 孙悟空可以决定他吃蟠桃的速度K(个/小时),每个小时选一颗桃树,并从树上吃掉K个,如果树上的桃子少于K个,则全部吃掉,并且这一小时剩余的时间…

novnc本地文件读取和写入权限

在使用NoVNC&#xff08;一种基于Web的VNC客户端&#xff09;时&#xff0c;出于安全考虑&#xff0c;通常不允许直接从客户端访问或修改服务器上的文件系统。如果你需要在NoVNC中实现文件的读写&#xff0c;你可能需要使用一些特殊的配置或者服务器端的支持。 例如&#xff0…

浏览器工作原理与实践--渐进式网页应用(PWA):它究竟解决了Web应用的哪些问题

在专栏开篇词中&#xff0c;我们提到过浏览器的三大进化路线&#xff1a; 第一个是应用程序Web化&#xff1b; 第二个是Web应用移动化&#xff1b; 第三个是Web操作系统化&#xff1b; 其中&#xff0c;第二个Web应用移动化是Google梦寐以求而又一直在发力的一件事&#xf…

【免费SSL】免费一年的SSL证书

一、SSL证书行业政策 目前市面上绝大多数的免费SSL证书有效期都在3个月左右&#xff0c;而不是一年。例如&#xff0c;腾讯云在2024年4月后不再提供有效期为一年的免费证书&#xff0c;改为提供有效期为3个月的免费证书。同样&#xff0c;阿里云在2023年11月后也不再提供有效期…

javaScript常见对象方法总结

1&#xff0c;object.assign() 用于合并对象的属性。它可以将一个或多个源对象的属性复制到目标对象中&#xff0c;实现属性的合并。 语法 Object.assign(target, ...sources); 1,target&#xff1a;目标对象&#xff0c;将属性复制到该对象中。 2,sources&#xff1a;一个…

51单片机学习笔记16 小型直流电机和五线四相电机控制

51单片机学习笔记16 小型直流电机和五线四相电机控制 一、电机分类二、小型直流电机控制1. 简介2. 驱动芯片ULN2003D3. 代码实现dc_motor_utils.cmain.c 三、五线四相步进电机控制1. 步进电机工作原理2. 构造3. 极性区分4. 驱动方式5. 28BYJ-48步进电机&#xff08;1&#xff0…

3D可视化技术亮相高铁站,引领智慧出行新潮流

在科技飞速发展的今天&#xff0c;我们的生活正经历着前所未有的变革。高铁站作为现代交通的重要枢纽&#xff0c;也在不断地创新和进步。 3D可视化技术通过三维立体的方式&#xff0c;将高铁站内部和外部的结构、设施、流线等以更加直观、生动的形式呈现出来。乘客们只需通过手…

幸运的彩票

题目描述 彩票的号码有 6 位数字&#xff0c;若一张彩票的前 3 位上的数之和等于后 3 位上的数之和&#xff0c;则称这张彩票是幸运的。本题就请你判断给定的彩票是不是幸运的。 输入格式 输入在第一行中给出一个正整数 N&#xff08;≤ 100&#xff09;。随后 N 行&#xff0…

Docker容器嵌入式开发:MySQL表的外键约束及其解决方法

本文内容涵盖了使用MySQL创建数据库和表、添加数据、处理字符集错误、解决外键约束问题以及使用SQL查询数据的过程。通过创建表、插入数据和调整字符集等操作&#xff0c;成功解决了数据库表中的字符集问题&#xff0c;并使用INSERT语句向各个表中添加了示例数据。同时&#xf…

MySQL - MySQL的RR隔离级别是如何基于ReadView机制实现的?

RR级别下,这个事务读取一条数据,无论读多少次,都是一个值,别的事务修改数据之后,哪怕提交了,你也是看不到人家修改的值的,这就避免了不可重复读的问题。 同时如果别的事务插入了一些新的数据,你也是读不到的,这样就可以避免幻读问题。这到底是如何实现的呢? 首先我…

《深入Linux内核架构》第1章 简洁和概述

目录 1.1 内核的任务 1.2 实现策略 1.3 内核的组成部分 ​1.3.1 进程、进程切换、调度 1.3.2 UNIX 进程 1.3.3 地址空间和特权级别 1.3.4 页表 1.3.5 物理内存的分配 1.3.6 计时 1.3.7 系统调用 1.3.8 设备驱动程序 1.3.9 网络 1.3.10 文件系统 1.3.11 模块和热插…

LangChain - Output Parsers

文章目录 一、输出解析器 (Output Parsers)快速入门 二、列表解析器三、datetime 日期时间解析器四、枚举解析器五、自动修复解析器六、Pydantic&#xff08;JSON&#xff09;解析器七、重试解析器八、结构化输出解析器 structured 转载改编自&#xff1a; https://python.lang…

AIGC实战——StyleGAN(Style-Based Generative Adversarial Network)

AIGC实战——StyleGAN 0. 前言1. StyleGAN1.1 映射网络1.2 合成网络1.3 自适应实例归一化层1.4 风格混合1.5 随机变化 2. StyleGAN 生成样本3. StyleGAN23.1 权重调制与解调3.2 路径长度正则化3.3 非渐进式增长 4. StyleGAN2 生成样本小结系列链接 0. 前言 StyleGAN (Style-Ba…