MySQL数据库,视图、存储过程与存储函数

数据库对象:

常见的数据库对象:

视图:

  • 视图是一种虚拟表,本身是不具有数据的占用很少的内存空间。

  • 视图建立在已有表的基础上,视图赖以建立的这些表称为基表。

  • 视图的创建和删除只影响视图本身,不影响对应的基表。但是对视图中的数据进行增加、删除和修改操作时,数据表(基表)中的数据会相应地发生变化当对基表中的数据进行增加,删除和操作时,与之对应的视图中的数据记录也会发生相对应的变化

  • 在数据库中,视图不会保存数据,数据真正保存在数据表(基表)中。

创建视图:

精简版:

CREATE  VIEW  视图名称

AS  查询语句;

关于视图中字段的字段名:(若不起字段名,视图中的字段的字段名即为查询字段的字段名)

①可以在查询语句的查询的字段后起别名,查询字段的别名即为视图中字段的字段名

在视图名称后加上括号( ),在括号中写上相应的字段的字段名要一一匹配)。

创建单表视图:

例:

CREATE VIEW view_emp1-- 方式一ASSELECT empno id,ename `name`,deptno dept_idFROM emp;
CREATE VIEW view_emp2(emp_id,`name`,dept_id)-- 方式二ASSELECT empno,ename,deptnoFROM emp;

创建多表视图:

例:

CREATE VIEW view_emp4ASSELECT e.empno,e.ename,e.deptno,d.locFROM emp eJOIN dept dON e.deptno = d.deptno;

利用视图对数据进行格式化:

比如想显示员工的信息的格式为 员工号--姓名--部门号--部门所在地:

CREATE VIEW view_emp5ASSELECT CONCAT(e.empno,'--',e.ename,'--',e.deptno,'--',d.loc) '员工信息'FROM emp eJOIN dept dON e.deptno = d.deptno;

CREATE VIEW view_emp6(员工信息)ASSELECT CONCAT(e.empno,'--',e.ename,'--',e.deptno,'--',d.loc)FROM emp eJOIN dept dON e.deptno = d.deptno;

基于视图创建视图:

例:

CREATE VIEW view_emp7(id,`name`)ASSELECT empno,enameFROM view_emp1;

查看视图:

查看数据库的表对象、视图对象:

SHOW TABLES;

查看视图的结构:

DESC / DESCRIBE 视图名称;

查看视图的属性信息

SHOW TABLE STATUS LIKE 视图;

查看视图的详细信息:

SHOW CREATE VIEW 视图名称;

更新视图中的数据:

类似于更新表的数据

例:

UPDATE view_emp7SET `name` = 'Tony'WHERE id = 7936;DELETE FROM view_emp7WHERE id = 7936;
  • 完成UPDATE操作后,不仅视图view_emp7中的id为7936的员工的名字改为了Tony,基表emp中的id为7936的员工的名字也改为了Tony。通过视图删除了id为7936的员工,基表中的id为7936的员工的信息也会跟着删除

  • 基表中的更新删除操作当然也会同步到视图

  • 如果视图中的字段是基表数据的组函数,更新和删除便不会成功。要使得视图可以更新,视图中的行与基表中的行必须保证有一一对应的关系。

  • 虽然可以更新视图数据,但是总的来说,视图作为虚拟表,主要用于方便查询,不建议更新视图的数据。

  • 对视图的修改,都是通过对实际基表中的数据的操作来完成的。

修改视图:

方式一:

使用CREATE OR REPLACE VIEW子句修改视图

CREATE OR REPLACE VIEW view_emp1-- 方式一

AS

SELECT 语句;

方式二:

使用ALTER VIEW的方式

ALTER VIEW 视图名

AS 

SELECT 语句;

删除视图:

DROP VIEW 视图名;

也可以删除多个视图:

DROP VIEW 视图名,视图名……;

假如基于一个或多个视图创建了额外的视图,将此一个或多个视图删除后,会导致此额外的视图的查询的失败。

视图的优点:

  1. 操作简单。

  2. 减少数据冗余。

  3. 数据更安全,用户不需要查询数据表,可以直接通过视图来获取数据表中的信息。

  4. 适应灵活多变的需求。

  5. 能够分解复杂的查询逻辑。

