mysql存储数据过程(mysql 存储过程总结(一))

2024-07-05 05:36:49 8

mysql存储数据过程(mysql 存储过程总结(一))

本文目录

mysql 存储过程总结(一)

1、存储过程定义:

存储过程是事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程可以简化应用开发 人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。 存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

2、特点:

封装,复用 : 可以把某一业务SQL封装在存储过程中,需要用到 的时候直接调用即可。

可以接收参数,也可以返回数据 :再存储过程中,可以传递参数,也可以接收返回 值。

减少网络交互,效率提升 : 如果涉及到多条SQL,每执行一次都是一次网络传 输。 而如果封装在存储过程中,我们只需要网络交互一次可能就可以了。

3、基本语法

(1)创建:

(2)调用:

(3)查看:

(4)删除

注意: 在命令行中,执行创建存储过程的SQL时,需要通过关键字 delimiter 指定SQL语句的 结束符。

MySQL里面sql语句调用存储过程,该如何写

这样:

CREATE PROCEDURE sp_add(a int, b int,out c int)

begin

set c=a+ b;

end;

调用过程:

call sp_add (1,2,@a);

select @a;

扩展资料:

注意事项

存储过程(stored procedure)是一组为了完成特定功能的SQL语句集合,经编译后存储在服务器端的数据库中,利用存储过程可以加速SQL语句的执行。

存储过程分为系统存储过程和自定义存储过程。

系统存储过程在master数据库中,但是在其他的数据库中可以直接调用,并且在调用时不必在存储过程前加上数据库名,因为在创建一个新数据库时,系统存储过程在新的数据库中会自动创建。

自定义存储过程,由用户创建并能完成某一特定功能的存储过程,存储过程既可以有参数又有返回值,但是它与函数不同,存储过程的返回值只是指明执行是否成功,并不能像函数那样被直接调用,只能利用execute来执行存储过程。

创建存储过程

   SQL Server创建存储过程:

      create procedure  过程名

         @parameter       参数类型

         @parameter      参数类型   

          。。。

          as 

          begin

          end

执行存储过程:execute 过程名

五、MYSQL存储过程和函数

• create procedure用来创建 存储过程 ,create function用来创建 函数

Delimiter命令是改变语句的结束符 ,MySQL默认的结束符为;号,由于procedure和function中的;号并不代表创建的结束,所以要替换成另外的结束符以便表示创建的结束 • rontine_body子句可以包含一个简单的SQL语句,也可以包含多个SQL语句, 通过begin…end将这多个SQL语句 包含在一起 • MySQL存储过程和函数中也可以包含类似create和drop等DDL语句 • comment子句用来写入对存储过程和函数的注释 • Language子句用来表示此存储过程和函数的创建语言 存储过程和函数被标注为deterministic表明当输入相同的参数是会返回相同的结果,反之如果是not deterministic则表示相同参数不会是相同结果,默认是not deterministic

相关属性短语只有咨询含义,并不是强制性的约束

• Drop procedure/function语句用来 删除指定名称的存储过程或函数

• Begin…end语句通常出现在存储过程、函数和触发器中,其中 可以包含一个或多个语句 ,每个语句用;号隔开

• 标签label可以加在begin…end语句以及loop, repeat和while语句 • 语句中通过iterate和leave来控制流程,iterate表示返回指定标签位置,leave表示跳出标签

Declare语句通常用来声明本地变量、游标、条件或者handler Declare语句只允许出现在begin … end语句中而且必须出现在第一行 Declare的顺序也有要求,通常是先声明本地变量,再是游标,然后是条件和handler

• 本地变量可以通过declare语句进行声明 • 声明后的变量可以通过select … into var_list进行赋值,或者通过set语句赋值,或者通过定义游标并使用fetch … into var_list赋值 • 通过declare声明变量方法:

• MySQL支持if,case,iterate,leave,loop,while,repeat语句作为存储过程和函数中的 流程控制语句 ,另外return语句也是函数中的特定流程控制语句

• Case语句在存储过程或函数中表明了 复杂的条件选择语句

• IF语句在存储过程或函数中表明了 基础的条件选择语句

其中在 function 里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我们开启了 bin-log, 我们就必须为我们的 function 指定一个参数。 在 MySQL 中创建函数时出现这种错误的解决方法: set global log_bin_trust_function_creators=TRUE;

• Iterate语句 仅出现在loop,repeat,while循环语句中,其含义表示重新开始此循环

