ProductGroupBuyingDao.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. <?php
  2. namespace app\common\dao\store\product;
  3. use app\common\dao\BaseDao;
  4. use app\common\model\store\product\ProductGroupBuying;
  5. class ProductGroupBuyingDao extends BaseDao
  6. {
  7. public function getModel(): string
  8. {
  9. return ProductGroupBuying::class;
  10. }
  11. public function search($where)
  12. {
  13. $query = ProductGroupBuying::getDb()->alias('B')->join('StoreProductGroup G','B.product_group_id = G.product_group_id');
  14. $query
  15. ->when(isset($where['mer_id']) && $where['mer_id'] !== '', function($query)use($where){
  16. $query->where('B.mer_id',$where['mer_id']);
  17. })
  18. ->when(isset($where['date']) && $where['date'] , function($query)use($where){
  19. getModelTime($query,$where['date'],'B.create_time');
  20. })
  21. ->when(isset($where['status']) && $where['status'] !== '', function($query)use($where){
  22. $query->where('B.status',$where['status']);
  23. })
  24. ->when(isset($where['user_name']) && $where['user_name'] !== '', function($query)use($where){
  25. $query->join('StoreProductGroupUser U','U.group_buying_id = B.group_buying_id')->where('is_initiator',1)
  26. ->whereLike('uid|nickname',"%{$where['user_name']}%");
  27. })
  28. ->when(isset($where['keyword']) && $where['keyword'] !== '' , function($query)use($where){
  29. $query->join('StoreProduct P','G.product_id = P.product_id')
  30. ->whereLike('P.product_id|store_name',"%{$where['keyword']}%");
  31. })
  32. ->when(isset($where['is_trader']) && $where['is_trader'] !== '', function($query)use($where){
  33. $query->join('Merchant M','M.mer_id = B.mer_id')->where('is_trader',$where['is_trader']);
  34. })
  35. ;
  36. return $query;
  37. }
  38. }