17、mysql中的存储过程的应用

其实存储过程也可以叫做过程,而函数也可以叫做存储函数,两者都是处理数据的一种方式,但是不同在于函数是必须要有返回值的,而过程则没有返回值,过程可以理解为是一种用来处理数据的没有返回值的函数,但是他们的语法又存在区别,接下来详细的介绍一下存储过程的使用

创建过程:

// 创建过程
create procedure 过程名字([参数列表])
begin-- 过程代码
end;// 示例
create procedure getUserNames()
beginselect uname from user;
end;

这里需要说一下过程的参数列表,创建过程时需要用到限定类型,有三个:in、out、inout

in传入数据供过程内部使用,可以是变量或者值,传入的参数值不管在过程内部怎么修改,在过程外部不受影响。
out传入的数据只能是变量,传入到过程之后先置为NULL,过程内部修改变量值,外部受影响
inout传入的数据只能是变量,过程内部修改变量值,外部受影响

就这几个参数,光说也不是很好理解,下边提供两个过程,通过改变setName的限定值来看一下三者的区别

// setName的一个过程,依次修改限定的值
create procedure setName(in name varchar(30))
BEGIN// 先看一下传递进来的值SELECT name as first_name;// 过程内部改变传递进来的值set name = "123456";// 看一下修改之后的值select name as second_name;
END;// getName的一个过程,看一下出入的参数值是否被修改
create procedure getName()
BEGINDECLARE name VARCHAR(30) ;set name = "123";select name as init_name;    // 将值传入到setName修改值call setName(name);select name as last_name;
END;依次修改setName的参数列表中限定词,看一下打印情况,作用一目了然

查看过程:

// 查看所有的存储过程
show procedure status\G;// 按着名称查看存储过程
show procedure status like '%me';// 查看过程的创建语句
show create procedure 过程名
show create procedure setName\G;

使用过程:

// 使用call关键字进行过程的使用
call getNames;

删除过程:

// 删除的基本语法都是 drop 类型   名称
drop procedure setName;

以上就是对存储过程的基本介绍

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

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

相关文章

CF9D-How many trees?【dp】

正题 题目链接:https://www.luogu.com.cn/problem/CF9D 题目大意 求nnn个点组成的深度大于hhh的二叉树有多少个。 解题思路 定义fi,jf_{i,j}fi,j​表示iii个点高度为jjj的树有多少个,然后每次将两棵(a,b)(x,y)(a,b)(x,y)(a,b)(x,y)合并就有 fax1,max{b,y}1fa,b∗…

把旧系统迁移到.Net Core 2.0 日记(2) - 依赖注入/日志NLog

Net Core 大量使用依赖注入(Dependency Inject), 打个比方,我们常用的日志组件有Log4Net,NLog等等.如果我们要随时替换日志组件,那么代码中就不能直接引用某个组件的内容,也不能直接New 某个组件.而是应该定义一组接口, 然后包装各个组件,实现这个接口. Net Core 自带组件容器,…

18、数据的备份和还原

mysql中数据的备份有以下几种方式: 1、直接在数据库文件夹中复制对应的表结构以及数据文件进行数据备份 2、将每一张表中的数据进行备份 3、使用mysqldump.exe 进行备份 4、增量数据备份 接下来就详细的介绍一下每一种备份的具体操作 直接在数据库文件夹中复制…

开源纯C#工控网关+组态软件(九)定制Visual Studio

一、 引子因为最近很忙(lan),很久没发博了。不少朋友对那个右键弹出菜单和连线的功能很感兴趣,因为VS本身是不包含这种功能的。大家想这是什么鬼,怎么我的设计器没有,其实这是一个微软黑科技,…

P2805-[NOI2009]植物大战僵尸【网络流,最大权闭合图】

正题 题目链接:https://www.luogu.com.cn/problem/P2805 题目大意 n∗mn*mn∗m的格子,攻击这个格子(x,y)(x,y)(x,y)可以获得价值cx,yc_{x,y}cx,y​,攻击一个格子(x,y)(x,y)(x,y)前要攻击(x,y1)(x,y1)(x,y1)。 对于有的格子(x,y)(x,y)(x,y)会保护些格子…

19、mysql中定时器的创建和使用

mysql中可以使用定时器,用来进行计划的调度,在mysql中定时器通过事件的形式存在,接下来介绍一下定时器的使用 创建定时器 CREATE EVENT IF NOT EXISTS 计划名-- 计划频率和开启计划时间或者是计划执行的时间-- 前一个可以实现持续的计划调度…

使用C#实现适配器模式 (Adapter Pattern) 和外观模式 (Facade Pattern)

本文的概念内容来自深入浅出设计模式一书现实世界中的适配器(模式)我带着一个国标插头的笔记本电脑, 来到欧洲, 想插入到欧洲标准的墙壁插座里面, 就需要用中间这个电源适配器.面向对象的适配器你有个老系统, 现在来了个新供应商的类, 但是它们的接口不同, 如何使用这个新供应商…

