MYSQL中表的基本查询

表的增删改查

Create(创建)

单行插入

使用insert into可以对表中任意一行进行插入

如果要省略某一列值,则需要写明每一列值对应的name

多行插入

如果要进行多行插入,则每一个值需要用" , "隔开

如果要指定列插入(省略某些行),也需要写明每一列对应的name

插入已有数据(自动更新)

由于主键或唯一键对应的值可能已经存在,会导致插入失败

可以选择insert ... on duplicate key update

这样,如果出现了冲突(数据已经存在),就会就会对已有数据进行更新

替换

主键或唯一键如果没有冲突则直接插入

如果存在插入,则删除后再插入

使用replace into可以进行替换插入

ReTrieve(读取)

全列查询

select * from name 可以进行全列查询

但是通常不会这样,因为数据库中数据通常很多

查询字段为表达式

使用select 字段名/表达式 from 表名

可以单独查询某些数据

结果去重

使用select distinct ... 可以去除重复数据

WHERE条件

where是一种筛选语句

案例:

结果排序

ASC是升序

DESC是降序

使用 ORDER BY 可以进行排序

NULL参与排序,排序数值默认比所有数据都要小

Update

使用 update ... set ... 可以对查询到的结果进行列值更新

Delete

使用delete from tablename ... 可以删除数据

截断表

使用truncate tablename可以将表阶段

实际上不对数据进行操作,所以比delete更快

但是删除数据后无法回滚

去重

去重需要建立一张新表,将去重的数据插入新表中,再将新表的名字改成旧表

就实现了表的去重

聚合函数

mysql中存在聚合函数可以对查询到的结果返回

聚合函数如下:

使用distinct可以对去重结果进行聚合

分组聚合

使用group by可以对指定列进行分组查询

分组的目的是为了聚合统计

分组指定列名,实际是用该列的不同的行数据来进行分组的

having可以和group可以搭配使用,对分组进行筛选

where是对具体的任意列进行条件筛选

而having是对分组聚合后的结果进行条件筛选

相关推荐
Database_Cool_2 小时前
Doris vs 阿里云 AnalyticDB MySQL vs ClickHouse:3 大 OLAP 产品 2026 深度对比
数据库·mysql·阿里云
金融支付架构实战指南2 小时前
秒杀&支付订单异步落地|Redis Stream 可靠队列实战
数据库·redis·缓存·stream·秒杀
小二·3 小时前
AI Agent 数据库运维实战
运维·数据库·人工智能
曹牧3 小时前
Oracle:子查询返回多行
数据库·oracle
计算机安禾3 小时前
【数据库系统原理】第10篇:SQL高级查询机制:嵌套子查询与相关子查询的执行窥探
大数据·数据库·sql
星马梦缘3 小时前
数据库 第十三章 未完结版本
java·网络·数据库
曹牧3 小时前
‌Oracle CTE(公共表表达式)
数据库·oracle
山峰哥3 小时前
VB事件驱动编程实战:从零到一搭建完整管理系统
前端·数据库·性能优化·深度优先·vb
ULIi096kr3 小时前
查看 MySQL 数据库容量大小:完整实用查询方法(含表数据、磁盘占用统计)
数据库·mysql