日期:2014-05-18  浏览次数:20497 次

存储过程返回值,100分请教
CREATE   procedure   www_User.SelectNews
@tblname   varchar(255),   --   表名
@strgetfields   varchar(100)   =   "* ",   --   需要返回的列  
@fldname   varchar(255)= "   ",   --   排序的字段名
@pagesize   int   =   10,   --   页尺寸
@pageindex   int   =   1,   --   页码
@ordertype   bit   =   0,   --   设置排序类型,   非   0   值则降序
@strwhere   varchar(1000)   =   "   "--   查询条件   (注意:   不要加   where)
as   declare @strtmp   varchar(50)   --   临时变量
declare   @strsql   varchar(1000)   --   主语句
        if   @fldname   !=   "   "
if   @ordertype   !=   0   set   @strtmp   =   "   order   by   "   +   @fldname   +   "   desc "
        else   set   @strtmp   =   "   order   by   "   +   @fldname   +   "   asc "
        else   set   @strtmp   =   " "

        if   @strwhere   !=   "   "   set   @strsql   =   "select   top   "   +   cast(@pagesize   as   nvarchar(2))   +   "   "   +   @strgetfields   +   "   from   [ "   +   @tblname   +   "]   where   "   +   @strwhere   +   @strtmp
        else   set   @strsql   =   "select   top   "   +   cast(@pagesize   as   nvarchar(2))   +   "   "   +   @strgetfields   +   "   from   [ "   +   @tblname   +   "] "   +   @strtmp
GO
我的数据表中有Title,path,dt等几个字段,我想取得该表中的前边10条记录(按照dt降序排列),用上边的存储过程,在查询分析器中输入参数如下:
@tblname   =   'www_news '
@strgetfields   =   'title,path,dt '
@fldname   =   'dt '
@pagesize   =   10
@pageindex   =   1
@ordertype   =   1

运行之后没有任何返回值,只有消息中显示:返回代码   =   0

我还需要怎么改,才能得到我想要的结果?

------解决方案--------------------
光拼成了sql语句还没执行呢

存储过程最后加上 exec(@strsql)
------解决方案--------------------
declare @strtmp varchar(50) -- 临时变量
declare @strsql varchar(1000) -- 主语句
/*----------------------*/
declare @tblname varchar(100)-- = '* '
declare @strgetfields varchar(100)
declare @fldname varchar(255)--= ' '
declare @pagesize int --= 10
declare @pageindex int-- = 1
declare @ordertype bit-- = 0
declare @strwhere varchar(1000) --= ' '-- 查询条件 (注意: 不要加 where)
set @tblname= 'dbo.datable '
set @strgetfields = 'startip,endip '
set @fldname= 'city '
set @pagesize=10
set @pageindex = 1
set @ordertype=1
set @strwhere= ' '
/*----------------------*/
if @fldname != ' '
begin
if @ordertype != 0 set @strtmp = ' order by ' + @fldname + ' desc '
else set @strtmp = ' order by ' + @fldname + ' asc '
end
else set @strtmp