在查询分析器中使用存储过程可按条件查询,一切正常,
DECLARE @return_value intEXEC @return_value = [dbo].[pagination3]
@tblName = N'View_2',
@strGetFields = N'*',
@fldName = N'id',
@PageSize = 10,
@PageIndex = 2,
@strWhere = N'typeid=1404'
id title typeid
1  aa    1404
2  bb    1404
3  cc    1404
---------------------------------------------------------
在ASP中如果不加条件一切正常
但加条件就查询不到,而且提示
ADODB.Recordset 错误 '800a0cc1' 在对应所需名称或序数的集合中,未找到项目。
________________________________________________
set recom = server.createobject("adodb.command")
recom.activeconnection = Conn
recom.commandtype = 4
recom.commandtext = "[pagination3]"
a="View_2"
b="*"
c="id"
d=10
e=2
++++++++++++++++++++++++
f="typeid=1404"
如果不加条件则正常输出数据,如果加上就报错.提示在对应所需名称或序数的集合中,未找到项目
++++++++++++++++++++++++recom.Parameters.Append recom.CreateParameter("@tblName",202,1,100,a)
recom.Parameters.Append recom.CreateParameter("@strGetFields",202,1,100,b)
recom.Parameters.Append recom.CreateParameter("@fldName",202,1,100,c)
recom.Parameters.Append recom.CreateParameter("@PageSize",202,1,100,d)
recom.Parameters.Append recom.CreateParameter("@PageIndex",202,1,100,e)
recom.Parameters.Append recom.CreateParameter("@strWhere",202,1,100,e)
set rs = recom.execute ()
if rs.eof then
set rs=nothing : set recom=nothing : Conn.Close : set Conn=nothing
response.write "无内容哦"
response.end
end ifdo while not rs.eof
response.write rs(0)&"<BR>"
response.write rs("id")&rs("title")&"||||||||||||||"&rs("typeid")&"<br>"rs.movenext
loop
set rs = rs.NextRecordset
set rs=nothing : set recom=nothing 