视图的缺点:

如果实际数据表的结构变了,就需要及时对相关的视图进行相应的维护。视图过多,会导致数据库运维成本的问题。


存储过程与存储函数:

存储过程与存储函数能将复杂的SQL逻辑封装在一起,供以调用

存储过程

存储过程(Stored Proceduce)是一组经过预先编译的SQL语句的封装

执行过程:存储函数预先存储在MySQL服务器上,需要执行的时候,客户端只需要向服务器端发出调用存储过程的命令,服务器端就可以将预先存储好的这一系列SQL语句全部执行。

优点:

  • 简化操作,提高了SQL语句的复用性。

  • 减少网络传输量。

  • 提高了数据查询的安全性。

关于参数前的符号

存储过程的参数类型可以是IN、OUT、INOUT,也可以不带参数

IN:当前参数为输入参数,也就是表示入参。如果没有定义参数种类,默认是IN

OUT:当前参数为输出参数,也就是表示出参。

INOUT:当前参数既可以为输入参数,也可以为输出参数。

DELIMITER:

因为MySQL默认的语句结束符号为‘;’。为了避免与存储过程中的语句结束符相冲突,需要用DELIMITER改变存储过程的结束符

格式:DELIMITER 新的结束符

例:

在存储过程的存储过程体中:

DELIMITER $   -- 将结束符设置为‘$’CREATE PROCEDURE 存储过程名(参数列表)BEGIN……(具体的存储过程的操作)END $DELIMITER ;   -- 将结束符设置为‘;’,以方便后面的操作使用‘;’为结束符。

注:使用DELIMITER时,应该注意避免使用‘\’为结束符,因为其为MySQL的转义字符

存储过程的创建:

格式:

DELIMITER 新结束符

CREATE PROCEDURE 存储过程名(参数列表)

[ characteristics]

BEGIN

……(具体的存储过程的操作)

END 新结束符

DELIMITER ;

characteristics

指定存储过程的特性,有以下取值:

  • LANGUAGE SQL:

说明存储过程体部分是由SQL语句组成的,当前系统支持的语言为 SQL。

  • DETERMINISTIC和NOT DETERMINISTIC:指明存储过程执行的结果是否正确.

    • DETERMINISTIC表示结果是确定的每次执行存储过程时,相同的输入会得到相同的输i出。

    • NOT DETERMINISTIC 表示结果是不确定的,相同的输入可能得到不同的输出。

如果没有指定任意一个值,默认 为 NOT DETERMINISTIC

  • { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }:指明子程序使 用SQL语句的限制

    • CONTAINS SQL表明子程序包含SQL语句,但是不包括读写数据的语句;

    • NO SQL表明子程序不包含SQL语句;

    • READS SQL DATA说明子程序包含读数据 的语句;

    • MODIFIES SQL DATA表明子程序包含写数据的语句。

默认情况下,系统会指定 为 CONTAINS SQL

  • SQL SECURITY {DEFINER | INVOKER }:

表示执行当前存储过程的权限,指明哪些用户有权限来执行

    • DEFINER表示只有定义者才能执行。

    • INVOKER表示拥有权限的调用者可以执行。

默认情况下,系统指定为 DEFINER

  • COMMENT ‘string’:注释信息,可以用来描述存储过程或函数。

存储过程体是SQL代码的内容,用BEGIN…END来表示存储过程体开始和结束。

存储过程的调用

使用CALL关键字:

CALL 存储过程名(参数列表);

①无参的存储过程的使用:

例:创建一个查看所有部门的平均工资的存储过程并调用:

DELIMITER $CREATE PROCEDURE dept_avg_sal()BEGINSELECT deptno,AVG(sal) avg_salFROM test_pro_1GROUP BY deptno;END $DELIMITER ;CALL dept_avg_sal;-- 因为无参,也可以不写括号

②带有传出参数(带有OUT)的存储过程的使用:

例:输出工资最低的员工的工资:

