MySQL语句--查询语句大全(有示例)

原文网址:MySQL语句--查询语句大全(有示例)_IT利刃出鞘的博客-CSDN博客

简介

本文介绍MySQL查询语法(命令)的使用。包括:基本查询、运算条件、排序、分页、分组、联结、组合、子查询、distinct等。

SQL查询语句官网:MySQL :: MySQL 8.0 Reference Manual :: 13.2.10 SELECT Statement

基本查询

操作

命令

示例/说明

查询所有列

SELECT * FROM 表名

SELECT * FROM table_name;

查询指定列

SELECT 列1,列2,...FROM 表名;

SELECT id,name FROM table_name;

使用 AS  给字段起别名

SELECT id AS  序号, name AS  名字, gender AS  性别 FROM students;

AS 不写也可以,跟写AS 一样效果。

通过 AS  给表起别名

SELECT col1,col2 FROM table_name AS  xxx

SELECT s.id,s.name,t.gender FROM students AS  s, teachers AS  t;

SELECT子句必须遵循的顺序(从左到右对应从上到下)

子句说明是否必须使用
SELECT要返回的列或表达式
FROM从中检索数据的表仅在从表选择数据时使用
WHERE行级过滤
GROUP BY分组说明仅在按组计算聚集时使用
HAVING组级过滤
ORDER BY输出排序顺序
LIMIT要检索的行数

运算条件

WHERE 后面支持多种运算符,进行条件的处理

比较运算符、逻辑运算符、模糊查询、范围查询、空判断

运算符

详情

示例

比较

等于: =

大于: >

大于等于: >=

小于: <

小于等于: <=

不等于: != 或 <>

例:查询编号大于3的学生:          SELECT * FROM students WHERE id > 3;

例:查询编号不大于4的学生:       SELECT * FROM students WHERE id <= 4;

例:查询姓名不是“黄蓉”的学生:   SELECT * FROM students WHERE name != '黄蓉';

例:查询没被删除的学生:            SELECT * FROM students WHERE is_delete=0;

逻辑

AND,OR,NOT

//sql 会首先执行 AND 条件,再执行 OR 语句。除非加括号

例:查询编号大于3的女同学:               SELECT * FROM students WHERE id > 3 AND gender=0;

例:查询编号小于4或没被删除的学生: SELECT * FROM students WHERE id < 4 OR is_delete=0;

例:查询编号小于4,或大于10而且没被删除的学生: SELECT * FROM students WHERE id < 4 or id > 10 AND is_delete=0;

例:查询编号小于4或大于10,而且没被删除的学生: SELECT * FROM students WHERE (id < 4 or id > 10) AND is_delete=0;

模糊查询

LIKE

% 任意多个任意字符

_ 一个任意字符

例:查询姓黄的学生:                           SELECT * FROM students WHERE name LIKE '黄%';

例:查询姓黄并且“名”是一个字的学生:SELECT * FROM students WHERE name LIKE '黄_';

例:查询姓黄或叫靖的学生:SELECT * FROM students WHERE name LIKE '黄%' OR name LIKE '%靖';

范围查询

分为 连续/非连续 范围查询

IN:非连续

BETWEEN … AND …:连续

    (包含端点)

例:查询编号是1或3或8的学生: SELECT * FROM students WHERE id in(1,3,8);

例:查询编号为3至8的学生:       SELECT * FROM students WHERE id BETWEEN 3 AND 8;

例:查询编号是3至8的男生:    SELECT * FROM students WHERE (id BETWEEN 3 AND 8) AND gender=1;

空判断

判断为空/非空

注意: null与’’是不同的

例:查询没有填写身高的学生:SELECT * FROM students WHERE height IS NULL;

例:查询填写了身高的学生:   SELECT * FROM students WHERE height IS NOT NULL;

例:查询填写了身高的男生:   SELECT * FROM students WHERE height IS NOT NULL AND gender=1;

优先级

优先级由高到低的顺序为:小括号 > NOT > 比较运算符 > 逻辑运算符

AND比OR先运算,如果同时出现并希望先算or,需要结合()使用

排序

排序查询语法

SELECT * FROM 表名 ORDER BY 列1 ASC|DESC[,列2 ASC|DESC,...]

语法说明

  • 将行数据按照列1进行排序,如果某些行 列1 的值相同时,则按照 列2 排序,以此类推
  • asc:从小到大排列,即升序;desc从大到小排序,即降序
  • 默认按照列值从小到大排列(即asc关键字)

示例

  • 查询未删除男生信息,按学号降序
    • SELECT * FROM students WHERE gender=1 and is_delete=0 ORDER BY id desc;
  • 查询未删除学生信息,按名称升序
    • SELECT * FROM students WHERE is_delete=0 ORDER BY name;
  • 显示所有的学生信息,先按照年龄从大–>小排序,当年龄相同时 按照身高从高–>矮排序
    • SELECT * FROM students  ORDER BY age desc,height desc;

分页

上边是文章的部分内容,为便于维护,全文已转移到此网址:MySQL语句-查询语句大全(有示例) - 自学精灵

  • 20
    点赞
  • 144
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT利刃出鞘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值