数据库存储历程要怎么写
![](/uploads/allimg/200930/5d5cd2eeec94698012995.jpg)
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$
创立并施行完储备历程,运转结果如下:
以上就是数据库储备历程要如何写的具体内容,更多请关注百分百源码网其它相关文章!