存储过程返回值,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