首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

存储过程返回值,100分请问

2012-02-02 
存储过程返回值,100分请教CREATEprocedurewww_User.SelectNews@tblnamevarchar(255),--表名@strgetfieldsv

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

热点排行