DELIMITER $CREATE PROCEDURE show_min_salary(OUT ms DECIMAL(7,2))BEGINSELECT MIN(sal) INTO msFROM emp;END $DELIMITER ;CALL show_min_salary(@ms);-- 调用show_min_salary过程并将输出值赋值给@ms变量。SELECT @ms;-- 查看@ms变量。

③带有传入参数(带有IN)的存储过程的使用:

例:输入员工的姓名,根据输入的姓名查询员工的工资:

DELIMITER $CREATE PROCEDURE show_someone_sal(IN empname VARCHAR(50))BEGINSELECT salFROM empWHERE ename = empname;END $DELIMITER ;CALL show_someone_sal('KING');-- 调用,输出名字为KING的员工的工资。

④带有输入函数与输出函数(带IN和OUT)的存储过程的使用:

例:输入员工的姓名,根据输入的姓名输出员工的工资:

DELIMITER $CREATE PROCEDURE show_sal(IN emp_name VARCHAR(50),OUT emp_salary DECIMAL(7,2))BEGINSELECT sal INTO emp_salaryFROM empWHERE ename = emp_name;END $DELIMITER ;CALL show_sal('KING',@es);-- 调用show_sal存储过程,将输出值赋值给变量@es。SELECT @es;-- 查看@es。

⑤带INOUT的参数的存储过程的使用:

例:查询某个员工领导的姓名,并用INOUT参数输入员工姓名,输出领导的姓名。

DELIMITER $CREATE PROCEDURE show_mgr_name(INOUT emp_name VARCHAR(50))BEGINSELECT ename INTO emp_nameFROM empWHERE empno = (SELECT mgrFROM empWHERE ename = emp_name);END $DELIMITER ;SET @James = 'JAMES';CALL show_mgr_name(@James);SELECT @James;

注:由于show_mgr_name存储过程不仅要对参数emp_name进行读取,还要对参数emp_name进行赋值,代入的参数不能是一个字符串值(只能读取,不能赋值),而应该是一个变量

存储过程的缺点:

可移植性差、调试困难、版本管理困难、不适合高并发的场景。

存储函数

函数可以对数据进行各种处理操作,提高用户对数据库的管理效率。MySQL支持自定义函数(存储函数),自定义的调用方式与MySQL预定义的系统函数一样。

格式:

DELIMITER 新结束符

CREATE FUNCTION 函数名(参数列表)

RETURNS 返回值类型

[ characteristics]

BEGIN

……(函数体)

END 新结束符

DELIMITER ;

注:

  • 函数中所有的参数都是IN类型的。

  • 函数体中必定包含RETURN语句

  • 函数体用BEGIN和END来表示函数体中的SQL语句的开始和结束。如果函数体只有一条语句,可省略BEGIN和END。建议统一加上,作为习惯。

  • [ characteristics]部分和存储过程的一致

  • 如果创建存储函数时出现‘you *might* want to use the less safe log_bin_trust_function_creators variable’的报错,有两种方式解决:

    • ①加上必要的函数特性“DETERMINISTIC和NOT DETERMINISTIC”与“{ CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }”例:

    • DELIMITER $CREATE FUNCTION job_by_name()RETURNS VARCHAR(50)NOT DETERMINISTICCONTAINS SQLREADS SQL DATABEGINRETURN (SELECT job FROM emp WHERE ename = 'KING');END $DELIMITER ;

    • ②执行:SET GLOBAL log_bin_trust_function_creators = 1;

关于带参数的存储函数的创建与调用:(与存储过程类似)

DELIMITER $CREATE FUNCTION job_by_id(emp_id INT)RETURNS VARCHAR(50)BEGINRETURN (SELECT job FROM emp WHERE empno = emp_id);END $DELIMITER ;SELECT job_by_id(empno)FROM emp;

对比存储函数和存储过程:

  • 存储函数可以放在查询语句中使用,存储过程不行。

  • 存储过程的功能更强大,包括能对表的操作和事务操作。

存储过程和存储函数的查看、修改、删除

查看:

①使用SHOW CREATE语句查看存储过程和存储函数的创建信息。

SHOW CREATE PROCEDURE/FUNCTION 存储过程名/存储函数名;

②使用SHOW STATUS语句查看存储过程和存储函数的状态信息。

