当前位置:文档之家› SQL存储过程.

SQL存储过程.

* 存储过程的能力大大增强了SQL语言的功能和灵活性。

存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。

* 可保证数据的安全性和完整性。

# 通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。

# 通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。

* 在运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案。

这种已经编译好的过程可极大地改善SQL语句的性能。

由于执行SQL语句的大部分工作已经完成,所以存储过程能以极快的速度执行。

* 可以降低网络的通信量。

* 使体现企业规则的运算程序放入数据库服务器中,以便:# 集中控制。

# 当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序。

企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。

如果把体现企业规则的运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化。

三、存储过程的种类:1)、系统存储过程:以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作,如sp_help就是取得指定对象的相关信息2)、扩展存储过程以XP_开头,用来调用操作系统提供的功能exec master..xp_cmdshell 'ping 10.8.16.1'3)、用户自定义的存储过程,这是我们所指的存储过程四、存储过程的书写格式:CREATE PROCEDURE [拥有者.]存储过程名[;程大庆油田企业级数据建模胜利油田关系数据库云南建行Oracle应用开发山东移动DB2数据库管理北京实业Oracle管理员招商银行SQLServer数据库更多...序编号][(参数#1,…参数#1024)][WITH{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}][FOR REPLICATION]AS 程序行其中存储过程名不能超过128个字。

每个存储过程中最多设定1024个参数(SQL Server 7.0以上版本),参数的使用方法如下:@参数名数据类型[VARYING] [=内定值] [OUTPUT]每个参数名前要有一个“@”符号,每一个存储过程的参数仅为该程序内部使用,参数的类型除了IMAGE外,其他SQL Server所支持的数据类型都可使用。

[=内定值]相当于我们在建立数据库时设定一个字段的默认值,这里是为这个参数设定默认值。

[OUTPUT]是用来指定该参数是既有输入又有输出值的,也就是在调用了这个存储过程时,如果所指定的参数值是我们需要输入的参数,同时也需要在结果中输出的,则该项必须为OUTPUT,而如果只是做输出参数用,可以用CURSOR,同时在使用该参数时,必须指定VARYING和OUTPUT这两个语句。

例子:CREATE PROCEDURE order_tot_amt @o_id int,@p_tot int output ASSELECT @p_tot = sum(Unitprice*Quantity)FROM orderdetailsWHERE ordered=@o_id例子说明:该例子是建立一个简单的存储过程order_tot_amt,这个存储过程根据用户输入的定单ID号码(@o_id),由定单明细表(orderdetails)中计算该定单销售总额[单价(Unitprice)*数量(Quantity)],这一金额通过@p_tot这一参数输出给调用这一存储过程的程序。

五、存储过程的常用格式:Create procedure procedue_name[@parameter data_type][output][with]{recompile|encryption}assql_statement解释:output:表示此参数是可传回的with {recompile|encryption}recompile:表示每次执行此存储过程时都重新编译一次encryption:所创建的存储过程的内容会被加密如:表book的内容如下编号书名价格001 C语言入门$30002 PowerBuilder报表开发$52实例1:查询表Book的内容的存储过程create proc query_bookasselect * from bookgoexec query_book实例2:加入一笔记录到表book,并查询此表中所有书籍的总金额Create proc insert_book@param1 char(10),@param2varchar(20),@param3 money,@param4 money output with encryption ---------加密asinsert book(编号,书名,价格)Values(@param1,@param2,@param3)select @param4=sum(价格) from bookgo执行例子:declare @total_price moneyexec insert_book '003','Delphi 控件开发指南',$100,@total_priceprint '总金额为'+convert(varchar,@total_price)go存储过程的3种传回值:1)、以Return传回整数2)、以output格式传回参数3)、Recordset传回值的区别:output和return都可在批次程式中用变量接收,而recordset则传回到执行批次的客户端中。

实例3:设有两个表为Product,Order_,其表内容如下:Product产品编号产品名称客户订数001 钢笔30002 毛笔50003 铅笔100Order_产品编号客户名客户订金001 南山区$30002 罗湖区$50003 宝安区$4请实现按编号为连接条件,将两个表连接成一个临时表,该表只含编号.产品名.客户名.订金.总金额, 总金额=订金*订数,临时表放在存储过程中代码如下:Create proc temp_saleasselect a.产品编号,a.产品名称,b.客户名,b.客户订金,a.客户订数* b.客户订金as总金额into #temptable from Product a inner join Order_ b on a.产品编号=b.产品编号if @@error=0print 'Good'else&n bsp; print 'Fail'go六、编写对数据库访问的存储过程:数据库存储过程的实质就是部署在数据库端的一组定义代码以及SQL。

将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来,那么以后要叫数据库提供与已定义好的存储过程的功能相同的服务时,只需调用execute,即可自动完成命令。

利用SQL的语言可以编写对于数据库访问的存储过程,其语法如下:CREATE PROC[EDURE] procedure_name[;number][{@parameter data_type} ][VARYING] [= default] [OUTPUT]][,...n][WITH{RECOMPILE| ENCRYPTION| RECOMPILE, ENCRYPTION}][FOR REPLICATION]ASsql_statement [...n][ ]内的内容是可选项,而()内的内容是必选项,例:若用户想建立一个删除表tmp中的记录的存储过程Select_delete可写为:Create Proc select_del AsDelete tmp例:用户想查询tmp表中某年的数据的存储过程create proc select_query @year int asselect * from tmp where year=@year在这里@year是存储过程的参数例:该存储过程是从某结点n开始找到最上层的父亲结点,这种经常用到的过程可以由存储过程来担当,在网页中重复使用达到共享。

空:表示该结点为顶层结点fjdid(父结点编号)结点n 非空:表示该结点的父亲结点号dwmc(单位名称)CREATE proc search_dwmc @dwidoldint,@dwmcresult varchar(100) outputasdeclare @stop intdeclare @result varchar(80)declare @dwmc varchar(80)declare @dwid intset nocount onset @stop=1set @dwmc=""select @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidoldset @result=rtrim(@dwmc)if @dwid=0set @stop=0while (@stop=1) and (@dwid<>0)beginset @dwidold=@dwidselect @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidoldif @@rowcount=0set @dwmc=""elseset @result=@dwmc+@resultif (@dwid=0) or (@@rowcount=0)set @stop=0elsecontinueendset @dwmcresult=rtrim(@result)使用exec pro-name [pram1 pram2.....]七、在SQL Server中执行存储过程:sql语句执行的时候要先编译,然后执行。

存储过程就是编译好了的一些sql语句。

用的时候直接就可以用了。

在SQL Server的查询分析器中,输入以下代码:declare @tot_amt intexecute order_tot_amt 1,@tot_amt outputselect @tot_amt以上代码是执行order_tot_amt这一存储过程,以计算出定单编号为1的定单销售金额,我们定义@tot_amt为输出参数,用来承接我们所要的结果。

存储过程具有以下特点:1.具有立即访问数据库的能力;2.是数据库服务器端的执行代码,在服务器执行操作时,减少网络通讯,提高执行效率。

相关主题