百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> 数据库存储历程要怎么写
分享文章到:

数据库存储历程要怎么写

发布时间:09/01 来源:未知 浏览: 关键词:
数据库存储历程可以运用SQL语句进行新建:CREATEPROCEDURE历程名([[IN|OUT|INOUT]参数名数据类型[,[IN|OUT|INOUT]参数名数据类型…]])[特性...]历程体。

  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$
新建并施行完存储历程,运转效果如下:

以上就是数据库存储历程要怎么写的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有153人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板