ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

php – 在Laravel 5.2中从大型数据库查询中排除结果的最佳方法

2019-07-01 16:03:15  阅读:202  来源: 互联网

标签:php mysql laravel-5 eloquent laravel-5-2


我正在使用Laravel 5.2来构建一个大型产品库存,而我在查看将显示产品的问题时遇到问题.这是一个例子:

我有很多产品 – 在我的数据库中准确地超过20k.其中大多数我想每天展示,但大约500-1000我只需要在一周的某些日子显示.

Currenly我已经回顾了以下方法,每个方法都有其缺点:

>创建表product_availability,其中每行将包含product_id,weekday和available(true / false)列.然而,根据这种结构,我有7行提供1个产品的信息,整个表格将包含~14万行,我认为这不是一个好主意 – 因为大多数产品无论如何都会每天都可用而且只有500 -1000不会.
>我的第二个猜测是简单地在products表中添加一个’availability’列,它将包含以下格式的JSON字符串:

{“mo”:“true”,“tu”:“false”,“we”:“false”,“th”:“true”,“fr”:“false”,“sa”:“false”,“ su“:”true“}

然后我会这样查询:

$weekday = date('N');
        switch ($weekday) {
            case '1':
                $builder->where('$availability->mo', 'true');
                break;
            case '2':
                $builder->where('$availability->tu', 'true');
                break;
            case '3':
                $builder->where('$availability->we', 'true');
                break;
            case '4':
                $builder->where('$availability->th', 'true');
                break;
            case '5':
                $builder->where('$availability->fr', 'true');
                break;
            case '6':
                $builder->where('$availability->sa', 'true');
                break;
            case '7':
                $builder->where('$availability->su', 'true');
                break;
        }

但IMO对于这个解决方案的问题在于它也将是一个缓慢而沉重的方法.

>我的第三个猜测是向后工作,而不是检查产品今天是否可用,而是检查它不在哪一天.这样我就可以获得’availability’列为null的所有产品,对于这些,它不是运行if语句然后以某种方式添加它们,但我不知道如何构造它.

所以我的问题是:

什么是最快的查询来获得今天可用的所有产品,请记住,只有很小一部分产品不可用(如何排除它们,也许)?

解决方法:

我认为你的第一个选择是最好的解决方案(虽然有一些变化).

我建议product_availability的表结构类似于:

| id | product_id | mon | tue | wed | thu | fri | sat | sun |
| 1  |      13403 |   1 |   0 |   1 |   0 |   1 |   0 |   0 |

然后你可以查询类似的东西:

SELECT
  products.*
FROM
  products
LEFT JOIN
  product_availability 
ON
  product_availability.product_id = products.id
WHERE
  # show if no entry here (i.e. always to be shown)
  product_availability.id IS NULL 
  OR
  # only want to show specific days
  product_availability.id IS NOT NULL AND CASE
    WHEN DAYOFWEEK(CURDATE()) = 1 THEN `sun` = 1
    WHEN DAYOFWEEK(CURDATE()) = 2 THEN `mon` = 1
    WHEN DAYOFWEEK(CURDATE()) = 3 THEN `tue` = 1
    WHEN DAYOFWEEK(CURDATE()) = 4 THEN `wed` = 1
    WHEN DAYOFWEEK(CURDATE()) = 5 THEN `thu` = 1
    WHEN DAYOFWEEK(CURDATE()) = 6 THEN `fri` = 1
    WHEN DAYOFWEEK(CURDATE()) = 7 THEN `sat` = 1
  END

这将显示所有产品.如果product_availability中有产品ID的条目,那么它将获得当前的一周(如果您愿意,可以使用其他方法替换它),并查看相应的日期是否有1来显示它.

only a very small fraction of them wouldn’t be available

在这种情况下,您只需要在product_availability中添加一个条目.

这是一个小提琴:http://sqlfiddle.com/#!9/c2bbf1/3

希望这可以帮助 :)

编辑:您可以用来转换为雄辩查询的一些方法:

  ->leftJoin('product_availability', 'products.id', '=', 'product_availability.product_id')
  ->whereNull('product_availability.id')
  ->orWhere(function ($query) {
    $query
      ->whereRaw('(product_availability.id IS NOT NULL AND CASE
        WHEN DAYOFWEEK(CURDATE()) = 1 THEN `sun` = 1
        WHEN DAYOFWEEK(CURDATE()) = 2 THEN `mon` = 1
        WHEN DAYOFWEEK(CURDATE()) = 3 THEN `tue` = 1
        WHEN DAYOFWEEK(CURDATE()) = 4 THEN `wed` = 1
        WHEN DAYOFWEEK(CURDATE()) = 5 THEN `thu` = 1
        WHEN DAYOFWEEK(CURDATE()) = 6 THEN `fri` = 1
        WHEN DAYOFWEEK(CURDATE()) = 7 THEN `sat` = 1
      END)');
  });

或者你可以做DB :: raw查询

标签:php,mysql,laravel-5,eloquent,laravel-5-2
来源: https://codeday.me/bug/20190701/1348229.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有