首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >MySQL基本查询

MySQL基本查询

作者头像
敲上瘾
发布2025-11-15 09:34:22
发布2025-11-15 09:34:22
940
举报

Create

插入

语法: INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ... value_list: value, [, value] ...

注意:MySQL语法不区分单双引号,不区分大小写。

忽略 [(column [, column] ...)]:全列插入。

()values():像一个扁担,左边和右边对应。其中前一个括号指明要插入的列,后一个括号填写对应的元素。如果前一个括号忽略则默认为全列插入。

可同时插入多条,即()values(),(),()......

into也可省略。

示例:

代码语言:javascript
复制
mysql> create table test8(
    -> id int primary key auto_increment,
    -> name varchar(20)
    -> );
Query OK, 0 rows affected (0.02 sec)

mysql> insert into test8 (id,name)values(20250031,'张三');
Query OK, 1 row affected (0.01 sec)

mysql> insert test8 (name)values('李四');
Query OK, 1 row affected (0.01 sec)

mysql> insert test8 values(20250045,'王五');
Query OK, 1 row affected (0.00 sec)

mysql> insert test8 (name)values('赵六'),('田七');
Query OK, 2 rows affected (0.01 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> 

替换

语法

INSERT ... ON DUPLICATE KEY UPDATE column = value [, column = value] ...

通常用来解决由于主键或者唯一键对应的值已经存在而导致插入失败的问题。即对数据进行更新。

如下我们插入已存在主键的值:

代码语言:javascript
复制
mysql> insert into values(20250031,'李华');
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'values(20250031,'李华')' at line 1

mysql> insert into test8 values(20250031,'李华') on duplicate key update name='李华';
Query OK, 2 rows affected (0.00 sec)

mysql> 

方法二:

代码语言:javascript
复制
mysql> replace into test8 values(20250031,'小明');
Query OK, 2 rows affected (0.00 sec)

Retrieve(读取)

select(确定列)

语法:

SELECT column1, column2, ... FROM table_name [WHERE condition] [GROUP BY column_name] [HAVING condition] [ORDER BY column_name [ASC|DESC]] [LIMIT offset, count];

全列查询:select * from 表名(建议不要使用)。

去重:select distinct 列名 form 表名

案例:

显示时对列重命名:列名 as 新列名。as可省略。

其次可对列进行运算然后显示,如下:

where条件(确定行)

语法:

SELECT 列名1, 列名2, ... FROM 表名 WHERE 条件表达式;

注意:NULL和0不一样。

NULL=NULL结果还是NULL,因为NULL不可以用=比较,而是用<=>。通常用is null,is not null。

示例:

英语不及格的同学及英语成绩

代码语言:javascript
复制
mysql> select name,english from exam_result where english<60;

语文成绩在[80,90]分的同学及语文成绩

代码语言:javascript
复制
select name,chinese from exam_result where chinese>=80 and chinesese<=90;

或:

代码语言:javascript
复制
mysql> select name,chinese from exam_result where chinese between 80 and 90;

数学成绩是58或59或98或99分的同学及数学成绩

代码语言:javascript
复制
mysql> select name,math from exam_result where math=58 or math=59 or math=98 or math=99;

代码语言:javascript
复制
mysql> select name,math from exam_result where math in (58,59,98,99);

姓孙的同学 及 孙某同学

代码语言:javascript
复制
mysql> select name from exam_result where name like '孙%';
代码语言:javascript
复制
mysql> select name from exam_result where name like '孙_';

语文成绩好于英语成绩的同学

代码语言:javascript
复制
mysql> select name,chinese,english from exam_result where chinese > english;

总分在200分以下的同学

代码语言:javascript
复制
mysql> select name,chinese+math+english 总分 from exam_result where chiinese+math+english<200;

注意:语句的执行顺序是从右往左,所以不能使用‘总分’这个词来计算,而where不支持把列重命名。执行顺序:1.from 2.where 3.select

语文成绩>80并且不姓孙的同学

代码语言:javascript
复制
mysql> select name,chinese from exam_result where chinese>80 and not(name like '孙%');

孙某同学,否则要求总成绩>200并且语文成绩<数学并且英语成绩>80

代码语言:javascript
复制
mysql> select name,chinese,math,english,chinese+math+english 总分
    -> from exam_result
    -> where (name like '孙_') or (chinese+math+english>200 and chinesee<math and english>80);

null查询

order by语句

语法:

-- ASC 为升序(从小到大) -- DESC 为降序(从大到小) -- 默认为 ASC SELECT ... FROM table_name [WHERE ...] ORDER BY column [ASC|DESC], [...];

注意:没有带asc或desc的排序查询,返回的顺序是未定义的。

同学及数学成绩,按数学成绩升序显示:

代码语言:javascript
复制
mysql> select name,math from exam_result order by math asc;

注意:NULL在排序时原则上比任何值都小。

查询同学各门成绩,依次按数学降序,英语升序,语文升序的方式显示:

代码语言:javascript
复制
mysql> select name,math,english,chinese
    -> from exam_result
    -> order by math desc,english desc,chinese asc;

查询同学及总分,从高到低

代码语言:javascript
复制
mysql> select name,math+chinese+english as total 
    -> from exam_result
    -> order by total desc;

这里order by后总分能用别名是因为,order by是后执行的。

查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示:

代码语言:javascript
复制
mysql> select name,math
    -> from exam_result
    -> where name like '孙%' or name like '曹%'
    -> order by math desc;

limit(分页)

语法:

-- 起始下标为 0 -- 从 s 开始,筛选 n 条结果 SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n -- 从 0 开始,筛选 n 条结果 SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n; ; -- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用 SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

建议:对未知表进行查询时,最好加一条 LIMIT 1,避免因为表中数据过大,查询全表数据导致数据库卡死。 按 id 进行分页,每页 3 条记录,分别显示 第 1、2、3 页

从开头连续读取3行

代码语言:javascript
复制
mysql> select*from exam_result limit 3;

从第2行开始往下读取4行:

代码语言:javascript
复制
mysql> select*from exam_result limit 2,4;

Update(更新)

语法:

UPDATE table_name SET column = expr [, column = expr ...] [WHERE ...] [ORDER BY ...] [LIMIT ...]

用于对查询到的值进行更新。

将孙悟空同学的数学成绩改为80分

代码语言:javascript
复制
mysql> update exam_result set math=80 where name='孙悟空';

将曹孟德同学的数学成绩改为60分,语文成绩改为70分

代码语言:javascript
复制
mysql> update exam_result set math=60,chinese=70 where name='曹孟德';

将总成绩倒数前三的3位同学的数学成绩加30分

代码语言:javascript
复制
mysql> update exam_result set math=math+30
    -> order by math+chinese+english asc
    -> limit 3;

将所有同学的语文成绩更新为原来的2倍。

Delete(删除)

语法:

DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]

