Laravel尝试查询多个表

时间:2017-07-28 17:27:31

标签: php mysql laravel

不太确定如何修复此问题,如果这甚至是我的查询或数据库的问题,那么就这样了。有3个表,产品,关系和标签。

'products' (
    'ID' bigint(20) unsigned NOT NULL AUTO_INCREMENT,
    'user_id' bigint(20) unsigned NOT NULL,
    'name' varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'primary_image' bigint(20) DEFAULT NULL,
    'description' longtext COLLATE utf8mb4_unicode_ci,
    'price' float DEFAULT NULL,
    'sale_price' float DEFAULT NULL,
    'currency' varchar(25) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'primary_color' varchar(7) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'secondary_color' varchar(7) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'status' varchar(15) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'quantity' bigint(20) DEFAULT NULL,
    'origin' varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'type' varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'size' varchar(200) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'processing_time' varchar(50) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
    'date_added' int(11) DEFAULT NULL,
    PRIMARY KEY ('ID')
) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

'relations' (
    'ID' bigint(20) unsigned NOT NULL,
    'relation_id' bigint(20) unsigned NOT NULL,
    'type' varchar(20) COLLATE utf8mb4_unicode_ci NOT NULL,
    'options' text COLLATE utf8mb4_unicode_ci,
    KEY 'ID' ('ID'),
    KEY 'relation_id' ('relation_id')
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

'tags' (
    'ID' bigint(20) unsigned NOT NULL AUTO_INCREMENT,
    'name' varchar(200) COLLATE utf8mb4_unicode_ci NOT NULL,
    'slug' varchar(200) COLLATE utf8mb4_unicode_ci NOT NULL,
    PRIMARY KEY ('ID')
) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

这些类别之间的关系如下:

  • products.ID = relations.ID
  • relations.relation_id = tags.ID

为了测试目的,数据库中添加了50k产品,250k关系和25k标签。

我正在构建一个在产品名称,描述和标签内搜索的查询。

执行此查询:

Product::select('ID', 'name')->where( 'name', 'like', '%'.$search_query.'%' )->orWhere( 'description', 'like', '%'.$search_query.'%' )->orWhereHas('relations', function( $query ) use( $search_query ) {
    $query->where('type', 'tags')->whereHas('tags', function( $query ) use( $search_query ) {
        $query->where( 'name', 'like', '%'.$search_query.'%' );
    });
})->paginate(25);
  • 此查询需要大约0.8秒来查找数据,如果我查询特定标记,则需要1.8秒
  • 我使用连接构建了一个类似的查询,它花了更长的时间,所以我现在仍然使用上面的查询。

你们有没有人知道我可能做错了什么?这里的主要问题是查询执行时间。

1 个答案:

答案 0 :(得分:0)

我无法优化此查询。如果您有'LIKE', searchquery.'%'(没有前导%),您可以索引文本列以获得速度提升。如果您需要在两端使用通配符的此功能,则必须使用全文索引搜索提供程序。 Algolia https://www.algolia.com/是我所知道的,并且创建了Laravel Scout来处理他们的搜索。此other question也引用http://sphinxsearch.com/http://lucene.apache.org/core/,但我不知道他们做了什么。

修改:https://www.elastic.co/products/elasticsearch