• Leave语句表明 退出指定标签的流程控制语句块 • 通常会用在begin…end,以及loop,repeat,while的循环语句中

• Loop语句是存储过程或函数中表达 循环执行 的一种方式

• repeat语句是存储过程或函数中表达 循环执行 的一种方式

• while语句是存储过程或函数中表达 循环执行 的一种方式

• Return语句用在 函数中,用来终结函数的执行并将指定值返回给调用者

• Cursor游标用来 声明一个数据集 • 游标的声明必须在变量和条件声明之后,在handler声明之前

• Cursor close语句用来 关闭之前打开的游标

• Cursor declare语句用来声明一个游标和指定游标对应的数据集合, 通常数据集合是一个select语句

• Cursor fetch语句用来获取游标指定数据集的 下一行数据 并将各个字段值赋予后面的变量

• Open cursor语句用来打开一个之前已经 声明好的游标

• Declare condition语句命名 特定的错误条件 ,而该特定错误可以在declare…handler中指定 处理方法

• 比如在MySQL中1051error code表示的是unknown table的错误,如果要对这 个错误做特殊处理,可以用三种方法:

• Declare handler语句用来声明一个handler来处理一个或多个特殊条件,当其中的某个条件满足时则触发其中的statement语句执行 • Statement可以是一个简单SQL语句,也可以是begin…end组成的多个语句

• Handler_action子句声明当执行完statement语句之后应该怎么办

Condition_value的值有以下几种:

• 当condition发生但没有声明handler时,则存储过程和函数依照如下规则处理

• create trigger语句用来创建一个触发器,触发器的作用是当表上有对应SQL语句发生时,则触发执行 • 触发器创建时需要 指定对应的表名 tbl_name

Definer关键词用来指定trigger的安全环境 • Trigger_time指定触发器的执行时间,BEFORE和AFTER指定触发器在表中的 每行数据修改前或者后 执行 • Trigger_event指定触发该触发器的具体 事件 • INSERT当新的一行数据插入表中时触发,比如通过执行insert,load data,replace语句插入新数据 • UPDATE当表的一行数据被修改时触发,比如执行update语句时 • DELETE当表的一行数据被删除时触发,比如执行delete,replace语句时 • 当执行insert into … on duplicate key update语句时,当碰到重复行执行update时,则触发update下的触发器 • 从5.7.2版本开始,可以创建具有相同trigger_time和trigger_event的同一个表上的多个触发器,默认情况下按照创建的时间依次执行,通过 指定FOLLOWS/PRECEDES改变执行顺序 ,即FOLLOWS时表示新创建的触发器后执行,PRECEDES则表示新触发器先执行 • Trigger_body表示触发器触发之后要执行的一个或多个语句,在内部可以引用涉及表的字段, OLD.col_name表示行数据被修改或删除之前的字段数据,NEW.col_name表示行数据被插入或修改之后的字段数据

• Drop trigger语句用来 删除一个触发器

• If exists短语用来避免删除不存在的触发器时引发报错 • 当你执行drop table时,表上的触发器也被drop掉了

mysql中的存储过程怎么使用

存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集功能是将常用或复杂的工作,预先用SQL语句写好并用一个指定名称存储起来,以后需要数据库提供与已定义好的存储过程的功能相同的服务时,只需调用call存储过程名字,即可自动完成命令。存储过程是由流控制和SQL语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,可由应用程序通过一个调用来执行,而且允许用户声明变量。同时,存储过程可以接收和输出参数、返回执行存储过程的状态值,也可以嵌套调用。

mysql利用存储过程实现批量处理数据的简单操作

-- 判断存储test是否存在,如果存在则删除 DROP PROCEDURE IF EXISTS test; -- 创建存储过程 CREATE PROCEDURE test() BEGIN -- 声明循环变量int型 i DECLARE i INT DEFAULT 1; -- 设置i=0 set i=0; -- 循环100次 while i《100 do -- if判断i为偶数 if i%2 = 0 THEN -- 要实现的操作  CONCAT(str1,str2,...) concat函数用于拼接子串和数字类型 INSERT into user(name,addr) VALUES(CONCAT(’test’,i,’ss’),’addr’); end if; -- i自增 set i=i+1; END WHILE; END; -- 调用存储过程 CALL test()

MySql编写一个存储过程

1、delimiter // ,声明分隔符:DELIMITER是分割符的意思,因为MySQL默认以";"为分隔符,如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要事先用DELIMITER关键字申明当前段分隔符,这样MySQL才会将";"当做存储过程中的代码,不会执行这些代码(这里如果不懂的话,你可以通过试错的方法来理解)。2、编写存储过程的格式:CREATE PROCEDURE()例子:  1)create procedure proc1(out s int) // 只有输出  2)create procedure proc2(in p_in bigint) // 只有输入  3)create procedure proc15() // 没有输入与输出  4)create procedure demo_multi_param(in id bigint,in name varchar(32),out c int) //多输入与输出3、过程体的开始与结束使用BEGIN与END进行标识。4、select count (*) into s from student; // 过程体,一系列的逻辑语句,sql语句5、delimiter ; 用完了之后要把分隔符还原。

mysql存储过程知识点难学吗

MySQL存储过程 一、存储过程 1.1 什么是存储过程 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,它存储在数据库中,一次编译后永久有效,用户通...,确实有一定的难度!

如何通过用MySQL怎么创建存储过程

创建存储过程CREATE PROCEDURE 存储过程名()一个例子说明:一个返回产品平均价格的存储过程如下代码:CREATE PROCEDURE productpricing()BEGINSELECT Avg(prod_price) AS priceaverageFROM products;END;//创建存储过程名为productpricing,如果存储过程需要接受参数,可以在()中列举出来。即使没有参数后面仍然要跟()。BEGIN和END语句用来限定存储过程体,过程体本身是个简单的SELECT语句

mysql 导入导出数据库以及函数、存储过程的介绍

本篇文章是对mysql中的导入导出数据库命令以及函数、存储过程进行了详细的分析介绍,需要的朋友参考下 mysql常用导出数据命令:1.mysql导出整个数据库 mysqldump-hhostname-uusername-ppassworddatabasename》backupfile.sql   mysqldump-hlocalhost-uroothqgr》hqgr.sql (如果root用户没用密码可以不写-p,当然导出的sql文件你可以制定一个路径,未指定则存放在mysql的bin目录下)2.mysql导出数据库一个表  mysqldump-hhostname-uusername-ppassworddatabase tablename》导出的文件名mysqldump-hlocalhost-uroothqgrt_ug_user》user.sql3.mysql导出一个数据库结构 mysqldump-hhostname-uusername-ppassword -d--add-drop-tabledatabasename》d:hqgrstructure.sql-d没有数据--add-drop-table在每个create语句之前增加一个droptable4.如果需要导出mysql里面的函数或者存储过程 mysqldump-hhostname-uusername-ppassword-ntd-Rdatabasename》backupflie.sql mysqldump-hlocalhost-uroot-ntd-Rhqgr》hqgr.sql 其中的-ntd是表示导出存储过程;-R是表示导出函数mysql常用导入数据的命令:1.mysql命令 mysql-hhostname-uusername-ppassworddatabasename《backupfile.sql2.source命令 mysql》sourcebackupfile.sql

mysql存储数据过程(mysql 存储过程总结(一))

本文编辑:admin

本文相关文章:


mysql存储数据过程(如何通过用MySQL怎么创建存储过程)

mysql存储数据过程(如何通过用MySQL怎么创建存储过程)

本文目录如何通过用MySQL怎么创建存储过程mysql 存储过程总结(一)mysql存储过程知识点难学吗MySql编写一个存储过程MySQL里面sql语句调用存储过程,该如何写五、MYSQL存储过程和函数mysql 导入导出数据库以及函数、

2024年7月17日 05:42

更多文章:


跑跑卡丁车高速下载(谁知道跑跑在哪里下啊)

跑跑卡丁车高速下载(谁知道跑跑在哪里下啊)

本文目录谁知道跑跑在哪里下啊跑跑卡丁车专业下载和高速下载有什么不同跑跑怎么下载下载跑跑卡丁车的详细步骤如何下载跑跑卡丁车(详细点)在哪下载跑跑谁知道跑跑在哪里下啊跑跑官网下载地址http://popkart.tiancity.com/hom

2024年6月7日 02:55

身边没有异性,怎么才能快速脱单?爱真心网的发展完善

身边没有异性,怎么才能快速脱单?爱真心网的发展完善

本文目录身边没有异性,怎么才能快速脱单爱真心网的发展完善身边没有异性,怎么才能快速脱单没异性,想脱单,可以选择婚恋平台,通过这样的平台,能找到很多异性朋友,你通过选择,可以很快脱单的,我就是这样一个成功案例,你可以参考1、一线姻缘:目前网上

2024年5月3日 08:38

鲁大师2015官方下载(最新鲁大师 怎么用)

鲁大师2015官方下载(最新鲁大师 怎么用)

本文目录最新鲁大师 怎么用鲁大师是个什么软件鲁大师配置图什么意思鲁大师怎么下载鲁大师官方网站 鲁大师2.76绿色版下载鲁大师从哪里下载最正规最新鲁大师 怎么用从网上下载鲁大师,打开安装,打开鲁大师一、鲁大师首页给您一个您的系统的简介,分专业

2023年5月2日 00:40

中国平安e行销网(中国平安E行销网手机怎么进去)

中国平安e行销网(中国平安E行销网手机怎么进去)

本篇文章给大家谈谈中国平安e行销网,以及中国平安E行销网手机怎么进去对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。本文目录中国平安E行销网手机怎么进去平安e行销网登录官网如何登录中国平安E行销中国平安e行销网怎样才能进入自己的e行销

2024年7月20日 19:46

搜狗输入法免费下载(电脑上怎么下载搜狗输入法)

搜狗输入法免费下载(电脑上怎么下载搜狗输入法)

今天给各位分享电脑上怎么下载搜狗输入法的知识,其中也会对电脑上怎么下载搜狗输入法进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录电脑上怎么下载搜狗输入法华为手机怎么下载搜狗输入法电脑搜狗输入法怎么下载vivo搜

2024年6月19日 03:02

微信版官方下载电脑版(微信电脑版怎么下载和安装啊)

微信版官方下载电脑版(微信电脑版怎么下载和安装啊)

各位老铁们好,相信很多人对微信版官方下载电脑版都不是特别的了解,因此呢,今天就来为大家分享下关于微信版官方下载电脑版以及微信电脑版怎么下载和安装啊的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!本文目录微信电脑版怎么下载

2024年7月9日 23:26

groupme(groupme收不到pin)

groupme(groupme收不到pin)

本文目录groupme收不到pinskype改名叫groupme了吗groupme是如何注册需不需要手机号验证groupme收不到pin因为谷歌发送PIN码是通过国际平信的方式,在国内大部分人是收不到平信的,收不到平信,你就无法验证Goog

2024年6月27日 07:54

wow文件夹瘦身(wow文件夹太大那些可以删)

wow文件夹瘦身(wow文件夹太大那些可以删)

本文目录wow文件夹太大那些可以删清理WOW文件夹WOW文件夹里那些文件可以删除 特别是 DATA里的··如何给WOW瘦身如何使魔兽世界文件夹瘦身魔兽世界Date文件夹下的哪些文件是必须要的,哪些是可以删除的啊魔兽世界更新的时候弹出“内存不

2024年3月19日 04:05

自己怎么免费做网站网页(自己如何做网站)

自己怎么免费做网站网页(自己如何做网站)

各位老铁们,大家好,今天由我来为大家分享自己怎么免费做网站网页,以及自己如何做网站的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!本文目录自己如何做网站如何

2024年6月19日 04:05

引流的方法一共有多少种?QQ空间广告位如何实现手机游戏APP软件精准引流

引流的方法一共有多少种?QQ空间广告位如何实现手机游戏APP软件精准引流

本文目录引流的方法一共有多少种QQ空间广告位如何实现手机游戏APP软件精准引流商家该怎么引流引流是什么意思有什么办法能实现快速的微信引流最有效的引流方式是什么如何进行QQ空间推广啊,觉得人太少了清吧如何做引流微营销里的空间引流是什么意思引流

2023年9月4日 12:00

口袋精灵游戏下载(怎么用苹果下载口袋妖怪复刻)

口袋精灵游戏下载(怎么用苹果下载口袋妖怪复刻)

本文目录怎么用苹果下载口袋妖怪复刻电脑可以下口袋精灵可以的给个网址,要教我模拟单机版口袋精灵游戏怎么下载口袋精灵在哪里可以下载到好玩的手机游戏啊有没有与口袋精灵类似的手机游戏怎么用电脑模拟口袋精灵黑/白进行游戏,下载了个no$Gba,加载游

2024年6月12日 05:52

qq企业邮箱登陆(如何从qq进入企业邮箱)

qq企业邮箱登陆(如何从qq进入企业邮箱)

本文目录如何从qq进入企业邮箱怎么用qq邮箱登录企业邮箱怎样登陆使用qq企业邮箱如何登录qq企业邮箱如何从qq进入企业邮箱解决如何从qq进入企业邮箱的步骤如下:1.打开mail.qq.com,登录腾讯qq邮箱,找到并打开其他邮箱,点击立即添

2024年7月11日 09:14

qq飞车cdk兑换(淘宝卖的永久A车CDKey兑换码是真的吗)

qq飞车cdk兑换(淘宝卖的永久A车CDKey兑换码是真的吗)

本文目录淘宝卖的永久A车CDKey兑换码是真的吗QQ飞车cdkey兑换码是什么,求详细解释QQ飞车手游CDK兑换奖励在哪儿兑换奖励 兑换渠道QQ飞车手游cdk兑换达到最大上限了还能换吗qq飞车cdkey兑换码是真的吗,真的可以兑换到永久S车

2024年5月17日 01:44

微软edge官网(microsoft edge浏览器的默认主页网址是什么)

微软edge官网(microsoft edge浏览器的默认主页网址是什么)

大家好,微软edge官网相信很多的网友都不是很明白,包括microsoft edge浏览器的默认主页网址是什么也是一样,不过没有关系,接下来就来为大家分享关于微软edge官网和microsoft edge浏览器的默认主页网址是什么的一些知识

2024年9月3日 16:10

韩剧《秘密》在哪个app可以看?秘密app如何使用

韩剧《秘密》在哪个app可以看?秘密app如何使用

本文目录韩剧《秘密》在哪个app可以看秘密app如何使用什么是秘密app秘密怎么加好友秘密入口的使用方法秘密app是什么秘密app怎么玩关于Secret这个app和SIE币是不是一个骗局秘密app怎么使用秘密怎么下载韩剧《秘密》在哪个app

2024年6月28日 12:41

音标怎么下载?从哪里下载音标字体

音标怎么下载?从哪里下载音标字体

本文目录音标怎么下载从哪里下载音标字体想在ppt里插入英语单词读音,可以在哪里下载音标怎么下载去我的空间留下邮箱,我可以把全部音标字符的word以及音标字体发给你。 希望我的回答对你有一些帮助~从哪里下载音标字体一、 够烦的拉,哈^

2024年6月29日 13:52

截屏快捷键ctrl+alt+(windows截屏快捷键ctrl+alt+)

截屏快捷键ctrl+alt+(windows截屏快捷键ctrl+alt+)

大家好,今天小编来为大家解答以下的问题,关于截屏快捷键ctrl+alt+,windows截屏快捷键ctrl+alt+这个很多人还不知道,现在让我们一起来看看吧!本文目录windows截屏快捷键ctrl+alt+电脑截屏快捷键ctrl+alt

2024年8月14日 11:40

登山赛车无限金币版(登山疯狂越野车无限金币版怎么下载)

登山赛车无限金币版(登山疯狂越野车无限金币版怎么下载)

大家好,关于登山赛车无限金币版很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于登山疯狂越野车无限金币版怎么下载的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!本

2024年8月14日 08:35

魔域的官方怎么老是说您的登录城市与本次不符?哪个高手知道哪里下载QQ魔域客户端,哪个是最新版本的我下了一个怎么进不去啊

魔域的官方怎么老是说您的登录城市与本次不符?哪个高手知道哪里下载QQ魔域客户端,哪个是最新版本的我下了一个怎么进不去啊

本文目录魔域的官方怎么老是说您的登录城市与本次不符哪个高手知道哪里下载QQ魔域客户端,哪个是最新版本的我下了一个怎么进不去啊qq魔域官方下载迅雷魔域官方下载魔域下载地址魔域的官方怎么老是说您的登录城市与本次不符很可能是被盗了。因为必须是你的

2023年9月1日 18:20

造梦西游ol外挂2022(造梦西游ol修改器下载教程(造梦西游ol修改器逍遥))

造梦西游ol外挂2022(造梦西游ol修改器下载教程(造梦西游ol修改器逍遥))

今天给各位分享造梦西游ol修改器下载教程(造梦西游ol修改器逍遥)的知识,其中也会对造梦西游ol修改器下载教程(造梦西游ol修改器逍遥)进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录造梦西游ol修改器下载教程

2024年5月7日 04:55

近期文章

本站热文

iphone vpn设置(ios设置vpn快捷开关)
2024-07-22 15:01:12 浏览:2334
windows12正式版下载(操作系统Windows Server 2012 R2,在哪能下载到,公司用的)
2024-07-20 17:26:53 浏览:1730
java安装教程(win10如何安装JAVA)
2024-07-19 19:55:49 浏览:1155
client mfc application未响应(每次进cf就提示client MFC Application未响应该怎么办啊!急急急)
2024-07-20 11:15:58 浏览:1152
标签列表

热门搜索