mysql访问对象存储_数据库对象存储过程 轻松走进数据库系列八

存储过程概念 存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可独立执行或由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程一旦创建,在服

存储过程概念

存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可独立执行或由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程一旦创建,在服务器上即被编译,可以在需要时执行多次,有效的提高了执行效率。

存储过程的分类:系统存储过程和用户存储过程 。

系统存储过程存储在master数据库中,且以sp_为前缀。在其他数据库中可以直接调用,不必指明数据库名

存储过程的优点

可以在单个存储过程中执行一系列 SQL 语句。

可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。

和函数的区别

执行的本质都一样。函数的限制比较多。具体如下;

1、返回值:函数只能返回值或者表对象而且是一个;而存储过程可以返回参数,返回单个或多个结果集以及返回值。

2、调用:函数是可以作为查询语句的一个部分来调用,所以可以嵌入在sql中使用,可以在select中调用;

由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面;

而存储过程作为一个独立的部分来执行。

3、数据来源;函数不能用临时表,只能用表变量;而存储过程的限制相对就比较少 。

实现功能:存储过程实现的功能要复杂一点;而函数的实现的功能针对性比较强。

主要讲用户存储过程的操作和调用

管理存储过程的操作

1、创建存储过程:创建一个和创建一组。

步骤:1、判断存储过程是否存在,若存在,先删除存储过程。

2、创建存储过程。

语法:(1)创建一个存储过程

if exists (sql语句)

Drop procedure proname

Go

'开始创建

Create procedure proname [参数列表(参数名,数据类型,默认值)[output]]

[with recompile|encryption]

As

(2)创建一组存储过程。用一个例子来说明吧!

test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201207%2F12%2F1342051413_3038.png&refer=http%3A%2F%2Fblog.csdn.net%2Fwangyongxia921%2Farticle%2Fdetails%2F7738693

使用“;”和 数字来创建了一组存储过程。

执行时,可以单独执行其中的一个,写明存储过程名,分号,和数字。例:execute group_sp;3

但是不可以单独删除某个存储过程,要删除只能一起删除。

2、修改存储过程:只把定义中的create改成alter即可。

3、删除存储过程:drop procedure proname

4、查看存储过程:sp_helptext 查看存储过程的文本,

sp_depends 查看存储过程的饮用对象。

sp_help 显示所有相关信息。

5、重命名存储过程:sp_rename '',''

调用存储过程

调用、参数传入、返回值。

调用:使用语句execute。

参数传入;按位传入:按照声明时的顺序传入;

按引用传入:按照参数的名字传入,书写参数时可一不安顺序来写。

返回值:return 和output

两者没有区别:只是声明不同。return出现在定义完存储过程后。Return @变量名

而output是在创建存储过程定义变量时,写在要变量之后: @变量名 output

注意:1、参数变量前都需要加@。

2、调用时,如果存储过程是批处理的第一条语句,可以不使用execute关键字,直接用存储过程铭来执行。

3、传值时,@变量名=default或者不写,使用定义时的默认值。

4、两种传值方式不可以混用。

触发器时特殊的存储过程,触发器是由事件触发的,而存储过程是单独执行或由程序调用的。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据库支持存储过程存储过程是一种预先编写好的程序,可以被多次调用和执行,使得数据库应用程序的开发更加灵活和高效。下面是MySQL数据库存储过程的创建和调用方法: 1. 创建存储过程MySQL数据库创建存储过程需要使用“CREATE PROCEDURE”语句,语法如下: ``` CREATE PROCEDURE procedure_name([IN | OUT | INOUT] parameter_name parameter_type) BEGIN -- 存储过程体 END; ``` 其,procedure_name 是存储过程的名称,parameter_name 是存储过程的参数名称,parameter_type 是存储过程的参数类型,可以是任意的MySQL数据类型,例如VARCHAR、INT、DOUBLE等。存储过程体可以包含SQL语句、流程控制语句、变量声明等。例如,下面是一个简单的存储过程: ``` CREATE PROCEDURE get_user_info(IN user_id INT) BEGIN SELECT * FROM users WHERE id = user_id; END; ``` 以上存储过程名为get_user_info,接受一个IN类型的参数user_id,返回对应用户的信息。 2. 调用存储过程MySQL数据库调用存储过程需要使用“CALL”语句,语法如下: ``` CALL procedure_name(parameter_value); ``` 其,procedure_name 是存储过程的名称,parameter_value 是存储过程的参数值,可以是任意的MySQL数据类型,例如字符串、整型等。例如,调用上述的get_user_info存储过程可以使用以下语句: ``` CALL get_user_info(1001); ``` 以上语句将会返回id为1001的用户信息。 综上所述,MySQL数据库存储过程的创建和调用方法比较简单,可以提高数据库应用程序的开发效率和灵活性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值