Mysql存储过程语法讲解,以及如何用Java调用!

存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的-种数据库对象。

存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。

其实存储过程思想上很简单,就是数据库SQL语言层面的代码封装与重用。

优缺点分析:

优点:
1.存储过程可封装, 并隐藏复杂的商业逻辑。
2.存储过程可以回传值,并可以接受参数。
3.存储过程无法使用 SELECT指令来运行,因为它是子程序,与查看表,数据表或用户定义函数不同。
4.存储过程可以用在数据检验, 强制实行商业逻辑等。

缺点
1.存储过程,往往定制化于特定的数据库上,因为支持的编程语言不同。当切换到其他厂商的数据库系统时,需要重写原有的存储过程。
2.存储过程的性能调校与撰写,受限于各种数据库系统。

语法
在linux系统下操作Mysql:

1.先进入数据库
mysql -u root -p 1234

2.声明结束符号,语句的结束符号从分号;临时改为一个$(可以是自定义)
delimiter $

3.声明存储过程:
create procedure proc_demo(in p_ in int)

4.变量定义:
declare id_int int unsigned default 1001

变量赋值
set useid=1

5.存储过程开始和结束符号:
begin end

6.创建mysql存储过程:
create procedure 存储过程名(参数)

7.调用存储过程:
call 存储过程名(赋值)

8.MySQL存储过程的查询,查看某个数据库下面的存储过程
select name from mysql.存储过程名 where db='数据库名’

show procedure status where db=‘数据库名’;

9.查看存储过程的详细信息
show create procedure 数据库.存储过程名

10.MySQL存储过程的修改
alter procedure 存储过程名

11.MySQL存储过程的删除
drop procedure 存储过程名

12.条件语句

  1. if-then-else 语句
delimiter //  
mysql > create procedure proc2(IN parameter int)  
     -> begin 
     -> declare var int;  
     -> set var=parameter+1;  
     -> if var=0 then 
     -> insert into t values(17);  
     -> end if;  
     -> if parameter=0 then 
     -> update t set s1=s1+1;  
     -> else 
     -> update t set s1=s1+2;  
     -> end if;  
     -> end;  
     -> //  
mysql > delimiter 
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值