无忧站长 >

SQLSERVER中使用存储过程(Stored Procedure)

2019-11-01 14:45:28 
随着SQLSERVER不断的学习,认识的深入,我们会发现越来越多的功能呈现在我们面前,这些功能都是十分强大的,在我们应用中发挥着十分有意义的作用,也因此感知作为一个大型的数据库管理系统的魅力所在。从这一篇开始,我们着手讨论“存储过程“,”触发器“,”游标“,”事务“和”锁“的应用,如果熟练的掌握了这些,我想驾驭SQLSERVER的能力将是一个新的层次。学习是为了应用,掌握就是为了解决问题。希望通过我们一起的学习,我们都可以很好的利用这个工具为我们服务。这是我们学习的目的也是我们的奋斗目标。好,我们继续吧!
说起存储过程,我们先了解他的概念,这是我们讨论必走的第一步:存储过程就是将所需要的工作,预先以SQL程序写好,命名后进行保存,以后需要作这些工作时可以使用EXECUTE指令来调用,即可自动完成相应任务。这里的存储过程也是自动化的一个方面,总之就是为了方便管理的一种措施。让我来说说他的优点吧:
1.执行效率高(这点不容置疑)
2.统一的操作流程:也就是通过存储过程的操作避免了一些操作过程中可能无意中认为的错误,只要确定了制作存储过程时是正确地,以后在调用过程中就不用担心了。大家使用时流程是一样的。
3.重复使用
4.安全性:这一点我们在数据库的安全策略里讨论过,可以参考前边的文章。也就是说:我们可以利用存储过程作为数据存储的管道。可以让客户在一定的范围内对数据进行操作。另外,存储过程是可以加密的,这样别人就看不到他的内容了。
存储过程分为三类:
系统存储过程(System stored Procedure)sp_开头,为SQLSERVER内置存储过程:
扩展存储过程(Extended stored Procedure),也就是外挂程序,用于扩展SQLSERVER的功能,以sp_或者xp_开头,以DLL的形式单独存在。

Δ(观察上面的你会发现系统存储过程和扩展存储过程都是在master数据库中。sp_开头的可是全局的,任何一个数据库都可以直接调用的。)
用户定义的存储过程(User-defined stored Procedure),这个就是用户在具体的数据库中自己定义的,名字最好不要以sp_和xp_开头,防止混乱。
了解了基本概念,就到应用的阶段了。
首先创建一个存储过程(在pubs数据库中),我们命名为MyProce示例代码如下(功能为向stores表中插入stor_id,stor_name两个字段值):

create procedure MyProce
@param1 char(4), @param2 varchar(40) --定义参数,作为存储过程的接口
with encryption --存储过程加密
as insert stores (stor_id,stor_name) values(@param1,@param2)
go

我们如此调用:

exec MyProce ‘111111’,’Leijun’book’ --参数赋值,调用存储过程

用企业管理器创建如图所示:

如果我们要修改,可以查看相应的存储过程的“属性“,如上图在”文本“窗体中修改。
但是注意我们这个因为用了with encryption语句,所以,打开时将有下面的提示,不允许查看,这也就是加密。

看了上面的是不是有所了解了,其实创建时还有其他的参数可以使用,我们这里只是一个简单的例子,更多的应用需要我们在实践中不断的总结,这样才能更加灵活的应用。 下面我们再来看一个创建的例子(这个的作用是在authors表中查找一个人名,表中把一个名字分为两字段存储了,如果查到了,打印“查有此人ID:”及其au_id字段值):

CREATE procedure SearchMe
@param1 varchar(10),@param2 varchar(30)
as
select @param2=au_id
from authors
where au_fname+au_lname=@param1
if @@rowcount>0 --全局变量,记录影响到的行
print’查有此人ID:’+@param2
GO

我们这样执行:Exec SearchMe ‘leijun’,null
由于查找到了所以显示如下:


例子就简单列举这些,因为他的灵活性很大,所以我们只简单的说明一下,如果要更好的利用,这就需要我们不断的摸索了。
下面我们谈谈使用过程中我了解到的注意事项:
1.在存储过程中,有些建立对象的语句是不可使用的:create default,create trigger,create procedure,create view,create rule.
2.在同一数据库中,不同的所有者可以建立相同名称的对象名。例如:a.sample,b.sample,c.sample三个数据表可以同时存在。如果存储过程中未指明对象的所有者(例如存储过程中的语句select * from sample,这句中的sample没有指明所有者),在执行的过程中默认的所有者查找顺序是:相应的存储过程的建立者->相应数据库的所有者。如果这个查找过程中没有把所有者确定下来,系统就要报错。
(这里我额外插一句:如果需要严密的数据操作,在任何操作中尽量加上所有者,例如leijun.sample)
3.在存储过程名称前边添加#或者##,所建立的存储过程则是“临时存储过程“(#是局部临时存储过程,##是全局临时存储过程)。
上面的都是一些容易忽略的,特别是第二条,我们一定的认真思考,也许这些有意无意的忽略是我们造成错误的根源!!