存储过程基本熟知(菜鸟)--摘抄

                 存储过程
基本语法[1]一.创建存储过程
create procedure sp_name  
@[参数名] [类型],@[参数名] [类型]
as
begin
.........
end
以上格式还可以简写成:
create proc sp_name
@[参数名] [类型],@[参数名] [类型]
as
begin
.........
end
/*注:“sp_name”为需要创建的存储过程的名字,该名字不可以以阿拉伯数字开头*/
二.调用存储过程
1.基本语法:exec sp_name [参数名]
三.删除存储过程
1.基本语法:
drop procedure sp_name
2.注意事项
(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
四.其他常用命令
1.show procedure status
显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等
2.show create procedure sp_name
显示某一个mysql存储过程的详细信息
3、exec sp_helptext sp_name
显示你这个sp_name这个对象创建文本

存储过程的种类:
         1,系统存储过程:以sp_开头,用来进行系统的各项设定,取得信息相关管理工作,如sp_help就是取得指定对象的信息
  2,扩展存储过程以xp_开头,用来调用操作系统提供的功能,
      exec master..xp_cmdshell 'ping 10.8.16.1'
  3,用户自己定义的存储过程,这是我们所指的存储过程
     常用格式
 
                Create procedure procedue_name
                [@parameter data_type][output]
                [with]{recompile|encryption}
                as
                ql_statement
 
解释:
output:表示此参数是可传回的
 
with {recompile|encryption}
recompile:表示每次执行此存储过程时都重新编译一次
encryption:所创建的存储过程的内容会被加密
 
如:
表book的内容如下
编号 书名 价格
 001 C语言入门 $30
 002 PowerBuilder报表开发 $52
 
实例1:查询表Book的内容的存储过程
create proc query_book
 as
 select * from book
 go
 exec query_book------调用存储过程
实例2:加入一笔记录到表book,并查询此表中所有书籍的总金额
Create proc insert_book
 @param1 char(10),@param2 varchar(20),@param3 money,@param4 money output
 with encryption ---------加密
 as
 insert book(编号,书名,价格) Values(@param1,@param2,@param3)
 select @param4=sum(价格) from book
 go
 
执行例子:
declare @total_price money
 exec insert_book '003','Delphi 控件开发指南',$100,@total_price
 print '总金额为'+convert(varchar,@total_price)
 go
 
存储过程的3种传回值:
 
1.以Return传回整数
 
2.以output格式传回参数
 
3.Recordset
 
传回值的区别:
 
output和return都可在批次程式中用变量接收,而recordset则传回到执行批次的客户端中
 
实例3:设有两个表为Product,Order,其表内容如下:
 
Product
 产品编号 产品名称 客户订数
 001 钢笔 30
 002 毛笔 50
 003 铅笔 100
 Order
 产品编号 客户名 客户订金
 001 南山区 $30
 002 罗湖区 $50
 003 宝安区 $4
 
请实现按编号为连接条件,将两个表连接成一个临时表,该表只含编号.产品名.客户名.订金.总金额,
 
总金额=订金*订数,临时表放在存储过程中
 
代码如下:
 
Create proc temp_sale
 as
 select a.产品编号,a.产品名称,b.客户名,b.客户订金,a.客户订数* b.客户订金 as总金额
 into #temptable from Product a inner join Order b on a.产品编号=b.产品编号
 if @@error=0
 print 'Good'
 else
 print 'Fail'
 go

                 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值