首页 > 数据库 >MySQL 视图&存储过程&函数

MySQL 视图&存储过程&函数

时间:2023-06-21 23:00:49浏览次数:39  
标签:语句 存储 函数 CREATE 视图 MySQL SELECT

1 视图

1.1 视图的作用

当我们创建一张表的视图后,可以用和表差不多的使用方式来使用视图,比如可以对视图进行select查询操作、过滤或者排序数据等等。同时,也可以联结其它视图或者表,甚至可以添加和更新数据(但一般不会这么做,而且存在诸多限制)。总结起来,视图有以下优点:

  • 重用SQL语句,简化复杂的SQL操作。在编写查询后,可以方便地重用它而不必知道它的基本查询细节。
  • 使用表的组成部分而不是整个表,做到保护数据,给用户授予表的特定部分的访问权限而不是整个表的访问权限。
  • 更改数据格式和表示,视图可返回与底层表的表示和格式不同的数据。

但是,视图也存在一些缺点,因为视图不包含数据,所以每次使用视图时,都必须处理查询执行时所需的任一个检索。如果你用多个联结和过滤创建了复杂的视图或者嵌套了视图,可能会发现性能下降得很厉害。因此,在部署使用了大量视图的应用前,应该进行测试。

关键字 占用物理空间 使用
create table 有,保存了数据 支持增删查改
视图 create view 无,仅保存了sql逻辑 支持增删查改,但是增删改有条件

1.2 视图的简单应用

创建视图

# 查询姓名中包含a字符的员工名、部门名和工种信息
# 创建视图
CREATE VIEW view1
AS
SELECT last_name, department_name, job_title
FROM employees e
JOIN departments d ON e.department_id = d.department_id
JOIN jobs j ON j.job_id  = e.job_id;
# 使用视图
SELECT * FROM view1 WHERE last_name LIKE '%a%';

修改视图

  • 方式一:create or replace view 视图名 as 查询语句;
  • 方式二:alter view 视图名 as 查询语句;
CREATE OR REPLACE VIEW view2
AS
SELECT AVG(salary),job_id FROM employees GROUP BY job_id;

ALTER VIEW view2 AS SELECT * FROM employees;

删除视图

DROP VIEW view1, view2;

正常的视图更新同表的更新是一样的,但具备以下特点的视图不允许更新:

  • 分组(使用GROUP BY和HAVING);联结
  • 子查询
  • 聚集函数(Min()、Count()、Sum()等)
  • DISTINCT
  • 导出(计算)列。

2 存储过程

2.1 存储过程的作用

在大多数实际场景中,操作并非都是使用一条SQL语句就可以完成的了。一个操作可能会涉及到连续执行三四条SQL语句以上,例如:

  1. 为了处理订单,需要核对以保证库存中有相应的物品。
  2. 如果库存有物品,这些物品需要预定以便不将它们再卖给别的人,并且要减少可用的物品数量以反映正确的库存量。
  3. 库存中没有的物品需要订购,这需要与供应商进行某种交互。
  4. 关于哪些物品入库(并且可以立即发货)和哪些物品退订,需要通知相应的客户。

对于这种场景,就可以使用存储过程进行优化了。存储过程的英文是Stored Procedure。它的思想很简单,就是一组经过预先编译的SQL语句的封装。存储过程预先存储在MySQL服务器上,需要执行的时候,客户端只需要向服务器端发出调用存储过程的命令,服务器端就可以把预先存储好的这一系列SQL语句全部执行。

  • 提高了sql语句的重用性
  • 减少操作过程中的失误,提高效率
  • 减少网络传输量(客户端不需要把所有的SQL语句通过网络发给服务器)
  • 减少了SQL语句暴露在网上的风险,也提高了数据查询的安全性

值得一提的是,存储过程是不具有事务性的。要保证一个存储过程中的全部SQL语句具有事务性,可以在存储过程中开启事务。

