MySQL高级语句(下)

目录

一、子查询,连接表格

 二、EXISTS------用来测试内查询有没有产生任何结果

 三、连接查询

 (1)inner join(等值相连)

 (2)left join(左联接)

 四、CREATE VIEW 视图

 五、排序

 1、算排名

 2、算累积总计

 六、空值(NULL) 和 无值(’’) 的区别

 七、MySQL之正则表达式

 八、存储过程

1、存储过程的概念

2、存储过程的优点

3、创建存储过程

4、调用存储过程

 5、查看存储过程

 6、存储过程的参数

 总结


接着上高级语句继续说

一、子查询,连接表格

  • 子WHERE子句或HAVING子句中插入另一个SQL语句
语法:
#外查询
SELECT "栏位1" FROM "表格1" WHERE "栏位2" [比较运算符]
#内查询
(SELECT "栏位1" FROM "表格2" WHERE "条件");
#可以是符号的运算符,例如:=、>、<、>=、<= ;也可以是文字的运算符,例如 LIKE、IN、BETWEEN

例:

select sum(sales) from info where place_name in (select place_name from destination where region = 'southwest');
#下面这个句子就是上面的简化版
select sum(sales) from info where place_name in('chengdu','kunming');

在这里插入图片描述

 例2

select sum(a.sales) from info a where a.place_name in(select place_name from destination b where b.place_name = a.place_name);

在这里插入图片描述

 在这里插入图片描述

 二、EXISTS------用来测试内查询有没有产生任何结果

  • 类似布尔值是否为真
  • 如果有的话,系统就会执行外查询中的SQL语句。若是没有的话,那整个 SQL 语句就不会产生任何结果。
语法:SELECT "栏位1" FROM "表格1" WHERE EXISTS (SELECT * FROM "表格2" WHERE "条件");
例:
select sum(sales) from info where exists (select * from destination where region = 'southwest');

在这里插入图片描述

 三、连接查询

在这里插入图片描述

 (1)inner join(等值相连)

SELECT * FROM 表1 表1的别名 INNER JOIN 表2 表2的别名 on 表1别名.栏位 = 表2别名.栏位;  #这里的栏位名称相同
例:
select * from destination a inner join info b on a.place_name = b.place_name;

在这里插入图片描述

 (2)left join(左联接)

  • 返回包括左表中的所有记录和右表中联结字段相等的记录
SELECT * FROM 表1 表1的别名 LEFT JOIN 表2 表2的别名 on 表1别名.栏位 = 表2别名.栏位;  #这里的栏位名称相同
例:
select * from destination a left join info b on a.place_name = b.place_name;

在这里插入图片描述

 四、CREATE VIEW 视图

  • 视图跟表格的不同是,表格中有实际储存资料,而视图是建立在表格之上的一个架构,它本身并不实际储存资料。
  • 临时表在用户退出或同数据库的连接断开后就自动消失了,而视图不会消失。
  • 视图不含有数据,只存储它的定义,它的用途一般可以简化复杂的查询。比如你要对几个表进行连接查询,而且还要进行统计排序等操作,写SQL语句会很麻烦的,用视图将几个表联结起来,然后对这个视图进行查询操作,就和对一个表查询一样,很方便。
    语法:CREATE VIEW "视图表名" AS "SELECT 语句";
    例:
    create view new_info as select a.region region,a.place_name place_name,b.sales sales from destination a inner join info b on a.place_name = b.place_name;
    

    select * from new_info;
    drop view new_info;

在这里插入图片描述

 五、排序

create database school;
use school;
create table class(name varchar(20),scores int(5));
insert into class values ('aa1',80);
insert into class values ('bb2',100);
insert into class values ('cc3',78);
insert into class values ('dd4',94);
insert into class values ('ee5',66);
insert into class values ('ff6',53);
insert into class values ('gg7',77);
select * from class;

在这里插入图片描述

 1、算排名

  • 表格自我连结 (Self Join),然后将结果依序列出,算出每一行之前 (包含那一行本身) 有多少行数
select a1.name, a1.scores,count(a2.scores) rank from class a1,class a2 where a1.scores < a2.scores or (a1.scores = a2.scores and a1.name = a2.name) group by a1.name,a1.scores order by a1.scores desc;
#统计scores栏位的值是比自己本身的值小的以及scores栏位和name栏位都相同的数量,比如ff6为6+1=7

在这里插入图片描述

 2、算累积总计

  • 表格自我连结 (Self Join),然后将结果依序列出,算出每一行之前 (包含那一行本身) 的总合
select A1.*,sum(A2.scores) sum_socores from class A1,class A2 where A1.scores < A2.scores or(A1.scores = A2.scores and A1.name = A2.name) group by A1.name order by A1.scores desc;

