zoukankan      html  css  js  c++  java
  • cs_forums_Posts_PostSet

    ALTER  PROCEDURE dbo.cs_forums_Posts_PostSet
    (
        
    @PostID    int,
        
    @PageIndex int,
        
    @PageSize int,
        
    @SortBy int,
        
    @SortOrder bit,
        
    @UserID int,
        
    @ReturnRecordCount bit,
        
    @AllowUnapproved bit = 0,
        
    @SettingsID int
    )
    AS
    SET Transaction Isolation Level Read UNCOMMITTED
    /*设置事务隔离级别,Read UNCOMMITTED  执行脏读或 0 级隔离锁定,这表示不发出共享锁,
      也不接受排它锁。当设置该选项时,可以对数据执行未提交读或脏读;在事务结束前可以更
      改数据内的数值,行也可以出现在数据集中或从数据集消失。该选项的作用与在事务内所有
      语句中的所有表上设置 NOLOCK 相同。这是四个隔离级别中限制最小的级别。
    */


    BEGIN

    DECLARE @PageLowerBound int
    DECLARE @PageUpperBound int
    DECLARE @ThreadID int
    DECLARE @SectionID int

    -- First set the rowcount
    --
     首先设置行数
    DECLARE @RowsToReturn int
    SET @RowsToReturn = @PageSize * (@PageIndex + 1)
    SET ROWCOUNT @RowsToReturn

    -- Set the page bounds
    --
     设置也面绑定
    SET @PageLowerBound = @PageSize * @PageIndex
    SET @PageUpperBound = @PageLowerBound + @PageSize + 1

    -- Get the ThreadID
    --
     获取主题ID
    SELECT
        
    @ThreadID = ThreadID,
        
    @SectionID = SectionID
    FROM 
        cs_Posts 
    WHERE 
        PostID 
    = @PostID and SettingsID = @SettingsID

    -- Is the Forum 0 (If so this is a private message and we need to verify the user can view it
    --
     如果是条个人消息我们要确认用户是否有权查看
    IF @SectionID = 0
    BEGIN
        
    IF NOT EXISTS (SELECT UserID FROM cs_PrivateMessages WHERE UserID = @UserID AND ThreadID = @ThreadID AND SettingsID = @SettingsID)
            
    RETURN
                 
    /*不存在此用户的ID就返回*/
    END

    -- Create a temp table to store the select results
    --
     如果不是个人消息
    CREATE TABLE #PageIndex 
    (
        IndexID 
    int IDENTITY (11NOT NULL,
        PostID 
    int
    )

    -- Sort by Post Date
    --
     按帖子日期排序
    IF @SortBy = 0 AND @SortOrder = 0
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID ORDER BY PostDate

    ELSE IF @SortBy = 0 AND @SortOrder = 1
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID  ORDER BY PostDate DESC

    -- Sort by Author
    --
     按作者ID排序
    IF @SortBy = 1 AND @SortOrder = 0
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID  ORDER BY UserID

    ELSE IF @SortBy = 1 AND @SortOrder = 1
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID  ORDER BY UserID DESC

    -- Sort by SortOrder
    --
     按排序类型排序
    IF @SortBy = 2 AND @SortOrder = 0
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID  ORDER BY SortOrder

    ELSE IF @SortBy = 2 AND @SortOrder = 1
        
    INSERT INTO #PageIndex (PostID)
        
    SELECT PostID FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID and SettingsID = @SettingsID  ORDER BY SortOrder DESC

    -- Select the individual posts
    --
     查询个人的帖子
    SELECT
        P.PostID, P.ThreadID, P.ParentID, P.PostAuthor, P.UserID, P.SectionID, P.PostLevel, P.SortOrder, P.Subject, P.PostDate, P.IsApproved,
        P.IsLocked, P.IsIndexed, P.TotalViews, P.Body, P.FormattedBody, P.IPAddress, P.PostType, P.EmoticonID, P.SettingsID, P.AggViews,
        P.PropertyNames 
    as PostPropertyNames, P.PropertyValues as PostPropertyValues,
        P.PostConfiguration, P.UserTime, P.ApplicationPostType, P.PostName,
        P.Points 
    as PostPoints, P.RatingSum as PostRatingSum, P.TotalRatings as PostTotalRatings,
        T.
    *, U.*, #PageIndex.*,
        T.IsLocked,
        T.IsSticky,
        Username 
    = P.PostAuthor,
        ThreadStarterAuthor 
    = T.PostAuthor,
        ThreadStartDate 
    = T.PostDate,    
        EditNotes 
    = (SELECT EditNotes FROM cs_PostEditNotes WHERE PostID = P.PostID),
        AttachmentFilename 
    = ISNULL ( (SELECT [FileName] FROM cs_PostAttachments WHERE PostID = P.PostID), ''),
        Replies 
    = 0--not used(SELECT COUNT(P2.PostID) FROM cs_Posts P2 (nolock) WHERE P2.ParentID = P.PostID AND P2.PostLevel != 1),
        IsModerator = 0-- not used
        HasRead = 0 -- not used
    FROM 
        cs_Posts P (nolock),
        cs_Threads T,
        cs_vw_Users_FullUser U,
        #PageIndex
    WHERE 
        P.PostID 
    = #PageIndex.PostID AND
        P.UserID 
    = U.cs_UserID AND
        T.ThreadID 
    = P.ThreadID AND
        #PageIndex.IndexID 
    > @PageLowerBound AND
        #PageIndex.IndexID 
    < @PageUpperBound and U.SettingsID = @SettingsID
    ORDER BY
        IndexID
    END

    IF @ReturnRecordCount = 1
       
    /*查询匿名状况下的总数吧,算了,卡语法吧.要懂参数还要看程序,真麻烦*/
      
    SELECT count(PostID) FROM cs_Posts (nolock) WHERE (IsApproved = 1 OR 1 = @AllowUnapprovedAND ThreadID = @ThreadID  and SettingsID = @SettingsID
  • 相关阅读:
    React Native 实现MQTT 推送调研 (1)
    bpmn的依赖注入
    vdom diff
    浏览器渲染与event loop
    uni-app 通过后缀名区分不同渠道版本
    网页定宽 栅格布局
    网页顶部菜单导航和左侧菜单导航的区别?
    Android利用tcpdump和wireshark抓取网络数据包
    就算做了
    我眼中的Serverless
  • 原文地址:https://www.cnblogs.com/ruanbl/p/509725.html
Copyright © 2011-2022 走看看