数据库存储历程怎么写
SQL语句需要先编译然后施行,而存储历程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,会员通过指定存储历程的名字并给定参数(要是该存储历程带有参数)来调取施行它。存储历程是可编程的函数,在数据库中新建并保留,可以由SQL语句和控制构造组成。当想要在不一样的利用程序或平台上施行雷同的函数,或者封装特定功能时,存储历程是非常实用的。数据库中的存储历程可以看做是对编程中面向对象办法的模拟,它允许控制数据的拜访方式。
举荐课程:MySql教程。
存储历程的长处:
(1).加强SQL说话的功能和灵便性:存储历程可以用控制语句编写,有很强的灵便性,可以完成复杂的推断和较复杂的运算。
(2).规范组件式编程:存储历程被新建后,可以在程序中被屡次调取,而无须从新编写该存储历程的SQL语句。并且数据库专业人员可以随时对存储历程进行修改,对利用程序源代码毫无影响。
(3).较快的施行速度:要是某一操纵包括批量的Transaction-SQL代码或离别被屡次施行,那么存储历程要比批处置的施行速度快许多。由于存储历程是预编译的。在首次运转一个存储历程时查询,优化器对其进行剖析优化,而且给出终究被存储在系统表中的施行规划。而批处置的Transaction-SQL语句在每次运转时都要进行编译和优化,速度相对要慢一些。
(4).减少网络流量:针对统一个数据库对象的操纵(如查询、修改),要是这一操纵所波及的Transaction-SQL语句被组织进存储历程,那么当在客户盘算机上调取该存储历程时,网络中传送的只是该调取语句,从而大大减少网络流量并落低了网络负载。
(5).作为一种平安机制来充分应用:通过对施行某一存储历程的权限进行限定,能够实现对响应的数据的拜访权限的限定,以免了非授权会员对数据的拜访,保障了数据的平安。
MySQL的存储历程
存储历程是数据库的一个重要的功能,MySQL 5.0之前并不支撑存储历程,这使得MySQL在利用上大打折扣。好在MySQL 5.0开端支撑存储历程,这样即可以大大提高数据库的处置速度,同时也可以提高数据库编程的灵便性。
MySQL存储历程的新建
语法
CREATE PROCEDURE 历程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 ...] 历程体 DELIMITER // CREATE PROCEDURE myproc(OUT s int) BEGIN SELECT COUNT(*) INTO s FROM students; END // DELIMITER ;
分隔符
MySQL默许以";"为分隔符,要是没有声明分割符,则编译器会把存储历程当做SQL语句进行处置,因而编译历程会报错,所以要事先用“DELIMITER //”声明目前段分隔符,让编译器把两个"//"之间的内容当成存储历程的代码,不会施行这些代码;“DELIMITER ;”的意为把分隔符复原。
参数
存储历程依据需要可能会有输入、输出、输入输出参数,要是有多个参数用","分割开。MySQL存储历程的参数用在存储历程的定义,共有三种参数类型,IN,OUT,INOUT:
IN参数的值必需在调取存储历程时指定,在存储历程中修改该参数的值不克不及被返回,为默许值OUT:该值可在存储历程内部被转变,并可返回INOUT:调取时指定,而且可被转变和返回
历程体
历程体的开端与完毕运用BEGIN与END进行标识。
总结
本次主如果把握了关于存储历程的运用,总的来说,存储历程现实上相似于C++中的函数,而在C++中我们是需要在新建这一历程的文件中去调取这一函数,但是关于存储历程来说,相当于是将这一操纵历程存储在数据库中,可以运用call与对其进行调取,并输入或者输出一些参数和效果。
印象最深的是相似“in n int”和“out sum int”这样的关于输入输出的定义,通过查看相干博客,可以总结如下关于输入输出定义的运用纪律:
MySQL存储历程的参数用在存储历程的定义,共有三种参数类型
IN,OUT,INOUT
格局为:Create procedure|function([[IN |OUT |INOUT ] 参数名 数据类形...])
IN 输入参数
表示该参数的值必需在调取存储历程时指定,在存储历程中修改该参数的值不克不及被返回,为默许值
OUT 输出参数
该值可在存储历程内部被转变,并可返回
INOUT 输入输出参数
调取时指定,而且可被转变和返回
IN 和 OUT在实验中已有体味,主如果对INOUT的了解,这里援用一个例子:
参数inout的运用实例(既能输入一个值又能传出来一个值)
语句功能:传一个年龄,主动让年龄增长10岁
create procedure p3(inout age int)
begin
set age:=age+10;
end
其中:调取的时候,inout型的参数值既是输入类型又是输出类型,给它一个值,值不是变量,因而我们需要先设定一个变量并初始化这个值,调取的时候直接传这个变量即可。
set @currentAge=8$
call p3(@currentAge)$
select @currentAge$
新建并施行完存储历程,运转效果如下:
以上就是数据库存储历程怎么写的细致内容,更多请关注 百分百源码网 其它相干文章!