解决方案 »

  1.   

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    go--drop proc pagination3
    --pagination3 'customers','*','customerid',10,2
    --获取指定页的数据:ALTER PROCEDURE [dbo].[pagination3]
    @tblName varchar(255), -- 表名
    @strGetFields varchar(1000) = '*', -- 需要返回的列 
    @fldName varchar(255)='''', -- 排序的字段名
    @PageSize int = 10, -- 页尺寸
    @PageIndex int = 1, -- 页码
    @doCount bit = 0, -- 返回记录总数, 非 0 值则返回
    @OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
    @strWhere varchar(1500) = '''' -- 查询条件 (注意: 不要加 where)
    AS
    declare @strSQL varchar(5000) -- 主语句
    declare @strTmp varchar(110) -- 临时变量
    declare @strOrder varchar(400) -- 排序类型
    if @doCount != 0
    begin
    if @strWhere !=''''
    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where '+@strWhere
    else
    set @strSQL ='select count(*) as Total from [' + @tblName + ']'
    end 
    --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况:
    else
    begin
    if @OrderType != 0
    begin
    set @strTmp = '<(select min'
    set @strOrder = ' order by [' + @fldName +'] desc'
    --如果@OrderType不是0,就执行降序,这句很重要!
    end
    else
    begin
    set @strTmp = '>(select max'
    set @strOrder = ' order by [' + @fldName +'] asc'
    end
    if @PageIndex = 1
    begin
    if @strWhere != ''''
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ 'from [' + @tblName + '] where ' + @strWhere + ' ' + @strOrder
    else
    set @strSQL ='select top '+ str(@PageSize) +' '+@strGetFields+ 'from ['+ @tblName + '] '+ @strOrder
    --如果是第一页就执行以上代码,这样会加快执行速度
    end
    else
    begin
    --以下代码赋予了@strSQL以真正执行的SQL代码
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from ['+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['+ @fldName + ']) from (select top '+ str((@PageIndex-1)*@PageSize) + ' ['+ @fldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)'+ @strOrder
    if @strWhere != ''''
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ 'from ['
    + @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
    + @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
    + @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
    + @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
    end
    end 
    exec (@strSQL)
      

  2.   

    参考: CREATE PROC proc_pageview
    @tbname     sysname,               --要分页显示的表名
    @FieldKey   nvarchar(1000),      --用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段
    @PageCurrent int=1,               --要显示的页码
    @PageSize   int=10,                --每页的大小(记录数)
    @FieldShow nvarchar(1000)='',      --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段
    @FieldOrder nvarchar(1000)='',      --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC
    @Where    varchar(1000)='',     --查询条件
    @RecordCount int OUTPUT             --总页数
    AS
    SET NOCOUNT ON
    --检查对象是否有效
    IF OBJECT_ID(@tbname) IS NULL
    BEGIN
        RAISERROR(N'对象"%s"不存在',1,16,@tbname)
        RETURN
    END
    IF OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTable')=0
        AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsView')=0
        AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTableFunction')=0
    BEGIN
        RAISERROR(N'"%s"不是表、视图或者表值函数',1,16,@tbname)
        RETURN
    END--分页字段检查
    IF ISNULL(@FieldKey,N'')=''
    BEGIN
        RAISERROR(N'分页处理需要主键(或者惟一键)',1,16)
        RETURN
    END--其他参数检查及规范
    IF ISNULL(@PageCurrent,0)<1 SET @PageCurrent=1
    IF ISNULL(@PageSize,0)<1 SET @PageSize=10
    IF ISNULL(@FieldShow,N'')=N'' SET @FieldShow=N'*'
    IF ISNULL(@FieldOrder,N'')=N''
        SET @FieldOrder=N''
    ELSE
        SET @FieldOrder=N'ORDER BY '+LTRIM(@FieldOrder)
    IF ISNULL(@Where,N'')=N''
        SET @Where=N''
    ELSE
        SET @Where=N'WHERE ('+@Where+N')'--如果@PageCount为NULL值,则计算总页数(这样设计可以只在第一次计算总页数,以后调用时,把总页数传回给存储过程,避免再次计算总页数,对于不想计算总页数的处理而言,可以给@PageCount赋值)
    IF @RecordCount IS NULL
    BEGIN
        DECLARE @sql nvarchar(4000)
        SET @sql=N'SELECT @RecordCount=COUNT(*)'
            +N' FROM '+@tbname
            +N' '+@Where
        EXEC sp_executesql @sql,N'@RecordCount int OUTPUT',@RecordCount OUTPUT
    END--计算分页显示的TOPN值
    DECLARE @TopN varchar(20),@TopN1 varchar(20)
    SELECT @TopN=@PageSize,
        @TopN1=(@PageCurrent-1)*@PageSize--第一页直接显示
    IF @PageCurrent=1
        EXEC(N'SELECT TOP '+@TopN
            +N' '+@FieldShow
            +N' FROM '+@tbname
            +N' '+@Where
            +N' '+@FieldOrder)
    ELSE
    BEGIN
        --处理别名
        IF @FieldShow=N'*'
            SET @FieldShow=N'a.*'    --生成主键(惟一键)处理条件
        DECLARE @Where1 nvarchar(4000),@Where2 nvarchar(4000),
            @s nvarchar(1000),@Field sysname
        SELECT @Where1=N'',@Where2=N'',@s=@FieldKey
        WHILE CHARINDEX(N',',@s)>0
            SELECT @Field=LEFT(@s,CHARINDEX(N',',@s)-1),
                @s=STUFF(@s,1,CHARINDEX(N',',@s),N''),
                @Where1=@Where1+N' AND a.'+@Field+N'=b.'+@Field,
                @Where2=@Where2+N' AND b.'+@Field+N' IS NULL',
                @Where=REPLACE(@Where,@Field,N'a.'+@Field),
                @FieldOrder=REPLACE(@FieldOrder,@Field,N'a.'+@Field),
                @FieldShow=REPLACE(@FieldShow,@Field,N'a.'+@Field)
        SELECT @Where=REPLACE(@Where,@s,N'a.'+@s),
            @FieldOrder=REPLACE(@FieldOrder,@s,N'a.'+@s),
            @FieldShow=REPLACE(@FieldShow,@s,N'a.'+@s),
            @Where1=STUFF(@Where1+N' AND a.'+@s+N'=b.'+@s,1,5,N''),    
            @Where2=CASE
                WHEN @Where='' THEN N'WHERE ('
                ELSE @Where+N' AND ('
                END+N'b.'+@s+N' IS NULL'+@Where2+N')'
        --执行查询
        EXEC(N'SELECT TOP '+@TopN
            +N' '+@FieldShow
            +N' FROM '+@tbname
            +N' a LEFT JOIN(SELECT TOP '+@TopN1
            +N' '+@FieldKey
            +N' FROM '+@tbname
            +N' a '+@Where
            +N' '+@FieldOrder
            +N')b ON '+@Where1
            +N' '+@Where2
            +N' '+@FieldOrder)
    END
    GO
      

  3.   

    recom.commandtext = "[proc_pageview]"
    a="View_2"
    b="id"
    c="id desc"
    d=10
    e=2
    f="typeid=1404"
    '@tbname     sysname,               --要分页显示的表名
    '@FieldKey   nvarchar(1000),      --用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段
    '@PageCurrent int=1,               --要显示的页码
    '@PageSize   int=10,                --每页的大小(记录数)
    '@FieldShow nvarchar(1000)='',      --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段
    '@FieldOrder nvarchar(1000)='',      --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC
    '@Where    varchar(1000)='',     --查询条件
    '@RecordCount int OUTPUT             --总页数
    recom.Parameters.Append recom.CreateParameter("@tbname",202,1,100,a)
    recom.Parameters.Append recom.CreateParameter("@FieldKey",202,1,100,b)
    recom.Parameters.Append recom.CreateParameter("@PageSize",202,1,100,10)
    recom.Parameters.Append recom.CreateParameter("@PageCurrent",202,1,100,1)
    recom.Parameters.Append recom.CreateParameter("@FieldOrder",202,1,100,c)
    recom.Parameters.Append recom.CreateParameter("@Where",202,1,100,f)
    recom.Parameters.Append recom.CreateParameter("@RecordCount",202,1,100,10)
    过程或函数 'proc_pageview' 需要参数 '@RecordCount',但未提供该参数。