国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

sql 存儲過程分頁

2024-07-21 02:33:25
字體:
來源:轉載
供稿:網友
    CREATE PROC myx_prPageRecordset
    @queryStr nvarchar(1000),
    @keyField nvarchar (200),
    @pageSize int,
    @pageNumber int
    AS
    BEGIN
    DECLARE @sqlText AS nvarchar(4000)
    DECLARE @sqlTable AS nvarchar(4000)
    SET @sqlTable = 'SELECT TOP ' + CAST((@pageNumber + 1) * @pageSize AS varchar(30)) + ' ' + @queryStr
    SET @sqlText =
    'SELECT TOP ' + CAST(@pageSize AS varchar(30)) + ' * ' +
    'FROM (' + @sqlTable + ') AS tableA ' +
    'WHERE ' + @keyField + ' NOT IN(SELECT TOP ' +
    CAST(@pageNumber * @pageSize AS varchar(30)) + ' ' + @keyField +
    ' FROM (' + @sqlTable + ') AS tableB)'
    EXEC (@sqlText)
    END    GO    核心代碼
    Dim strsql As String
    myComm = New SqlClient.SqlCommand("myx_prPageRecordset", myConn)
    myComm.CommandType = CommandType.StoredProcedure
    myComm.Parameters.Add(New SqlClient.SqlParameter("@queryStr", SqlDBType.NVarChar, 1000))
    myComm.Parameters("@queryStr").Value = " * from tbpage order by id DESC"
    myComm.Parameters.Add(New SqlClient.SqlParameter("@keyField", SqlDbType.NVarChar, 200))
    myComm.Parameters("@keyField").Value = "[id]"
    myComm.Parameters.Add(New SqlClient.SqlParameter("@pageSize", SqlDbType.NVarChar, 1000))
    myComm.Parameters("@pageSize").Value = PageSize
    myComm.Parameters.Add(New SqlClient.SqlParameter("@pageNumber", SqlDbType.NVarChar, 1000))
    myComm.Parameters("@pageNumber").Value = myPage - 1    呵呵,執行幾W條的代碼只需150毫秒左右    建立一個test(id,name,fid)    向test添充幾十條數據,使id=1,2,3,4.........(即遞增的integer),其他任意在T-sql Debugger給改存儲過程分別傳遞如下參數:    @queryStr= * from test
    @keyField=[ID]
    @pageSize=3
    @pageNumber=1    問題出來了,看輸出結果(注重id):
    id name fid
    4 kwklover 2
    5 kwklover 2
    6 kwklover 2    根據傳入參數,我們的預期應該是:
    id name fid
    1 kwklover 2
    2 kwklover 2
    3 kwklover 2
    下面是我參照小春的存儲分頁寫的分頁存儲過程,可以解決上面的問題:
    CREATE Procedure prGetRecordByPage
    (
    @PageSize int, --每頁的記錄條數
    @PageNumber int, --當前頁面
    @QuerySql varchar(1000),--部分查詢字符串,如* From Test order by id desc
    @KeyField varchar(500)
    )
    AS
    Begin    Declare @SqlTable AS varchar(1000)
    Declare @SqlText AS Varchar(1000)    Set @SqlTable='Select Top '+CAST(@PageNumber*@PageSize AS varchar(30))+' '+@QuerySql
    Set @SqlText='Select Top '+Cast(@PageSize AS varchar(30))+' * From '
    +'('+@SqlTable+') As TembTbA '
    +'Where '+@KeyField+' Not In (Select Top '+CAST((@PageNumber-1)*@PageSize AS varchar(30))+' '+@KeyField+' From '
    +'('+@SqlTable+') AS TempTbB)'
    Exec(@SqlText)    End
    GO

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 海淀区| 屏南县| 桂阳县| 嘉峪关市| 华坪县| 永仁县| 社旗县| 水城县| 玛沁县| 潢川县| 南华县| 海林市| 兴宁市| 德保县| 合川市| 苏尼特左旗| 汉川市| 银川市| 五台县| 莱西市| 北安市| 开江县| 庆城县| 张掖市| 平顶山市| 东平县| 阜城县| 沾化县| 塔城市| 龙口市| 四会市| 玛纳斯县| 开鲁县| 靖宇县| 池州市| 滨海县| 普洱| 淄博市| 天等县| 沈阳市| 屯昌县|