在这里插入图片描述

 六、空值(NULL) 和 无值(’’) 的区别

  • 无值的长度为 0,不占用空间的;而 NULL 值的长度是 NULL,是占用空间的。
  • IS NULL 或者 IS NOT NULL,是用来判断字段是不是为 NULL 或者不是 NULL,不能查出是不是无值的。
  • 无值的判断使用=’‘或者<>’'来处理。<> 代表不等于。
  • 在通过 count()指定字段统计有多少行数时,如果遇到 NULL 值会自动忽略掉,遇到无值会加入到记录中进行计算。
    SELECT length(NULL), length(''), length('1');

    在这里插入图片描述

  • 测试 
#建表
create table test(test varchar(20));
insert into test values(' ');
insert into test values('123123');
insert into test values();
insert into test values('1111');
insert into test values('');
select * from test;	

在这里插入图片描述

 

例:
select * from test where test is null;
select * from test where test is not null;
select * from test where test = '';
select * from test where test <> '';
select count(test) from test;

在这里插入图片描述

 七、MySQL之正则表达式

匹配模式			描述									    实例
^ 				匹配文本的开始字符 						‘^bd’ 匹配以 bd 开头的字符串
$ 				匹配文本的结束字符 						‘qn$’ 匹配以 qn 结尾的字符串
. 				匹配任何单个字符							‘s.t’ 匹配任何 s 和 t 之间有一个字符的字符串
* 				匹配零个或多个在它前面的字符 				‘fo*t’ 匹配 t 前面有任意个 o
+ 				匹配前面的字符 1 次或多次					‘hom+’ 匹配以 ho 开头,后面至少一个m 的字符串
字符串 			匹配包含指定的字符串 						‘clo’ 匹配含有 clo 的字符串
p1|p2 			匹配 p1 或 p2 							‘bg|fg’ 匹配 bg 或者 fg
[...] 			匹配字符集合中的任意一个字符 				‘[abc]’ 匹配 a 或者 b 或者 c
[^...] 			匹配不在括号中的任何字符 					‘[^ab]’ 匹配不包含 a 或者 b 的字符串
{n} 			匹配前面的字符串 n 次 					    ‘g{2}’ 匹配含有 2 个 g 的字符串
{n,m}			匹配前面的字符串至少 n 次,至多m 次		    ‘f{1,3}’ 匹配 f 最少 1 次,最多 3 次
语法:SELECT "栏位" FROM "表名" WHERE "栏位" REGEXP {模式};
例:我这里使用上面实验的库
use plane
select * from info where place_name regexp '^b';
select * from info where place_name regexp 'ei|un';

在这里插入图片描述

 八、存储过程

1、存储过程的概念

  • 存储过程是一组为了完成特定功能的SQL语句集合。
  • 存储过程在使用过程中是将常用或者复杂的工作预先使用SQL语句写好并用一个指定的名称存储起来,这个过程经编译和优化后存储在数据库服务器中。当需要使用该存储过程时,只需要调用它即可。存储过程在执行上比传统SQL速度更快、执行效率更高。

2、存储过程的优点

  • 执行一次后,会将生成的二进制代码驻留缓冲区,提高执行效率
  • SQL语句加上控制语句的集合,灵活性高
  • 在服务器端存储,客户端调用时,降低网络负载
  • 可多次重复被调用,可随时修改,不影响客户端调用
  • 可完成所有的数据库操作,也可控制数据库的信息访问权限

3、创建存储过程

格式:
DELIMITER $$							#将语句的结束符号从分号;临时改为两个$$(可以是自定义)
CREATE PROCEDURE xxx()					#创建存储过程,过程名为xxx,不带参数
 BEGIN                                  #过程体以关键字 BEGIN 开始
   sql语句;                             #过程体语句
 END $$								    #过程体以关键字 END 结束
DELIMITER ;                             #将语句的结束符号恢复为分号

4、调用存储过程

CALL 过程名;
例:
call cha_info;

在这里插入图片描述

 5、查看存储过程

SHOW CREATE PROCEDURE [数据库.]存储过程名;		#查看某个存储过程的具体信息

在这里插入图片描述

 在这里插入图片描述

 6、存储过程的参数

  • IN 输入参数:表示调用者向过程传入值(传入值可以是字面量或变量)
  • OUT 输出参数:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
  • INOUT 输入输出参数:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)
delimiter !!
create procedure test1(in inname char(20))
  begin
  select * from info where place_name = inname;
  end !!
delimiter ;

在这里插入图片描述

 总结

数据库语言和命令有相似的地方,语句格式和使用方法需要我们根据实际情况合理运用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值