2.2 存储过程的简单使用

  • in:该参数可以作为输入,也就是该参数需要调用方传入值
  • out:该参数可以作为输出,也就是该参数可以作为返回值
  • inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值
# 1.空参列表
# 案例:插入到admin表中五条记录
SELECT * FROM admin;
DELIMITER $	# 存储过程的结尾可以使用 delimiter 重新设置
CREATE PROCEDURE myp1()
BEGIN
	INSERT INTO admin(username,`password`) 
	VALUES('john1','0000'),('lily','0000'),('rose','0000'),('jack','0000'),('tom','0000');
END $
#调用
CALL myp1()$

# 2.创建带in模式参数的存储过程
# 案例1:创建存储过程实现 根据女神名,查询对应的男神信息
CREATE PROCEDURE myp1(IN beautyName VARCHAR(20))
BEGIN
	SELECT bo.*
	FROM boys bo
	RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
	WHERE b.name=beautyName;
END $
#调用
CALL myp2('柳岩')$

# 3.创建out 模式参数的存储过程
# 案例1:根据输入的女神名,返回对应的男神名
CREATE PROCEDURE myp2(IN beautyName VARCHAR(20),OUT boyName VARCHAR(20))
BEGIN
	SELECT bo.boyname INTO boyname
	FROM boys bo
	RIGHT JOIN
	beauty b ON b.boyfriend_id = bo.id
	WHERE b.name=beautyName ;
END $

# 4.创建带inout模式参数的存储过程
# 案例1:传入a和b两个值,最终a和b都翻倍并返回
CREATE PROCEDURE myp3(INOUT a INT ,INOUT b INT)
BEGIN
	SET a=a*2;
	SET b=b*2;
END $
# 调用
SET @m=10$
SET @n=20$
CALL myp8(@m,@n)$
SELECT @m,@n$

删除和查看存储过程

DROP PROCEDURE myp1;
SHOW CREATE PROCEDURE myp2;

3 函数

3.1 函数的作用

SQL自带许多封装好的函数,使用函数可以实现对数据的各种处理操作。MySQL支持自定义函数,定义好之后,调用方式与调用MySQL预定义的系统函数一样。

3.2 函数的简单使用

定义函数的形式:

CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型
BEGIN
	函数体
END 
  • 参数列表 包含两部分:参数名 参数类型
  • 函数体:肯定会有return语句,没有会报错。return语句没有放在函数体的最后也不报错,但不建议
  • 函数体中仅有一句话,则可以省略begin end
  • 使用delimiter语句设置结束标记
# 1.无参有返回 案例:返回公司的员工个数
DELIMITER $	# 存储过程的结尾可以使用 delimiter 重新设置
CREATE FUNCTION myf1() RETURNS INT
BEGIN
    DECLARE c INT DEFAULT 0;#定义局部变量
    SELECT COUNT(*) INTO c#赋值
    FROM employees;
    RETURN c;
END $
SELECT myf1()$
# 2.有参有返回 案例1:根据员工名,返回它的工资
CREATE FUNCTION myf2(empName VARCHAR(20)) RETURNS DOUBLE
BEGIN
	SET @sal=0;#定义用户变量 
	SELECT salary INTO @sal   #赋值
	FROM employees
	WHERE last_name = empName;
RETURN @sal;
END $
SELECT myf2('k_ing') $

删除和查看函数

SHOW CREATE FUNCTION myf3;
DROP FUNCTION myf3;

4 总结

无论是定义和使用方式,存储过程和函数是比较类似的。

关键字 调用语法 返回值 应用场景
存储过程 Procedure Call调用存储过程 一般用于更新
函数 Function Select 函数() 只能是一个 一般用于查询

它们和视图有着同样的优点,清晰、安全,还可以减少网络传输量。不过不同的是,视图是虚拟表 ,通常不对底层数据表直接操作,而存储过程是程序化的SQL,可以直接操作底层数据表 ,相比于面向集合的操作方式,能够实现一些更复杂的数据处理。一旦存储过程被创建出来,使用它就像使用函数一样简单,我们直接通过调用存储过程名即可。然而,相较于函数,存储过程是没有返回值的。

