主頁 > 知識庫 > SQL通用存儲過程分頁,支持多表聯(lián)合

SQL通用存儲過程分頁,支持多表聯(lián)合

熱門標(biāo)簽:上海楊浦怎么申請申請400電話 山西防封卡電銷卡套餐 地圖標(biāo)注多個行程 海外地圖標(biāo)注門市標(biāo) 陜西人工外呼系統(tǒng)哪家好 銅川小型外呼系統(tǒng)運營商 云南外呼電銷機器人系統(tǒng) 廈門商鋪地圖標(biāo)注 浙江外呼系統(tǒng)怎么安裝
SQLPager存儲過程
復(fù)制代碼 代碼如下:

ALTER proc [dbo].[SqlPager]
(
@tblName varchar(255), -- 表名(注意:可以多表鏈接)
@strGetFields varchar(1000) = '*', -- 需要返回的列
@OrderfldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 頁尺寸
@PageIndex int = 1, -- 頁碼
@doCount int = 1 output, --查詢到的記錄數(shù)
@OrderType bit = 0, -- 設(shè)置排序類型, 非 0 值則降序
@strWhere varchar(500) = '' -- 查詢條件 (注意: 不要加 where)
)
AS
declare @strSQL nvarchar(4000) -- 主語句
declare @strTmp varchar(110) -- 臨時變量
declare @strOrder varchar(300) -- 排序類型

if @strWhere != ''
set @strSQL = 'select @doCount=count(*) from ' + @tblName + ' where '+@strWhere
else
set @strSQL = 'select @doCount=count(*) from ' + @tblName
exec sp_executesql @strSQL,N'@doCount int out',@doCount out
--以上代碼的意思是如果@doCount傳遞過來的不是0,就執(zhí)行總數(shù)統(tǒng)計。以下的所有代碼都是@doCount為0的情況
set @strSQL='';

if @OrderType != 0
begin
set @strTmp = '(select min'
set @strOrder = ' order by [' + @OrderfldName +'] desc'--如果@OrderType不是0,就執(zhí)行降序,這句很重要!
end
else
begin
set @strTmp = '>(select max'
set @strOrder = ' order by [' + @OrderfldName +'] 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--如果是第一頁就執(zhí)行以上代碼,這樣會加快執(zhí)行速度
end
else
begin--以下代碼賦予了@strSQL以真正執(zhí)行的SQL代碼
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from '
+ @tblName + ' where [' + @OrderfldName + ']' + @strTmp + '(['+ @OrderfldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @OrderfldName + '] from ' + @tblName + ' ' + @strOrder + ') as tblTmp)'+ @strOrder
if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ ' from '
+ @tblName + ' where [' + @OrderfldName + ']' + @strTmp + '(['
+ @OrderfldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
+ @OrderfldName + '] from ' + @tblName + ' where ' + @strWhere + ' '
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
end
exec (@strSQL)

SQLHelper類中寫執(zhí)行存儲過程 這是我的數(shù)據(jù)庫操作類.方法有點老,還是三層架構(gòu).(mvc也應(yīng)該差不多.我還木有試試.)
復(fù)制代碼 代碼如下:

/// summary>
/// 分頁(存儲過程) 用法例如下:
/// /summary>
/// param>表名(注意:可以多表鏈接)/param>
/// param>需要返回的列/param>
/// param>主鍵/param>
/// param>排序的字段名/param>
/// param>頁尺寸/param>
/// param>頁碼/param>
/// param>查詢到的記錄數(shù)/param>
/// param>設(shè)置排序類型, desc、asc/param>
/// param>查詢條件 (注意: 不要加 where)/param>
/// returns>/returns>
public static DataTable DbPager(
string tblName,
string strGetFields,
string PkeyfldName,
string OrderfldName,
int PageSize,
int PageIndex,
out int doCount,
string OrderType,
string strWhere)
{
SqlConnection con = new SqlConnection(ConnString.Value);
SqlDataAdapter da = new SqlDataAdapter("DbPager", con);
da.SelectCommand.CommandType = CommandType.StoredProcedure;
da.SelectCommand.Parameters.Add(new SqlParameter("@tblName", tblName));
da.SelectCommand.Parameters.Add(new SqlParameter("@strGetFields", strGetFields));
da.SelectCommand.Parameters.Add(new SqlParameter("@PkeyfldName", PkeyfldName));
da.SelectCommand.Parameters.Add(new SqlParameter("@OrderfldName", OrderfldName));
da.SelectCommand.Parameters.Add(new SqlParameter("@PageSize", PageSize));
da.SelectCommand.Parameters.Add(new SqlParameter("@PageIndex", PageIndex));
da.SelectCommand.Parameters.Add("@doCount", SqlDbType.Int);
da.SelectCommand.Parameters["@doCount"].Direction = ParameterDirection.Output;
da.SelectCommand.Parameters.Add(new SqlParameter("@OrderType", OrderType));
da.SelectCommand.Parameters.Add(new SqlParameter("@strWhere", strWhere));
DataSet ds = new DataSet();
da.Fill(ds);
doCount = Convert.ToInt32(da.SelectCommand.Parameters["@doCount"].Value);
return ds.Tables[0];
}
您可能感興趣的文章:
  • 五種SQL Server分頁存儲過程的方法及性能比較
  • SQL Server 分頁查詢通用存儲過程(只做分頁查詢用)
  • sqlserver2005利用臨時表和@@RowCount提高分頁查詢存儲過程性能示例分享
  • 深入sql server 2005 萬能分頁存儲過程的詳解
  • 基于Sql Server通用分頁存儲過程的解決方法
  • mssql 高效的分頁存儲過程分享
  • SQL Server 2005通用分頁存儲過程及多表聯(lián)接應(yīng)用
  • MSSQL MySQL 數(shù)據(jù)庫分頁(存儲過程)
  • 三種SQL分頁查詢的存儲過程代碼
  • SQL分頁查詢存儲過程代碼分享

標(biāo)簽:孝感 自貢 許昌 常州 信陽 朔州 萊蕪 西雙版納

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL通用存儲過程分頁,支持多表聯(lián)合》,本文關(guān)鍵詞  SQL,通用,存儲,過程,分頁,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL通用存儲過程分頁,支持多表聯(lián)合》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL通用存儲過程分頁,支持多表聯(lián)合的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章