好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

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

SQL通用存儲過程分頁,支持多表聯合

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

ALTER proc [dbo].[SqlPager]
(
@tblName varchar(255), -- 表名(注意:可以多表鏈接)
@strGetFields varchar(1000) = '*', -- 需要返回的列
@OrderfldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 頁尺寸
@PageIndex int = 1, -- 頁碼
@doCount int = 1 output, --查詢到的記錄數
@OrderType bit = 0, -- 設置排序類型, 非 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,就執行總數統計。以下的所有代碼都是@doCount為0的情況
set @strSQL='';

if @OrderType != 0
begin
set @strTmp = '(select min'
set @strOrder = ' order by [' + @OrderfldName +'] desc'--如果@OrderType不是0,就執行降序,這句很重要!
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--如果是第一頁就執行以上代碼,這樣會加快執行速度
end
else
begin--以下代碼賦予了@strSQL以真正執行的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類中寫執行存儲過程 這是我的數據庫操作類.方法有點老,還是三層架構.(mvc也應該差不多.我還木有試試.)
復制代碼 代碼如下:

/// summary>
/// 分頁(存儲過程) 用法例如下:
/// /summary>
/// param>表名(注意:可以多表鏈接)/param>
/// param>需要返回的列/param>
/// param>主鍵/param>
/// param>排序的字段名/param>
/// param>頁尺寸/param>
/// param>頁碼/param>
/// param>查詢到的記錄數/param>
/// param>設置排序類型, 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通用分頁存儲過程及多表聯接應用
  • MSSQL MySQL 數據庫分頁(存儲過程)
  • 三種SQL分頁查詢的存儲過程代碼
  • SQL分頁查詢存儲過程代碼分享

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

巨人網絡通訊聲明:本文標題《SQL通用存儲過程分頁,支持多表聯合》,本文關鍵詞  SQL,通用,存儲,過程,分頁,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL通用存儲過程分頁,支持多表聯合》相關的同類信息!
  • 本頁收集關于SQL通用存儲過程分頁,支持多表聯合的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 攻当着受面被C| 久久精品视频亚洲| 韩国高清色www在线播放| 精品美女一区二区三区| 三国同人h文啪啪高黄| 狼人香蕉国产在线视频| 欧美中文字幕在线播放| 国模冰莲?私拍03| 亚洲综合久久一本伊伊区| 哒哒哒视频在线观看高清免费| 好男人的资源在线| Free???国产video| 久久精品精品| 朋友人妻翘臀迎接粗大撞击| 500部大龄熟乱视频| 欧美视频区| 免费无码国产精品一区| 杂乱小说目录阅读免费下载| 特级做a爰片毛片免费看一区| gogogo韩国线播放免费观看| 久欠精品国国产99国产精2021的功能介绍 | 周慧敏凸点三级视频| 免费看黄的视频软件| 精品国产免费久久久久久婷婷| 四川一级少妇A片免费| 日韩 人妻 精品 无码 制服 | 老太高潮一级毛片免费水大的 | 中国大陆最新毛片免费看| 老色鬼精品无码一区二区| 第一版主H精品辣文| 操女穴| 国产精品18久久久久久欧美网址| 波多野结衣之痴汉电车| 精品欧美一区二区三区成人片在线 | 一区二区三区四区在线播放| 第1章饱满的乳峰喷奶水| ??免费吃奶摸下激烈| 芒果视频?成人app?ios| 美女乳房视频| 韩国一级做a爱性色毛片| 附近学生约100三小时|