设为首页 收藏本站
查看: 669|回复: 0

[经验分享] MySQL--存储过程

[复制链接]

尚未签到

发表于 2018-10-7 14:22:33 | 显示全部楼层 |阅读模式
定义  
一个复杂逻辑对SQL语句的批量处理,
  
通过一个名字存储
  
创建
  
delimiter // 修改终止符
  
-- 存储过程没有返回值
  
delimiter //    ---- 把终止符;修改成//
  
create procedure porc2()
  
begin
  
-- 可执行语句
  
insert into mm_users values (0,'xiaownag','xxx');
  
select * from mm_users;
  
end
  
//       ---- 填写终止符
  
delimiter ;   ---- 还原原来的终止符以执行
  
查看
  
-- 查看 mysql.proc
  
   select db,name,type from mysql.proc;
  
调用
  
-- 调用 如果存储过程没有参数 小括号可以省略
  
call proc();
  
--在pymysql中执行存储过程
  
    cursor.callproc('存储对象名')
  
删除
  
-- 删除
  
drop procedure proc_stu;
  
delete from mysql.proc where name = 'porc1';
  
- 存储过程和函数的区别
  
- 课件
  
-- 函数在使用时候有哪些限制
  
-- select 语句不能够在函数中执行
  
-- 函数中除 select into之外其他的 select 语句都不能够执行
  
-- select into 是将查询的结果赋值给某一个变量
  
delimiter //
  
create function f4(in a int,in b int) returns int
  
begin
  
-- 定义一个变量 res
  
declare res int default 0;
  
-- 将 a + b的结果赋值给 res
  
select count(*) from mm_users into res;
  
-- set res = a + b;
  
-- 返回 res
  
return res;
  
end
  
//
  
delimiter ;
  
-- 通过存储过程来实现函数中不能够调用 select 语句的弊端
  
-- 但是存储过程没有返回值
  
-- 可以通过 out 类型的参数来给存储过程实现多个返回值的功能
  
- 相同点
  
相同点
  
存储过程和函数都是为了可重复的执行操作数据库的 sql 语句的集合.
  
存储过程和函数都是一次编译,就会被缓存起来,
  
下次使用就直接命中缓存中已经编译好的 sql,
  
不需要重复编译
  
减少网络交互,减少网络访问流量
  
- 不同点
  
不同点
  
标识符不同,函数的标识符是 function, 过程:procedure
  
函数中有返回值,且必须有返回值,而过程没有返回值,
  
但是可以通过设置参数类型(in,out)来实现多个参数或者返回值
  
函数使用 select 调用,存储过程需要使用 call 调用
  
select 语句可以在存储过中调用,
  
但是除了 select ... into 之外的 select 语句都不能再函数中调用
  
通过 in out 参数,过程相关函数更加灵活,可以返回多个结果
  
在实际开发中根据个人喜好选择使用函数或者存储过程
  
- 参数/返回值
  
-- 参数的类型
  
-- in 传入类型的参数,函数或者存储过程的参数 默认就是传入类型的参数
  
-- out 传出类型的参数, 给存储过程实现多个返回值的功能
  
-- inout  既可以传入又可以传出 一般不用 一个参数要表达多个意思,
  
造成参数的语义不够清晰 函数的参数的最大个数: 1024
  
procedure p1(
  
    in arg1 int,   # 让存储过程内部使用
  
    out arg2 varchar(50)
  
    inout arg3 int
  
)
  
begin
  
    ...
  
end
  
@i1 = "alex"
  
# @il 引用
  
call p1(1, @i1, @i2)  # @设置一个变量@i1= null



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-614416-1-1.html 上篇帖子: MySQL--函数 下篇帖子: zabbix-mysql表分区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表