SQL Server存储过程带参数和通配符

使用带有参数的简单过程

  Create PROCEDURE au_info
      @lastname varchar(40),
      @firstname varchar(20)
  
AS
  
Select au_lname, au_fname, title, pub_name
      FROM authors a INNER JOIN titleauthor ta
      ON a.au_id = ta.au_id INNER JOIN titles t
      ON t.title_id = ta.title_id INNER JOIN publishers p
      ON t.pub_id = p.pub_id
      Where  au_fname = @firstname
      AND au_lname = @lastname
  GO

  au_info 存储过程可以通过以下方法执行:

  EXECUTE au_info 'Dull', 'Ann'
  
-- or
  
EXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'
  
-- or
  
EXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'
  
-- or
  
EXEC au_info 'Dull', 'Ann'
  
-- or
  
EXEC au_info @lastname = 'Dull', @firstname = 'Ann'
  
-- or
  EXEC au_info @firstname = 'Ann', @lastname = 'Dull'

  如果该过程是批处理中的第一条语句,则可使用:

  au_info 'Dull', 'Ann'
  
-- or
  
au_info @lastname = 'Dull', @firstname = 'Ann'
  
-- or
  au_info @firstname = 'Ann', @lastname = 'Dull'

 

使用带有通配符参数的简单过程

  Create PROCEDURE au_info2
  
@lastname varchar(30) = 'D%',
  
@firstname varchar(18) = '%'
  
AS
  
Select au_lname, au_fname, title, pub_name
  
FROM authors a INNER JOIN titleauthor ta
  
   ON a.au_id = ta.au_id INNER JOIN titles t
  
   ON t.title_id = ta.title_id INNER JOIN publishers p
  
   ON t.pub_id = p.pub_id
  
Where au_fname LIKE @firstname
  
   AND au_lname LIKE @lastname
  GO

  au_info2 存储过程可以用多种组合执行。下面只列出了部分组合:

  EXECUTE au_info2
  
-- or
  
EXECUTE au_info2 'Wh%'
  
-- or
  
EXECUTE au_info2 @firstname = 'A%'
  
-- or
  
EXECUTE au_info2 '[CK]ars[OE]n'
  
-- or
  
EXECUTE au_info2 'Hunter', 'Sheryl'
  
-- or
  EXECUTE au_info2 'H%', 'S%'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值