zoukankan      html  css  js  c++  java
  • Mysql 随机获得表的几条记录

    在做博客文章详情的时候,有一个拓展阅读的功能:

    想法一:根据当前文章Id,写死两条链接,Id+1,Id-1,但是文章Id可能被删除,Id不连续,不可取。×

    想法二:获得当前文章记录的前一条和后一条记录,好像有点难受,要查询两次。查询两次,可行。√

    想法三:直接获取文章表两条随机的记录。一次查询,舒服。√

    SELECT *
    FROM t_article
    WHERE Id >= ((SELECT MAX(Id) FROM t_article)-(SELECT MIN(Id) FROM t_article)) * RAND() + (SELECT MIN(Id) FROM t_article)
    LIMIT 2

    ArticleService对应的方法

            /// <summary>
            /// 延伸阅读-获取两条随机文章
            /// </summary>
            /// <param name="num"></param>
            /// <returns></returns>
            public IEnumerable<ArticleModel> GetRandomArticleList(int num)
            {
                string _where = "WHERE Id >= ((SELECT MAX(Id) FROM t_article)-(SELECT MIN(Id) FROM t_article)) * RAND() + (SELECT MIN(Id) FROM t_article) LIMIT "+num;
                return repository.GetByWhere(_where,null,null,null); ;
            }
  • 相关阅读:
    POJ 2002 Squares
    POJ 1840 Eqs
    POJ 1759 Garland
    UVA 572 Oil Deposits
    POJ 3278 Catch That Cow
    POJ 2488 A Knight's Journey
    UVA 699 The Falling Leaves
    [Poi1999] 原始生物
    [bzoj3033] 太鼓达人
    [bzoj1123] BLO
  • 原文地址:https://www.cnblogs.com/baocaige/p/11202071.html
Copyright © 2011-2022 走看看