jzoj3852-单词接龙【0/1分数规划,负环】

正题 题目链接:https://jzoj.net/senior/#main/show/3852 题目大意 nnn个单词串,头尾有两个相同单词就可以连在一起,求一个最长的环使得平均单词长度最长。 解题思路 其实总共26∗2626*2626∗26个点,然后求一个回路使得平均边长最长 就是0…

20、mysql中触发器的使用

是什么 触发器不同于定时器,触发器用在表中的记录上,每当表中的记录进行增、删、改操作时,则绑定在表上的对应的触发器被触发,进行对应的操作。(有点类似于java中的swing中的监听器) 怎么用 可以表中每一…

在 .NET Core 中使用 DiagnosticSource 记录跟踪信息

前言最新一直在忙着项目上的事情,很久没有写博客了,在这里对关注我的粉丝们说声抱歉,后面我可能更多的分享我们在微服务落地的过程中的一些经验。那么今天给大家讲一下在 .NET Core 2 中引入的全新 DiagnosticSource 事件机制,为什…

jzoj3854-分组【树状数组,线段树】

正题 题目链接:https://jzoj.net/senior/#contest/show/2990/2 题目大意 一个小队满足要求 队长的地位最高所有队员和队长的年龄差不超过kkk 给出nnn个人的地位和年龄,qqq个询问 每次询问一组(x,y)(x,y)(x,y)求若(x,y)(x,y)(x,y)在同一个队里那这个队的最多人数…

.NET:持续进化的统一开发平台

标题使用的是进化这个词语,是因为 .NET 在不断的努力,也在不断的重构。这篇文章的更多目的和意义在于科普,俗称“传教”。持续进化的 .NET上图即是一个学习的路线图同样他也是 .NET 平台的进化图。也是代表着 未来.NET的发展方向。今天的故事…

21、mysql修改密码的方法总结

修改mysql服务的连接密码其原理在于修改mysql服务自带mysql数据库下user表中的数据,下边三种修改方式和使用场景不同,不过最终的原理一致,前两种需要连接mysql服务之后修改,第三种方式无需连接服务即可修改。 1.强制修改root密码…

jzoj3853-帮助Bsny【dp】

正题 题目链接:https://jzoj.net/senior/#main/show/3853 题目大意 nnn个数字,每次可以将一个数字拿出并插入任意位置,操作kkk次求最少段连续相同的数。 解题思路 先将相同的缩在一起 设fi,j,s,zf_{i,j,s,z}fi,j,s,z​表示到第iii个,拿出了…

linux下jdk的安装和配置

1.将jdk的rpm包上传到服务器 2.使用rpm命令安装jdk rpm -ivh ***.rpm 3.配置环境变量 cd /usr/java目录下查看是否有jdk安装后的目录(一般都在这个目录下) vi /etc/profile,将以下代码添加到文件中 export JAVA_HOME/usr/java/jdk1.8.0_…

容器化的 DevOps 工作流

对于 devops 来说,容器技术绝对是我们笑傲江湖的法宝。本文通过一个小 demo 来介绍如何使用容器技术来改进我们的 devops 工作流。devops 的日常工作中难免会有一些繁琐的重复性劳动。比如管理 Azure 上的各种资源,我们会使用 Azure CLI 工具。同时我们也…

Summer Training day6 coseforces339D 线段树、位操作

D. Xenia and Bit Operationstime limit per test2 secondsmemory limit per test256 megabytesinputstandard inputoutputstandard outputXenia the beginner programmer has a sequence a, consisting of 2n non-negative integers: a1, a2, ..., a2n. Xenia is currently…

U102380-简单数据结构题【Trie】

前言 %%%\%\%\%%%%北大爷的题目 正题 题目链接:https://www.luogu.com.cn/problem/U102380 题目大意 nnn个数,求一个数kkk使得max{aixork}max\{a_i\ xor\ k\}max{ai​ xor k}最小。 解题思路 我们对每一个数按位建到一个TrieTrieTrie里,然后对于每个节…

linux下redis的安装和配置

以下介绍的是使用源码包的方式安装redis 1.创建安装目录 cd /usr/local mkdir redis 2.上传包到此目录下,并解压 tar -zxvf ****.tar.gz 3.使用make命令进行redis安装 cd到解压后的目录下,执行如下命令 编译命令:make,如果执行make命…

.NET Core 2.1 Preview 2发布 - April 10, 2018

我们今天宣布发布 .NET Core 2.1 Preview 2。这也是我们在接下来的两到三个月内接近最终发布的版本,该版本现已准备好进行广泛的测试。我们希望您有任何反馈意见。ASP.NET Core 2.1 Preview 2和Entity Framework 2.1 Preview 2也在今天发布。您可以在Windows&#x…