SHOW PROCEDURE/FUNCTION [LIKE 'patten'];

③从infomation_schema.Routines表中查看存储函数和存储过程的信息。

SELECT *

FROM information_schema.Routines

WHERE ROUTINE_NAME = '存储函数名或存储过程名' [AND ROUTINE_TYPE = 'FUNCTION'/'PROCEDURE'];

修改:

修改存储过程或函数,不影响存储函数或存储过程的功能(不能修改存储函数体或存储过程体),只是修改相关特性。使用ALTER语句实现。

ALTER CREATE PROCEDURE/FUNCTION 存储过程名/存储函数名 [ characteristics];

删除:

DROP CREATE PROCEDURE/FUNCTION [IF EXISTS] 存储过程名/存储函数名;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/221684.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

打造绿色计算数智动力 HashData 入选“绿色计算最具价值解决方案”

12月13日-14日,由绿色计算产业联盟(GCC)、边缘计算产业联盟(ECC)联合举办“2023计算产业生态大会”(CIEC 2023)在北京举行。作为计算领域的权威会议,本次大会邀请了多位两院院士、众多产业专家,…

单元测试二(实验)-云计算2023.12-云南农业大学

1、实践系列课《深入浅出Docker应用》 https://developeraliyun.com/adc/scenarioSeries/713c370e605e4f1fa7be903b80a53556?spma2c6h.27088027.devcloud-scenarioSeriesList.13.5bb75b8aZHOM2w 容器镜像的制作实验要求 创建Dockerfile文件: FROM ubuntu:latest WORKDIR data…

调用Win10隐藏的语音包

起因 在做一个文本转语音的Demo的时候,遇到了语音包无法正确被Unity识别的问题。明明电脑上安装了语音包但是代码就是识别不出来 原因 具体也不是非常清楚,但是如果语言包是在的话,大概率是Win10系统隐藏了。 确定语言包 首先查看%windi…

2024年天津仁爱学院高职升本科专业考试报考须知

2024年天津仁爱学院高职升本科专业考试报考须知 一、报名条件 1.报考天津仁爱学院2024年高职升本科各专业的考生,应符合天津市教育招生考试院制定的2024年天津市高职升本科及天津仁爱学院专业考试有关报考条件,须完成2024年天津市高职升本科文化考…

k8s部署nacos

先决条件: 这里的存储使用的是storageClass,所以要预先将storageClass(nfs)部署完成详情参见: k8s-StoargClass的使用-基于nfs-CSDN博客 因为nacos数据存储依赖于mysql.所以要预先部署MySQL,然后再部署nacos 部署mysql使用的pvc [rootmaster /devops/nacos/mysql]$cat mysql…

jmeter判断’响应断言‘两个变量对象是否相等

