但是有利也有弊,它要求排序字段必須構成唯一記錄,且select后的字段列表中,不允許出現與排序字段同名的字段。
雖然sql2k5及以上版本已經提供了rownum()來進行分頁處理,但是使用sql2k進行開發的還是較多的
int index = arrstrorders[i].indexof(" "); //判斷是否有升降標識
if (index > 0)
{
//替換升降標識,分頁所需
bool flag = arrstrorders[i].indexof(" desc", stringcomparison.ordinalignorecase) != -1;
sbreverseorder.appendformat("{0} {1}", arrstrorders[i].remove(index), flag ? "asc" : "desc");
}
else
{
sbreverseorder.appendformat("{0} desc", arrstrorders[i]);
}
}
//計算總頁數
_pagesize = _pagesize == 0 ? _recordcount : _pagesize;
int pagecount = (_recordcount + _pagesize - 1) / _pagesize;
//檢查當前頁數
if (_pageindex 1)
{
_pageindex = 1;
}
else if (_pageindex > pagecount)
{
_pageindex = pagecount;
}
stringbuilder sbsql = new stringbuilder();
//第一頁時,直接使用top n,而不進行分頁查詢
if (_pageindex == 1)
{
sbsql.appendformat(" select top {0} * ", _pagesize);
sbsql.appendformat(" from ({0}) as t ", _safesql);
sbsql.appendformat(" order by {0} ", sboriginalorder.tostring());
}
//最后一頁時,減少一個top n
else if (_pageindex == pagecount)
{
sbsql.append(" select * from ");
sbsql.append(" ( ");
sbsql.appendformat(" select top {0} * ", _recordcount - _pagesize * (_pageindex - 1));
sbsql.appendformat(" from ({0}) as t ", _safesql);
sbsql.appendformat(" order by {0} ", sbreverseorder.tostring());
sbsql.append(" ) as t ");
sbsql.appendformat(" order by {0} ", sboriginalorder.tostring());
}
//前半頁數時的分頁
else if (_pageindex (pagecount / 2 + pagecount % 2))
{
sbsql.append(" select * from ");
sbsql.append(" ( ");
sbsql.appendformat(" select top {0} * from ", _pagesize);
sbsql.append(" ( ");
sbsql.appendformat(" select top {0} * ", _pagesize * _pageindex);
sbsql.appendformat(" from ({0}) as t ", _safesql);
sbsql.appendformat(" order by {0} ", sboriginalorder.tostring());
sbsql.append(" ) as t ");
sbsql.appendformat(" order by {0} ", sbreverseorder.tostring());
sbsql.append(" ) as t ");
sbsql.appendformat(" order by {0} ", sboriginalorder.tostring());
}
//后半頁數時的分頁
else
{
sbsql.appendformat(" select top {0} * from ", _pagesize);
sbsql.append(" ( ");
sbsql.appendformat(" select top {0} * ", ((_recordcount % _pagesize) + _pagesize * (pagecount - _pageindex)));
sbsql.appendformat(" from ({0}) as t ", _safesql);
sbsql.appendformat(" order by {0} ", sbreverseorder.tostring());
sbsql.append(" ) as t ");
sbsql.appendformat(" order by {0} ", sboriginalorder.tostring());
}
return sbsql.tostring();
}
/// summary>
/// 獲取記錄總數sql語句
/// /summary>
/// param name="_n">限定記錄數/param>
/// param name="_safesql">sql查詢語句/param>
/// returns>記錄總數sql語句/returns>
public static string createtopnsql(int _n, string _safesql)
{
return string.format(" select top {0} * from ({1}) as t ", _n, _safesql);
}
/// summary>
/// 獲取記錄總數sql語句
/// /summary>
/// param name="_safesql">sql查詢語句/param>
/// returns>記錄總數sql語句/returns>
public static string createcountingsql(string _safesql)
{
return string.format(" select count(1) as recordcount from ({0}) as t ", _safesql);
}
}
標簽:周口 預約服務 營口 湘潭 鄂爾多斯 河源 寧夏 欽州
巨人網絡通訊聲明:本文標題《淺談mssql access數據庫 top分頁方法》,本文關鍵詞 淺談,mssql,access,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。