存储过程结构

CREATE PROCEDURE [拥有者.]存储过程名[;程序编号]
  [(参数#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 AS
  SELECT @p_tot = sum(Unitprice*Quantity)
  FROM orderdetails
  WHERE 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}
  as
  sql_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
  &n bsp; print 'Fail'
  go

 

 

 

存储过程优缺点https://blog.csdn.net/jackmacro/article/details/5688687

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值