簡體   English   中英

如何使用 elequent 模型從 laravel 表中獲取不同的記錄?

[英]How I can get distinct records from laravel table using elequent model?

我必須根據實體 ID 獲取不同的記錄。 我試過這個,但它不起作用

User::where('id',$id)->with(['userRoleEntity' => function($q) { $q->distinct('entityId'); }])->first();

我應該在用戶實體數組中得到兩條記錄,但得到 3 條記錄。我該如何解決這個問題? 提前致謝

正方形中的值不應該存在https://prnt.sc/qkamdi

distinct方法不支持傳遞參數,需要選擇一個字段並distinct

User::where('id',$id)->
    with(['userRoleEntity' => function($q) { 
      $q->select('entityId')->distinct(); 
}])->first();

或者

試試這個:

User::where('id',$id)->
    with(['userRoleEntity' => function($q) { 
      $q->groupBy('entityId'); 
}])->first();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM