laravel 中 如何讓sql語句隨機取出10條資料

來源:互聯網
上載者:User
關鍵字 php laravel

回複內容:

首先,附上MySQL官方文檔摘錄及連結:

ORDER BY RAND() combined with LIMIT is useful for selecting a random sample from a set of rows:

就上述進行簡單翻譯如下(對英文不好的同學):

ORDER BY RAND()LIMIT一起使用,可以用於從多行結果中選取隨機的一部分

mysql> SELECT * FROM table1, table2 WHERE a=b AND c

其次,使用Laravel Eloquent的查詢器(query builder),需要用到DB(Facade)進行原生查詢:

因為不瞭解你的查詢的上下文,所以這裡用假想的Post模型進行說明

$post = Post::where('category_id', $category_id) ->orderBy(\DB::raw('RAND()')) ->take(10) ->get();

解釋:

  1. Eloquent的orderBy方法只支援第二個參數為ASCDESC,因此,這裡需要調用DB::raw方法來實現原生查詢

  2. 另外,還可以使用orderByRaw('RAND()'),效果等同

  3. 限制結果數目,要用Eloquent的take方法,相當與SQL的LIMIT

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.