随笔 - 3  文章 - 0 评论 - 62 trackbacks - 11
<2009年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

与我联系

搜索

 

常用链接

留言簿

我参与的团队

随笔档案

最新评论

阅读排行榜

评论排行榜

--/*-----存储过程 分页处理 孙伟 2005-03-28创建 -------*/
--
/*----- 对数据进行了2分处理使查询前半部分数据与查询后半部分数据性能相同 -------*/
--
/*-----存储过程 分页处理 孙伟 2005-04-21修改 添加Distinct查询功能-------*/
--
/*-----存储过程 分页处理 孙伟 2005-05-18修改 多字段排序规则问题-------*/
--
/*-----存储过程 分页处理 孙伟 2005-06-15修改 多字段排序修改-------*/
--
/*-----存储过程 分页处理 孙伟 2005-12-13修改 修改数据分页方式为top max模式 性能有极大提高-------*/
--
/*-----缺点:相对之前的not in版本主键只能是整型字段,如主键为GUID类型请使用not in 模式的版本-------*/
CREATE PROCEDURE dbo.proc_ListPageInt
(
@tblName     nvarchar(200),        ----要显示的表或多个表的连接
@fldName     nvarchar(500= '*',    ----要显示的字段列表
@pageSize    int = 10,        ----每页显示的记录个数
@page        int = 1,        ----要显示那一页的记录
@pageCount    int = 1 output,            ----查询结果分页后的总页数
@Counts    int = 1 output,                ----查询到的记录数
@fldSort    nvarchar(200= null,    ----排序字段列表或条件
@Sort        bit = 0,        ----排序方法,0为升序,1为降序(如果是多字段排列Sort指代最后一个排序字段的排列顺序(最后一个排序字段不加排序标记)--程序传参如:' SortA Asc,SortB Desc,SortC ')
@strCondition    nvarchar(1000= null,    ----查询条件,不需where
@ID        nvarchar(150),        ----主表的主键
@Dist                 bit = 0           ----是否添加查询字段的 DISTINCT 默认0不添加/1添加
)
AS
SET NOCOUNT ON
Declare @sqlTmp nvarchar(1000)        ----存放动态生成的SQL语句
Declare @strTmp nvarchar(1000)        ----存放取得查询结果总数的查询语句
Declare @strID     nvarchar(1000)        ----存放取得查询开头或结尾ID的查询语句

Declare @strSortType nvarchar(10)    ----数据排序规则A
Declare @strFSortType nvarchar(10)    ----数据排序规则B

Declare @SqlSelect nvarchar(50)         ----对含有DISTINCT的查询进行SQL构造
Declare @SqlCounts nvarchar(50)          ----对含有DISTINCT的总数查询进行SQL构造


if @Dist  = 0
begin
    
set @SqlSelect = 'select '
    
set @SqlCounts = 'Count(*)'
end
else
begin
    
set @SqlSelect = 'select distinct '
    
set @SqlCounts = 'Count(DISTINCT '+@ID+')'
end


if @Sort=0
begin
    
set @strFSortType=' ASC '
    
set @strSortType=' DESC '
end
else
begin
    
set @strFSortType=' DESC '
    
set @strSortType=' ASC '
end



--------生成查询语句--------
--
此处@strTmp为取得查询结果数量的语句
if @strCondition is null or @strCondition=''     --没有设置显示条件
begin
    
set @sqlTmp =  @fldName + ' From ' + @tblName
    
set @strTmp = @SqlSelect+' @Counts='+@SqlCounts+' FROM '+@tblName
    
set @strID = ' From ' + @tblName
end
else
begin
    
set @sqlTmp = + @fldName + 'From ' + @tblName + ' where (1>0) ' + @strCondition
    
set @strTmp = @SqlSelect+' @Counts='+@SqlCounts+' FROM '+@tblName + ' where (1>0) ' + @strCondition
    
set @strID = ' From ' + @tblName + ' where (1>0) ' + @strCondition
end

----取得查询结果总数量-----
exec sp_executesql @strTmp,N'@Counts int out ',@Counts out
declare @tmpCounts int
if @Counts = 0
    
set @tmpCounts = 1
else
    
set @tmpCounts = @Counts

    
--取得分页总数
    set @pageCount=(@tmpCounts+@pageSize-1)/@pageSize

    
/**当前页大于总页数 取最后一页**/
    
if @page>@pageCount
        
set @page=@pageCount

    
--/*-----数据分页2分处理-------*/
    declare @pageIndex int --总数/页大小
    declare @lastcount int --总数%页大小 

    
set @pageIndex = @tmpCounts/@pageSize
    
set @lastcount = @tmpCounts%@pageSize
    
if @lastcount > 0
        
set @pageIndex = @pageIndex + 1
    
else
        
set @lastcount = @pagesize

    
--//***显示分页
    if @strCondition is null or @strCondition=''     --没有设置显示条件
    begin
        
if @pageIndex<2 or @page<=@pageIndex / 2 + @pageIndex % 2   --前半部分数据处理
            begin 
                
if @page=1
                    
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName                        
                        
+' order by '+ @fldSort +' '+ @strFSortType
                
else
                
begin                    
                    
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' where '+@ID+' <(select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1as Varchar(20)) +' '+ @ID +' from '+@tblName
                        
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
                        
+' order by '+ @fldSort +' '+ @strFSortType
                
end    
            
end
        
else
            
begin
            
set @page = @pageIndex-@page+1 --后半部分数据处理
                if @page <= 1 --最后一页数据显示                
                    set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@lastcount as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType 
                
else
                    
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' where '+@ID+' >(select max('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
                        
+' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
                        
+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType 
            
end
    
end

    
else --有查询条件
    begin
        
if @pageIndex<2 or @page<=@pageIndex / 2 + @pageIndex % 2   --前半部分数据处理
        begin
                
if @page=1
                    
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName                        
                        
+' where 1=1 ' + @strCondition + ' order by '+ @fldSort +' '+ @strFSortType
                
else
                
begin                    
                    
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' where '+@ID+' <(select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1as Varchar(20)) +' '+ @ID +' from '+@tblName
                        
+' where (1=1) ' + @strCondition +' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
                        
+' '+ @strCondition +' order by '+ @fldSort +' '+ @strFSortType
                
end            
        
end
        
else
        
begin 
            
set @page = @pageIndex-@page+1 --后半部分数据处理
            if @page <= 1 --最后一页数据显示
                    set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@lastcount as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' where (1=1) '+ @strCondition +' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType                     
            
else
                    
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
                        
+' where '+@ID+' >(select max('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
                        
+' where (1=1) '+ @strCondition +' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
                        
+' '+ @strCondition+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType                
        
end    
    
end

------返回查询结果-----
exec sp_executesql @strTmp
--print @strTmp
SET NOCOUNT OFF
GO

调用方法列子:
/// <summary>
    
/// 通用分页数据读取函数 
    
/// 注意:在函数调用外部打开和关闭连接,以及关闭数据读取器
    
/// </summary>
    
/// <param name="comm">SqlCommand对象</param>
    
/// <param name="_tblName">查询的表/表联合</param>
    
/// <param name="_fldName">要查询的字段名</param>
    
/// <param name="_pageSize">每页数据大小</param>
    
/// <param name="_page">当前第几页</param>
    
/// <param name="_fldSort">排序字段</param>
    
/// <param name="_Sort">排序顺序0降序1升序</param>
    
/// <param name="_strCondition">过滤条件</param>
    
/// <param name="_ID">主表主键</param>        
    
/// <param name="_dr">返回的SqlDataReader ref</param>

    public static void CutPageData(SqlConnection conn, ref SqlCommand comm, string _tblName, string _fldName, int _pageSize, int _page, string _fldSort, int _Sort, string _strCondition, string _ID, ref SqlDataReader _dr)
    
{
        
//注意:在函数调用外部打开和关闭连接,以及关闭数据读取器
        
//comm = new SqlCommand("proc_ListPage",conn);
        
//comm.CommandType = CommandType.StoredProcedure;
        comm.Parameters.Add("@tblName", SqlDbType.NVarChar, 200);
        comm.Parameters[
"@tblName"].Value = _tblName;
        comm.Parameters.Add(
"@fldName", SqlDbType.NVarChar, 500);
        comm.Parameters[
"@fldName"].Value = _fldName;
        comm.Parameters.Add(
"@pageSize", SqlDbType.Int);
        comm.Parameters[
"@pageSize"].Value = _pageSize;
        comm.Parameters.Add(
"@page", SqlDbType.Int);
        comm.Parameters[
"@page"].Value = _page;
        comm.Parameters.Add(
"@fldSort", SqlDbType.NVarChar, 200);
        comm.Parameters[
"@fldSort"].Value = _fldSort;
        comm.Parameters.Add(
"@Sort", SqlDbType.Bit);
        comm.Parameters[
"@Sort"].Value = _Sort;
        comm.Parameters.Add(
"@strCondition", SqlDbType.NVarChar, 1000);
        comm.Parameters[
"@strCondition"].Value = _strCondition;
        comm.Parameters.Add(
"@ID", SqlDbType.NVarChar, 150);
        comm.Parameters[
"@ID"].Value = _ID;
        comm.Parameters.Add(
"@Counts", SqlDbType.Int, 0);
        comm.Parameters[
"@Counts"].Direction = ParameterDirection.Output;
        comm.Parameters.Add(
"@pageCount", SqlDbType.Int, 0);
        comm.Parameters[
"@pageCount"].Direction = ParameterDirection.Output;

        _dr 
= comm.ExecuteReader();
    }

调用例如:
CutPageData(conn, ref comm, "VOX_CDSinger", "id, cdsinger, cdsingertype, area, cdsingerreadme", 15, page, "id", 1, strFilter, "id", ref dr);
对应说明:
CutPageData(数据连接对象, ref Sqlcommand对象, "需要表或视图名称", "要查询的字段", 每页读取数据条数, 当前页, "排序字段可多字段如(addtime desc, visitcounts注意这里最后一个字段不加desc或asc 最后一个字段对应于后面的排序规则)", 排序方式(1 desc 0 asc), where条件(这里不再添加where条件添加如:' and visitcounts>100'), 表主键, ref 返回的SqlDataReader对象);

这里的调用同样适用于之前的not in版本.


呵呵 这里献给大家 圣诞快乐 !
posted on 2005-12-21 09:48 New InterFace 阅读(3960) 评论(51)  编辑 收藏 网摘

FeedBack:
#1楼 2005-12-21 09:55 THIN      
我习惯用游标,有时间好好看看你的代码,学习学习……
  回复  引用  查看    
#2楼 2005-12-21 09:59 Chark      
好东西自然要分享, 一会在细看.
  回复  引用  查看    
#3楼 2005-12-21 10:11 小君[未注册用户]
收下先,有时间细细看
  回复  引用    
#4楼 2005-12-21 10:24 vivien      
不错
  回复  引用  查看    
不知道要来做啥
  回复  引用    
#6楼 2005-12-21 11:03 SF[未注册用户]
要是ID不是 int/bigint 类型的怎么办?
  回复  引用    
#8楼 2005-12-21 13:09 shuhill[未注册用户]
好东西,先收了,再仔细看。
  回复  引用    
#9楼 2005-12-21 14:46 sunw.net      
还可以.
试过了.四十多万条记录分页速度很快. 但是输出参数 @Counts,@pageCounts 无法取得,问题会在哪里?

  回复  引用  查看    
#10楼 2005-12-21 15:05 一滴水      
收下:)
  回复  引用  查看    
大哥,你这满屏幕的代码看得晕死人的
  回复  引用  查看    
试过了.四十多万条记录分页速度很快. 但是输出参数 @Counts,@pageCounts 无法取得,问题会在哪里?

你是怎么调用的 代码写出来看

  回复  引用    
#13楼 2005-12-21 16:03 sunw.net      
代码是这样写的:
public static void CutPageData(string _tblName, string _fldName, int _pageSize, int _page, string _fldSort, int _Sort, string _strCondition, string _ID, out SqlDataReader _dr,out int counts,out int pageCounts)
{
SqlDataProvider db = new SqlDataProvider();

SqlParameter[] prams =
{
db.MakeInParam("@tblName", SqlDbType.NVarChar, 200,_tblName),
db.MakeInParam("@fldName", SqlDbType.NVarChar, 500,_fldName),
db.MakeInParam("@pageSize", SqlDbType.Int,4,_pageSize),
db.MakeInParam("@page", SqlDbType.Int,4,_page),
db.MakeInParam("@fldSort", SqlDbType.NVarChar, 200,_fldSort),
db.MakeInParam("@Sort", SqlDbType.Bit,4,_Sort),
db.MakeInParam("@strCondition", SqlDbType.NVarChar, 1000,_strCondition),
db.MakeInParam("@ID", SqlDbType.NVarChar, 150,_ID),
db.MakeOutParam("@Counts",SqlDbType.Int,4),
db.MakeOutParam("@pageCount", SqlDbType.Int, 4),
};

db.RunProc("proc_ListPageInt",prams,out _dr);
counts = Convert.ToInt32(prams[8].Value);
pageCounts =Convert.ToInt32(prams[9].Value);
}

关于:SqlDataProvider 是自己写的一个SQL数据库通用访问类. 上面方法中
_dr 有值,而out int counts,out int pageCounts 取不到值

  回复  引用  查看    
你这里
只是执行了存储过程
存储过程中的返回值
应该再你 的 dr 读取器 调用以后
dr.Read()
才可以取到

  回复  引用    
我之前的函数也是因为这个原因
第2个参数才使用 ref SqlCommand comm
而并没有直接在里面声明SqlCommand
你可以看到我的调用函数 注释掉的部分

函数的外面 在取返回值

  回复  引用    
#16楼 2005-12-21 17:47 雨玲珑      
能调用存储过程么
  回复  引用  查看    
你去CSDN查一下,早就有了
  回复  引用    
你去CSDN查一下,早就有了

还请给个连接!
csdn 我所知道的 网上所有的
只是 not in top max 游标 等 顺序查询

我是在这个基础上 增加了 数据 2分处理
数据相对与非2分处理 在读取后半段数据时候快的一倍。



  回复  引用    
#19楼 2005-12-22 16:01 小残      
既然是拼凑SQL语句,何不交给.Net去做,.Net下的字符处理要比SQL来得有效率吧。写起来,看起来,用起来都比较舒适。
  回复  引用  查看    
#20楼 2005-12-22 21:05 upto      
楼主~我建议你将它封装为一个类~更通用~
其实用连接池的时候, 嵌入SQL语句的效率并不会差.
你现在在SQL Server里面拼字符串效率是一个问题

  回复  引用  查看    
恩。。
多谢提醒。。。
找个空闲时间准备封装看看

  回复  引用    
#22楼 2006-01-20 10:48 Jamedy      
不知道兄台这句是怎么理解的
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' <(select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' order by '+ @fldSort +' '+ @strFSortType
end

  回复  引用  查看    
#23楼 2006-03-07 10:24 Jwin      
我采用这个分页
怎么中间的页取不到数据?
如:page=1&Size=100可以看到全部数据
page=3&Size=10或者page=4&Size=10就没有数据
但是在page=7&Size=10又有数据库了
为什么

  回复  引用  查看    
把你的调用数据程序贴出来看看
  回复  引用  查看    
#25楼 2006-04-04 16:58 AlphaWu      
有用ASP。NET调用的例子么??
  回复  引用  查看    
#26楼 2006-05-30 13:23 ξσ Dicky σξ      
不错
  回复  引用  查看    
我现在好期待,急需中

QQ267827

  回复  引用    
请问现这个好代码封成类了吗?

我现在好期待,急需中

QQ267827

  回复  引用    
这个支持多表查询吗?
  回复  引用  查看    
#30楼 2006-08-24 23:44 e旋风      
好像有问题,我11行数据,每页显示5笔

第一页有5条OK
第二页只有4条,丢了一条
第三页1条,OK

查看了下点第二页时产生的DataSet,记录总数是4条,还有一条不知道哪去了


但是我设置成每页显示6笔

第一页有6条,OK
第二页有5条,OK

这个又是正常的!!!


设置成每页显示3笔

也是正常的!!!

奇怪了!!!!!!!!!!

我的QQ: 84993908 EMAIL: xiangzi@gmail.com

我现在在用你的这个做分页,期待你的回答 ,谢谢

代码如下

/// <summary>
/// 通用分页数据读取函数
/// 注意:使用Credit.Lqw.Data.BaseDA类不需关心连接打开和关闭(数据读取器除外)
/// </summary>
/// <param name="_tblName">要显示的表或多个表的连接</param>
/// <param name="_fldName">要显示的字段列表(例:BH,MC,GG,DW,JG,JGLX,FBSJ,PP,LY,BZ)</param>
/// <param name="_pageSize">每页显示的记录数</param>
/// <param name="_page">当前第几页</param>
/// <param name="_fldSort">排序字段列表或条件</param>
/// <param name="_Sort">排序字段可多字段如(addtime desc, visitcounts注意这里最后一个字段不加desc或asc 最后一个字段对应于后面的排序规则)"</param>
/// <param name="_strCondition">查询条件,不需where</param>
/// <param name="_ID">主表的主键</param>
/// <returns></returns>
public DataSet ListPage(string _tblName,string _fldName,int _pageSize,int _page,string _fldSort,int _Sort,string _strCondition,string _ID)
{
SqlParameter[] arrPara = new SqlParameter[10];

arrPara[0] = new SqlParameter( "@tblName",SqlDbType.NVarChar,200); //要显示的表或多个表的连接
arrPara[0].Value = _tblName;

arrPara[1] = new SqlParameter( "@fldName",SqlDbType.NVarChar,500); //要显示的字段列表
arrPara[1].Value = _fldName;

arrPara[2] = new SqlParameter( "@pageSize",SqlDbType.Int); //每页显示的记录数
arrPara[2].Value = _pageSize;

arrPara[3] = new SqlParameter( "@page",SqlDbType.Int); //当前第几页
arrPara[3].Value = _page;

arrPara[4] = new SqlParameter( "@fldSort",SqlDbType.NVarChar,200); //排序字段列表或条件
arrPara[4].Value = _fldSort;

arrPara[5] = new SqlParameter( "@Sort",SqlDbType.Bit); //排序方法,0为升序,1为降序
arrPara[5].Value = _Sort;

arrPara[6] = new SqlParameter( "@strCondition",SqlDbType.NVarChar,1000); //查询条件,不需where
arrPara[6].Value = _strCondition ;

arrPara[7] = new SqlParameter( "@ID",SqlDbType.NVarChar,150); //主表的主键
arrPara[7].Value = _ID;

arrPara[8] = new SqlParameter( "@pageCount",SqlDbType.Int); //查询结果分页后的总页数(输出参数)
arrPara[8].Direction = ParameterDirection.Output;
arrPara[8].Value = -1;

arrPara[9] = new SqlParameter( "@Counts",SqlDbType.Int); //记录总数(输出参数)
arrPara[9].Direction = ParameterDirection.Output;
arrPara[9].Value = -1;

DataSet DSListPage = BaseDA.ExecuteDataSet(CommandType.StoredProcedure,"CCIC_ListPageInt_SP",arrPara);
pageCountTotal= Convert.ToInt32(arrPara[8].Value);
countsTotal=Convert.ToInt32(arrPara[9].Value);

return DSListPage;
}

  回复  引用  查看    
#31楼 2006-08-27 01:09 e旋风      
楼主我又来提意见了

我换用了你 2005-6-15 (存储过程 分页处理 孙伟 2005-06-15修改 多字段排序修改)

这个版本后


因为我是参考了这个帖子
http://community.csdn.net/Expert/topic/4700/4700485.xml?temp=.4185907">http://community.csdn.net/Expert/topic/4700/4700485.xml?temp=.4185907

我把最后那个贴你代码的存储过程修改到我的系统里,数据就显示正常了


我的QQ: 84993908
MSN:xiangzi@live.com
Email:xiangzi@gmail.com
欢迎交流!!

  回复  引用  查看    
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' <(select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' order by '+ @fldSort +' '+ @strFSortType

这里怕是对非主键排序字段会有问题

  回复  引用    
#33楼 2007-01-02 17:37 whfyc[未注册用户]
我也无法取得存储过程的返回值阿!!
代码是这样写的:
public static void CutPageData(string _tblName, string _fldName, int _pageSize, int _page, string _fldSort, int _Sort, string _strCondition, string _ID, out SqlDataReader _dr,out int counts,out int pageCounts)
{
SqlDataProvider db = new SqlDataProvider();

SqlParameter[] prams =
{
db.MakeInParam("@tblName", SqlDbType.NVarChar, 200,_tblName),
db.MakeInParam("@fldName", SqlDbType.NVarChar, 500,_fldName),
db.MakeInParam("@pageSize", SqlDbType.Int,4,_pageSize),
db.MakeInParam("@page", SqlDbType.Int,4,_page),
db.MakeInParam("@fldSort", SqlDbType.NVarChar, 200,_fldSort),
db.MakeInParam("@Sort", SqlDbType.Bit,4,_Sort),
db.MakeInParam("@strCondition", SqlDbType.NVarChar, 1000,_strCondition),
db.MakeInParam("@ID", SqlDbType.NVarChar, 150,_ID),
db.MakeOutParam("@Counts",SqlDbType.Int,4),
db.MakeOutParam("@pageCount", SqlDbType.Int, 4),
};

db.RunProc("proc_ListPageInt",prams,out _dr);
counts = Convert.ToInt32(prams[8].Value);
pageCounts =Convert.ToInt32(prams[9].Value);
}

关于:SqlDataProvider 是自己写的一个SQL数据库通用访问类. 上面方法中
_dr 有值,而out int counts,out int pageCounts 取不到值

  回复  引用    
#34楼 2007-01-29 16:10 王[未注册用户]
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' <(select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' order by '+ @fldSort +' '+ @strFSortType
end

这段是什么意思,不明白
用主键排序,如果sort=0,只有第1页有数据,第2页和以后的都没有数据,不知道什么原因

  回复  引用    
#35楼 2007-04-13 10:05 84ww[未注册用户]
我用的时候怎么取不到中间页码的数据啊,
只能取到第一页,最后一页的数据

  回复  引用    
#36楼 2007-08-13 21:34 JESH[未注册用户]
楼主,取不到中间的页啊, 之前的not in版本倒是没有问题, 请问是什么原因呢?
  回复  引用    
#37楼 2007-11-06 11:21 安东[未注册用户]
测试中提示服务器: 消息 8114,级别 16,状态 4,过程 proc_ListPageInt,行 0
将数据类型 nvarchar 转换为 int 时出错。


proc_ListPageInt [Job_Base],'*',100,100,lastupdate_time,0,lastupdate_time,jobid,0

jobid是主键且为int

我用如下语句查看 jobid的数据类型

select column_name,data_type from information_schema.columns
where table_name = 'Job_Base'
结果:
column_name,data_type
JobId int

不知道到底那里除了问题,请指教,在线等

  回复  引用    
#38楼 2007-11-30 11:18 没剑      
楼主,我试用了下你的这个存储过程,速度还不错!!!
不过select top ***这个的话是不是对你这个存储过程有限制啊?
如果是有上1000W数据的话,哪么是不是select top N id from table
这里的N至少也上了100W了吧?。。。呵呵,我这个是极端想法,哈哈

  回复  引用  查看    
#39楼 2007-12-04 13:52 没剑      
楼主,找到个bug,如果是多字段排序你这个分页结果出来是错的...
如:order by bigcatid desc,smallcatid desc,id desc
如果真实数据排序为:
bigcatid smallcatid id
5 5 5
5 5 4
4 4 6
一页显示一条数据,哪么在第三页时的SQL句为:
SELECT TOP 1 * FROM table WHERE ID <
(SELECT MIN(ID) FROM (
SELECT TOP 2 ID FROM table ORDER BY bigcatid desc,smallcatid desc,ID DESC) AS TBMinID
) ORDER BY bigcatid desc,smallcatid desc,ID DESC
--
上面的:
SELECT TOP 2 ID FROM table ORDER BY bigcatid desc,smallcatid desc,ID DESC
取得数据ID是:5,4这两条
哪么:(SELECT MIN(ID) FROM (
SELECT TOP 2 ID FROM table ORDER BY bigcatid desc,smallcatid desc,ID DESC) AS TBMinID
返回:4
哪么:SELECT TOP 1 * FROM table WHERE ID <4 order by...
哪么第三页的结果当然就不会是ID为6的哪条咯~~~
口黑口黑~


  回复  引用  查看    
#40楼 2007-12-28 16:50 qwqwq[未注册用户]
楼主可以给我个实例吗?急着用的!!
  回复  引用    
#41楼 2007-12-29 17:37 qqq[未注册用户]
为什么多表查询时到第二页就出错!!帮忙解决一下!!
  回复  引用    
#42楼 2008-04-17 23:39 84ww[未注册用户]
楼主,你这个存储过程取数据好像得不到正确结果,有些干脆就不出来,我是直接在查询分析器里执行的,我觉得 top max 这个原理好像不能达到分页目的吧?能不能简单讲解下?
  回复  引用    
#43楼 2008-04-28 00:04 启程      
楼主,你这个存储过程取数据好像得不到正确结果,有些干脆就不出来,我是直接在查询分析器里执行的,我觉得 top max 这个原理好像不能达到分页目的吧?能不能简单讲解下?
  回复  引用  查看    
#44楼 2008-06-24 15:55 啊 海[未注册用户]
晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死晕死

网上大量流传你这个代码,原以为没有问题的,直接拿来就改了用了,改后测试才发觉,数据相差十万八千里。

我以为我改错了,把你的源码原封不动来测试,还是相差十万八千里。

是我的错,不应该随便拿来就用。

  回复  引用    
#45楼 2008-07-03 23:21 double[未注册用户]
错了
加上非主键排序
id 就乱了
凭 id> 或 id<
就错了

这种只是适合 id(主键) 排序

  回复  引用    
#46楼 2008-08-14 14:48 qqqq[未注册用户]
根本不支多字段排序的!!无耐!!!!!!!!!!!!!!
  回复  引用    
#47楼 2008-08-14 15:31 qqqq[未注册用户]
--引用--------------------------------------------------
qqqq: 根本不支多字段排序的!!无耐!!!!!!!!!!!!!!
--------------------------------------------------------

不好意思!!是可以支持的!!

  回复  引用    



发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 301327




相关文章:

相关链接: