出处:http://www.jb51.net/article/54730.htm
--有输入参数的存储过程--create proc GetComment
(@commentid int)
asselect * from Comment where CommentID=@commentid
调用方式:exec GetComment 3
--有输入与输出参数的存储过程--create proc GetCommentCount
@newsid int,
@count int output
asselect @count=count(*) from Comment where NewsID=@newsid
调用方式:
declare @cnt int
exec GetCommentCount 1,@cnt output
print @cnt
--返回单个值的函数--create function MyFunction
(@newsid int)
returns int
asbegindeclare @count int
select @count=count(*) from Comment where NewsID=@newsid
return @count
end调用方式:
declare @cnt int
exec @cnt =
MyFunction 1print @cnt
--返回值为表的函数--Create function GetFunctionTable
(@newsid int)
returns table
asreturn(select * from Comment where NewsID=@newsid)
go
调用方式:select * from GetFunctionTable(2)CREATE proc func_withconditions
(
@firstName varchar(20),
@lastName varchar(20)
)
AS
begin
declare @sql varchar(500)
set @sql = 'select * from employee where 1=1 '
if(@firstName is not null)
set @sql = @sql+' and first_name='+''''+@firstName+''''
if(@lastName <> ' ' and @lastName is not null)
set @sql = @sql+' and last_name='+''''+@lastName+''''
exec(@sql)
end
GO
调用方式:
exec func_withconditions 'ahg',''
exec func_withconditions 'ahg',NULL
exec func_withconditions NULL,'jhg'