删除孙悟空同学的考试成绩

代码语言:javascript
复制
mysql> delete from exam_result where name='孙悟空';

删除整张表数据:delete from 表名。

截断表

语法:

TRUNCATE [TABLE] table_name

注意:这个操作慎用

  1. 只能对整表操作,不能像 DELETE 一样针对部分数据操作。
  2. 实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,所以无法回滚。
  3. 会重置 AUTO_INCREMENT 项。delete不会重置AUTO_INCREMENT。

去重表数据

语法:

INSERT INTO table_name [(column [, column ...])] SELECT...

比如我们有一个表:duplicate_table,要对它去重,

首先创建一个相同的表结构

代码语言:javascript
复制
mysql> create table no_duplicate_table like duplicate_table;
代码语言:javascript
复制
mysql> insert into noduplicate_table select distinct * from duplicate_table;

然后把duplicate_table删除,no_duplicate_table重命名为 duplicate_table。

这样的好处在于把一切都准备就绪,然后统一放入、更新、生效等。

聚合统计

聚合函数

函数

说明

COUNT([DISTINCT] expr)

返回查询到的数据的 数量

SUM([DISTINCT] expr)

返回查询到的数据的 总和,不是数字没有意义

AVG([DISTINCT] expr)

返回查询到的数据的 平均值,不是数字没有意义

MAX([DISTINCT] expr)

返回查询到的数据的 最大值,不是数字没有意义

MIN([DISTINCT] expr)

返回查询到的数据的 最小值,不是数字没有意义

测试:

统计班里一共多少学生

代码语言:javascript
复制
mysql> select count(*) from exam_result;

或:

代码语言:javascript
复制
mysql> select count(name) from exam_result;

统计数学成绩总分

代码语言:javascript
复制
mysql> select sum(math) from exam_result;

统计平均总分

代码语言:javascript
复制
mysql> select sum(math+chinese+english)/count(name) from exam_result;

或:

代码语言:javascript
复制
mysql> select avg(math+chinese+english) from exam_result;

返回英语最高分

代码语言:javascript
复制
mysql> select max(english) from exam_result;

返回>70分以上的数学最低分

代码语言:javascript
复制
mysql> select min(math) from exam_result where math>70;

group by句子的使用

语法:

select column1, column2, .. from table group by column;

分组:把一组按条件拆分成多个组 。然后在各自组能做统计。在逻辑上相当于拆分成多张"表"。

测试:

显示每个部门的平均工资和最高工资

代码语言:javascript
复制
select deptno,avg(sal),max(sal) from emp group by deptno;

显示每个部门的每种岗位的平均工资和最低工资

代码语言:javascript
复制
select avg(sal),min(sal),job, deptno from emp group by deptno, job;

显示平均工资低于2000的部门和它的平均工资。having和group by配合使用,对group by结果进行过滤

代码语言:javascript
复制
select avg(sal) as myavg from emp group by deptno having myavg<2000;

having与where的使用方法相同,但它们使用在不同的场景。

  • where:对具体任意列进行统计筛选。
  • having:对分组聚合后的结果进行条件筛选。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-05-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Create
    • 插入
    • 替换
  • Retrieve(读取)
    • select(确定列)
    • where条件(确定行)
    • order by语句
    • limit(分页)
  • Update(更新)
  • Delete(删除)
    • 截断表
    • 去重表数据
  • 聚合统计
    • 聚合函数
    • group by句子的使用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档