如何在存储过程里生成where语句
李天平 2004-07-07 01:46:20 这样的存储过程如何写
CREATE PROCEDURE sp_Forums_GetTopics
@ForumID int,
@Subject varchar(50),
@MemberName varchar(50),
@AddedDate datetime
AS
DECLARE @strwhere varchar(500)
set @strwhere='(1=1)'
if @ForumID is not null
begin
SET @strwhere=' and '+@strwhere+'ForumID = '+@ForumID
end
if @Subject is not null
begin
SET @strwhere=' and '+@strwhere+'Subject='+@Subject
end
if @MemberName is not null
begin
SET @strwhere=' and '+@strwhere+'MemberName='+@MemberName
end
if @AddedDate is not null
begin
SET @strwhere=' and '+@strwhere+'AddedDate='+@AddedDate
end
SELECT TopicID, Subject, AddedDate, TopicReplies, TopicLastReplyDate, TopicLastPostDate, MemberID, MemberName, Email, ShowEmail
FROM v_Forums_Topics WHERE @strwhere ORDER BY TopicLastPostDate Desc
GO
解析抱错:在关键字 'ORDER' 附近有语法错误。
请问那么如何根据传进来的变量,实现动态得到where语句?