简单讲解MySQL的高级语句

简单讲解MySQL的高级语句

(一)按关键字排序

1.使用ORDER BY语句来实现排序

2.排序可针对一个或多个字段

3.ASC:升序,默认排序方式

4.DESC:降序

6.ORDER BY的语法结构:select column1,column2… from 库名 order by column1,column2,… asc|desc;
升序:在这里插入图片描述
降序:
在这里插入图片描述
加入条件排序:在这里插入图片描述
在这里插入图片描述

多条件排序:
在这里插入图片描述

(二)对结果进行分组

1.使用GROUP BY语句来实现分组

2.通常结合聚会函数一起使用

3.可以按一个或多个字段对结果进行分组

4.GROUP BY的语法结构:
select column_name,aggregate_function(column_name) from table_name where column_name operator value GROUP BY column_name;

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

(三)限制结果条目

1.只返回SELECT查询结果的第一行或前几行

2.使用LIMIT语句限制条目

3.LIMIT语法结构:select column1,column2,… from table_name [offset,] number;

在这里插入图片描述
第一个数字:位置偏移量是从零开始,第二个数字:返回记录行的最大数目
第三到第五
在这里插入图片描述

(四)设置别名

1.使用AS语句设置别名,关键字AS可省略

2.设置别名时,保证不能与库中其他表或字段名称冲突

3.别名的语法结构:select column_name AS alias_name from table_name;
select column_name(s) from table_name AS alias_name;
as复制:在这里插入图片描述
as统计:
在这里插入图片描述
as别名:
在这里插入图片描述

(五)通配符

1.用于替换字符串中的部分字符

2.通常配合LIKE一起使用,并协同WHERE完成查询

3.常用通配符

​ %表示零个,一个或多个

​ _表示单个字符
在这里插入图片描述
在这里插入图片描述

(六)子查询

1.也称作内查询或者嵌套查询

2.先于主查询被执行,其结果将作为外层主查询的条件

3.在增删改查中都可以使用子查询

4.支持多层嵌套

5.IN语句是用来判断某个值是否在给定的结果集中

在这里插入图片描述

在这里插入图片描述

(七)NULL值

1.表示缺失的值

2.与数字0或者空白(spaces)是不同的

3.使用IS NULL或IS NOT NULL进行判断

4.NULL值和空值的区别:(1)空值长度为0,不占空间;
(2)NULL值的长度为NULL,占用空间
(3)IS NULL无法判断空值
(4)空值使用"=“或者”<>"来处理
(5)COUNT () 计算时,NULL会忽略,空值会加入计算

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

在这里插入图片描述

(八)正则表达式

1.根据指定的匹配模式匹配记录中符合要求的特殊字符

2.使用REGEXP关键字指定匹配模式

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

(九)运算符

(1)算数运算符

(1.1)用于对记录中的字段值进行运算
MySQL 的运算符共有四种,分别是:算术运算符、比较运算符、逻辑运算符和位运算符
在这里插入图片描述

(1.2)以select命令来实现最基础的加减乘除运算,具体操作如下所示:

在这里插入图片描述
(1.3)整数相除,出来的结果是浮点型的。
在除法运算和求余数运算中,除数不能为 0,若除数是 0,返回的结果则为 NULL。
需要注意的是,如果有多个运算符,按照先乘除后加减的优先级进行运算

在这里插入图片描述

(1.4)某些字符串类型的字段存储的数字型字符串,这些字段在进行算术运算时将会被自动转换为数字的值。如果字符串的开始部分是数字,在转换时将被转换为这个数字。如果是既包含字符又包含数字得的混合字符串,无法转换为数字时,将被转换为 0。

在这里插入图片描述

(2) 比较运算符

在这里插入图片描述
(2-1) 等于运算符
用来判断数字、字符串和表达式是否相等的,如果相等则返回 1,如果不相等则返回 0。其中字符的比较是根据 ASCII 码来判断的。
ASCII码表转换:
0-48,1-49,…9-57
A-65,B-66
a-97,b-98
比较规则:
如果两者都是整数,则按照整数值进行比较。
如果一个整数一个字符串,则会自动将字符串转换为数字,再进行比较。
如果两者都是字符串,则按照字符串进行比较。
如果两者中至少有一个值是 NULL,则比较的结果是 NULL

在这里插入图片描述
(2-2) 不等于运算符
不等于号有两种写法,分别是<>或者!=,用于针对数字、字符串和表达式不相等的比较。如果不相等则返回 1,如果相等则返回 0。
需要注意的是不等于运算符不能用于判断 NULL。

在这里插入图片描述
(2-3) 大于、大于等于、小于、小于等于运算符
注意:都不能用于判断NULL。
在这里插入图片描述
(2-4) IS NULL、IS NOT NULL
IS NULL 判断一个值是否为 NULL,如果为 NULL 返回 1,否则返回 0。
IS NOT NULL 判断一个值是否不为 NULL,如果不为 NULL 返回 1,否则返回 0。
在这里插入图片描述
(2-5) between and
用于判断一个值是否落在某两个值之间
例如,判断某数字是否在另外两个数字之间,也可以判断某英文字母是否在另外两个字母之间
在这里插入图片描述
(2-6) least、greatest
LEAST:当有两个或者多个参数时,返回其中的最小值。如果其中一个值为 NULL,则返回结果就为 NULL。
GREATEST:当有两个或者多个参数时,返回其中的最大值。如果其中一个值为 NULL, 则返回结果就为 NULL。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(2-7) in、not in
IN 判断一个值是否在对应的列表中,如果是返回 1,否则返回 0。
NOT IN 判断一个值是否不在对应的列表中,如果不是返回 1,否则返回 0。
在这里插入图片描述
(2-8) like、not like
LIKE 用来匹配字符串,如果匹配成功则返回 1,反之返回 0;NOT LIKE 正好跟 LIKE 相反。
LIKE 支持两种通配符:’%’ 用于匹配任意数目的字符,而’_’只能匹配一个字符。
在这里插入图片描述

(3)逻辑运算符

在这里插入图片描述
(1)逻辑非
逻辑非将跟在它后面的逻辑测试取反,把真变为假,把假变为真。
如果 NOT 后面的操作数为 0 时,所得值为 1;如果操作数为非 0 时,所得值为 0;如果操作数为 NULL 时,所得值为 NULL。
注意:非0值都是1
在这里插入图片描述
(2)逻辑与
如果所有值都是真返回 1,否则返回 0。
在这里插入图片描述
(3)逻辑或(最好用or)
逻辑或表示包含的操作数,任意一个为非零值并且不是 NULL 值时,返回 1,否则返回0。
在这里插入图片描述
运算总结:
and运算,只要碰到0就是0,(非0和null是null)
or运算,只要碰到非0值就是1,(0和null是null)
异或运算,只要碰到null都是null

(四)位运算符

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

(十)连接查询

MySQL的连接查询,通常都是将来自两个或多个表的行结合起来,基于这些表之间的共同字段,进行数据的拼接。首先,要确定一个主表作为结果集,然后将其他表的行有选择性的连接到选定的主表结果集上。使用较多的连接查询包括:内连接,左连接和右连接。

外连接:分为左连接和右连接。

左外连接就是以左表为准,去匹配右表,左表有多少条数据,结果就是多少条数据。左表有的数据正常显示,右表没有的数据就用NULL显示。

(10.1)内连接

在这里插入图片描述

(10.2)左连接

在这里插入图片描述

(10.3)右连接

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值