存储过程返回值,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 = ' '
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
EXEC(@strsql)
GO
末尾应加EXEC(@strsql),还有from [ ' + @tblname + ']中如果人家输入的是dbo.tablename,这个语句就会出错了。
[解决办法]
use pub
go
create procedure 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
exec(@strsql)
GO
--调用
SelectNews 'titleauthor ', 'au_id,title_id,au_ord ', 'royaltyper ',10,1,1
-测试没有问题.
[解决办法]
可能楼主少了一个执行语句.
exec(@strsql)