1、首先需要设置变量,json、正则、csv文件等变量 2、然后在响应断言中 ①JMeter Variable Name to use —— 输入一个变量,变量名即可 ② 模式匹配规则 ——相等 ③测试模式 ——输入引用的变量命${变量名} (注意这里是需要添加一个测试模式…

【CANoe】CANoe中使用RS232

文章目录 1、CANoe中自带示例2、示例讲解2.1CANoe自带Port A和Port B通讯2.2CANoe自带Port A和串口助手通讯 1、CANoe中自带示例 我使用的事CANoe12,RS232路径如下: C:\Users\Public\Documents\Vector\CANoe\Sample Configurations 12.0.75\IO_HIL\RS23…

shiro入门demo(一)身份验证

shiro&#xff08;身份&#xff09;认证&#xff0c;简单来说就是登录/退出。搭建springboot项目&#xff0c;引入shiro和单元测试依赖&#xff1a; <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-…

读书笔记-《数据结构与算法》-摘要6[快速排序]

快速排序 核心&#xff1a;快排是一种采用分治思想的排序算法&#xff0c;大致分为三个步骤。 定基准——首先随机选择一个元素最为基准划分区——所有比基准小的元素置于基准左侧&#xff0c;比基准大的元素置于右侧递归调用——递归地调用此切分过程 快排的实现与『归并排…

Axure的安装及界面基本功能介绍

目录 一. Axure概述 二. Axure安装 2.1 安装包下载 2.2 安装步骤 三. Axure功能介绍​ 3.1 工具栏介绍 3.1.1 复制&#xff0c;剪切及粘贴 3.1.2 选择模式和连接 3.1.3 插入形状 3.1.4 点&#xff08;编辑控点&#xff09; 3.1.5 置顶和置底 3.1.6 组合和取消组合 …

【LeetCode刷题笔记(5)】【Python】【盛最多水的容器】【中等】

文章目录 盛最多水的容器算法题描述示例示例 1示例 2 提示题意拆解解决方案&#xff1a;【双指针】运行结果复杂度分析 结束语 盛最多水的容器 盛最多水的容器 算法题描述 给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i…

【排序算法】希尔排序

一&#xff1a;基本介绍 插入排序介绍 1.1 插入排序存在问题 我们看简单的插入排序可能存在的问题 数组 arr {2,3,4,5,6,1} 这时需要插入的数 1(最小), 这样的过程是&#xff1a; {2,3,4,5,6,6}{2,3,4,5,5,6}{2,3,4,4,5,6}{2,3,3,4,5,6}{2,2,3,4,5,6}{1,2,3,4,5,6} 结论:…

AI猫图片展示

AI猫展示 文章目录 AI猫展示

【sgAutocomplete】自定义组件:基于elementUI的el-autocomplete组件开发的自动补全下拉框组件(带输入建议的自动补全输入框)

特性&#xff1a; 1、支持本地保存选中过的记录 2、支持动态接口获取匹配下拉框内容 3、可以指定对应的显示label和字段组件key 4、自动生成速记符字段&#xff08;包含声母和全拼两种类型&#xff09;&#xff0c;增强搜索匹配效率 sgAutocomplete源码 <template><!…

计算机网络:物理层(奈氏准则和香农定理,含例题)

带你速通计算机网络期末 文章目录 一、码元和带宽 1、什么是码元 2、数字通信系统数据传输速率的两种表示方法 2.1、码元传输速率 2.2、信息传输速率 3、例题 3.1、例题1 3.2、例题2 4、带宽 二、奈氏准则&#xff08;奈奎斯特定理&#xff09; 1、奈氏准则简介 2、…

《深入理解 Android ART 虚拟机》笔记

Dex文件格式、指令码 一个Class文件对应一个Java源码文件&#xff0c;而一个Dex文件可对应多个Java源码文件。开发者开发一个Java模块&#xff08;不管是Jar包还是Apk&#xff09;时&#xff1a; 在PC平台上&#xff0c;该模块包含的每一个Java源码文件都会对应生成一个同文件…

Flink Window中典型的增量聚合函数(ReduceFunction / AggregateFunction)

一、什么是增量聚合函数 在Flink Window中定义了窗口分配器&#xff0c;我们只是知道了数据属于哪个窗口&#xff0c;可以将数据收集起来了&#xff1b;至于收集起来到底要做什么&#xff0c;其实还完全没有头绪&#xff0c;这也就是窗口函数所需要做的事情。所以在窗口分配器…

计算机组成原理-ATT格式vsIntel格式

文章目录 AT&T格式 vs lntel格式 x86汇编语言是lntel格式&#xff0c;还有一种汇编语言格式是AT&T AT&T格式 vs lntel格式 lntel格式中取主存地址内容未指明长度默认为32位&#xff0c;对应下图中第四行右边的指令 百分号 美元符号 小括号 可用于计算机结构体数组…

竞赛保研 python+opencv+机器学习车牌识别

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于机器学习的车牌识别系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;4分工作量&#xff1a;4分创新点&#xff1a;3分 该项目较为新颖&#xff0c;适…

Amazon Q:对话智能赋能企业发展

授权说明&#xff1a;本篇文章授权活动官方亚马逊云科技文章转发、改写权&#xff0c;包括不限于在 亚马逊云科技开发者社区, 知乎&#xff0c;自媒体平台&#xff0c;第三方开发者媒体等亚马逊云科技官方渠道 。 在最近举办的亚马逊云科技大会上&#xff0c;引人瞩目的消息是A…