标签:语句,存储,函数,CREATE,视图,MySQL,SELECT
From: https://blog.51cto.com/u_14065757/6532815

相关文章

  • LoadRunner通过SiteScope监控MySQL的性能
    步骤:安装SiteScope下载Java版的MySQL驱动,下载地址:http://www.mysql.com/downloads/connector/j/下载成功后,把解压缩的mysql-connector-java-5.1.14-bin.jar文件放入:C:\SiteScope\java\lib\ext 以及 C:\SiteScope\java64\lib\ext目录下。重启系统.进入SiteSc......
  • MySQL约束
    1约束1.1约束分类NOTNULL:非空,用于保证该字段的值不能为空。比如姓名、学号等。DEFAULT:默认,用于保证该字段有默认值,比如性别。PRIMARYKEY:主键,用于保证该字段的值具有唯一性,并且非空。比如学号、员工编号等。UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空。比如座位号。......
  • mysql - #1067 - Invalid default value
    mysql中无法设置默认值为函数或者表达式,如果你强制设置时,就会报错误:#1067-Invaliddefaultvalue。这不是mysql的bug,而是故意这么设计的。参看:http://dev.mysql.com/doc/refman/5.0/en/data-type-defaults.html这里写道:"TheDEFAULTvalueclauseinadatatypespecification......
  • lucene 文件存储相关的几个类
    lucene文件存储相关的几个类,以及他们的派生关系如下图:Directory 代表了Lucene的索引的存储的位置,这是一个抽象类。DbDirectory存储到BerkeleyDB4.3 的实现,BerkeleyDB是历史悠久的嵌入式数据库系统,主要应用在UNIX/LINUX操作系统上,其设计思想是简单、小巧、可靠、高性......
  • 备份 mysql数据
    Mysql数据库的常用备份方法是使用使用mysqldump,其命令格式如下:#mysqldump[options]database[tables]其中参数的含义为:options:代表mysqldump的选项,通过mysqldump–help可以查到。database:代表将要备份的数据库tables:代表将要备份的表,如果不指定任何表,则备份整个数据库......
  • 如何从AWS中学习如何使用AmazonSimpleStorageService(S3)进行数据存储
    目录文章标题:32.《如何从AWS中学习如何使用AmazonSimpleStorageService(S3)进行数据存储》背景介绍:随着数据量的不断增加,数据存储的需求也越来越大。传统的数据存储方式已经无法满足现代应用程序的需求,因此,数据存储技术不断发展和创新,尤其是在云计算领域,各种存储解决......
  • 基于 Flink CDC 构建 MySQL 到 Databend 的 实时数据同步
    这篇教程将展示如何基于FlinkCDC快速构建MySQL到Databend的实时数据同步。本教程的演示都将在FlinkSQLCLI中进行,只涉及SQL,无需一行Java/Scala代码,也无需安装IDE。假设我们有电子商务业务,商品的数据存储在MySQL,我们需要实时把它同步到Databend中。接下来的内......
  • 如何做mysql调优?绝命7招,让慢SQL调优100倍
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......
  • 自动化平台总结(httprunner+djangorestframework+python3+Mysql+Vue)【基础构思】
    一、前言最近从零搭建了一个自动化测试平台,虽然不是第一次从零搭建,但是也从来没有进行过这类搭建的总结,还是记录一下,搭建过程中的一些问题和方法。方便以后总结和翻阅二、简介搭建的平台使用的是Python3.6,未来有空可能考虑加个java版本。前端用的Vue,主体是httprunner2.......
  • Mysql
    mysql8修改登陆host:updateusersethost='%'whereuser='root';ALTERUSER'root'@'localhost'IDENTIFIEDWITHmysql_native_passwordBY'设置的密码';Centos6安装二进制MySQL5.7由于centos6的yum源停更,索性安装个二进制的mysql5.71.下载mys......