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 ;

2.case 语句

mysql > delimiter //  
mysql > create procedure proc3 (in parameter int)  
     -> begin 
     -> declare var int;  
     -> set var=parameter+1;  
     -> case var  
     -> when 0 then   
     -> insert into t values(17);  
     -> when 1 then   
     -> insert into t values(18);  
     -> else   
     -> insert into t values(19);  
     -> end case;  
     -> end;  
     -> //  
mysql > delimiter ; 
case
    when var=0 then
        insert into t values(30);
    when var>0 then
    when var<0 then
    else
end case

13.循环语句
1.while ···· end while
while 条件 do
–循环体
end while

mysql > delimiter //  
mysql > create procedure proc4()  
     -> begin 
     -> declare var int;  
     -> set var=0;  
     -> while var<6 do  
     -> insert into t values(var);  
     -> set var=var+1;  
     -> end while;  
     -> end;  
     -> //  
mysql > delimiter ;

2.repeat···· end repea
它在执行操作后检查结果,而 while 则是执行前进行检查。
repeat
–循环体
until 循环条件
end repeat;

mysql > delimiter //  
mysql > create procedure proc5()  
     -> begin   
     -> declare v int;  
     -> set v=0;  
     -> repeat  
     -> insert into t values(v);  
     -> set v=v+1;  
     -> until v>=5  
     -> end repeat;  
     -> end;  
     -> //  
mysql > delimiter ;

3.loop ·····end loop
loop 循环不需要初始条件,这点和 while 循环相似,同时和 repeat 循环一样不需要结束条件, leave 语句的意义是离开循环。

mysql > delimiter //  
mysql > create procedure proc6()  
     -> begin 
     -> declare v int;  
     -> set v=0;  
     -> LOOP_LABLE:loop  
     -> insert into t values(v);  
     -> set v=v+1;  
     -> if v >=5 then 
     -> leave LOOP_LABLE;  
     -> end if;  
     -> end loop;  
     -> end;  
     -> //  
mysql > delimiter ;

14.MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT

IN 输入参数:表示调用者向过程传入值(传入值可以是字面量或变量)
OUT 输出参数:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量)
INOUT 输入输出参数:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)

参数定义可以是一个,可以是两个,也可以是三个

创建存储过程案例

  delimiter $
  create procedure proc_demo(in usid integer)
     begin
     delete from userinfos where userid=:usid;
     end$
  delimiter ;
call proc_demo(2);   call调用存储过程并传参

注意
begin end 之间可以是SQL语句,也可以给变量赋值;
当sql中参数的值要去赋值时语法必须是 sql参数=: 传参
如果存储过程没有参数,也必须在过程名后面写上小括号

delimiter $
create procedure proc_sum(in num1 integer,in num2 integer,out sums integer)
 begin
 set sums=num1+num2; 
 end$
 delimiter ;

解析
在存储过程中设置了需要传参的变量num1和num2,调用存储过程的时候,通过调用存储过程call proc_sum()传参将值给num1和num2,然后进行存储过程里的SQL操作。

用java调用存储过程
导Mysql依赖包

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.38</version>
</dependency>
@SpringBootApplication
@EnableScheduling
public class ConnMySql (
public static void main (String[] args) throws Exception{
    // 1.加载驱动
   Class.forName ("com.mysql.jdbc.Driver") ;
  
   try{
       // 2.连接数据库
       Connection conn = DriverManager.getConnection("jdbc:mysql://192.168.56.44:3306/tpshop","root","1234") ;
       //3.调用存储过程
       CallableStatement cstmt = conn prepareCall ("(call proc_sum(?,?,?) )")
       //call proc_sum(?,?,?)  调用的存储过程中有3个参数,用3个?表示
     }catch{
       //第一个参数是in输入型
       cstmt.setInt (1, 4);
       //第二个参数是in输入型   
       cstmt.setInt (2,5);    
      //注册输出参数
      //第3个参数是输出型,用来接收out结果
      cstmt.registerOutParameter(3, Types.INTEGER) ;  
      cstmt.execute () ;
      System.out.println ( "执行结果是: "+cstmt.getInt(3));
      cstmt.close();
    }
}
}

猜你喜欢

转载自blog.csdn.net/zp17834994071/article/details/107048721