qq_26892211 2017-04-21 08:00 采纳率: 0%
浏览 1089

多条件搜索商品信息sql语句优化的问题

SELECT
a.goods_id,
a.goods_name,
a.selling_price,
a.purchase_price,
a.bar_code,
a.picture
FROM
t_supplier_goods_library a
WHERE a.status = 1
AND EXISTS
(SELECT
1
FROM
t_goods_stock b
WHERE a.goods_id = b.goods_id
AND b.stock_num > 0
AND b.stock_org_id = 10047)
AND (
a.goods_name LIKE '%奶%'
OR a.brand_name LIKE '%奶%'
OR EXISTS
(SELECT
1
FROM
t_goods_type b
WHERE a.goods_type_id_2 = b.goods_type_id
AND b.goods_level = 2
AND b.goods_type LIKE '%奶%')
)
就一个商品信息搜索sql因为查询了三张表导致速度很慢要五六秒才能反映过来
我的解决办法是把三张表搜素的关键冗余到一张表然后查询
我先想知道这样做是对还是错

  • 写回答

4条回答 默认 最新

  • meweiweifeng 2017-04-21 08:35
    关注

    SELECT a.goods_id, a.goods_name, a.selling_price, a.purchase_price, a.bar_code
    , a.picture
    FROM t_supplier_goods_library a
    WHERE a.status = 1
    AND EXISTS (
    SELECT 1
    FROM t_goods_stock b
    WHERE a.goods_id = b.goods_id
    AND b.stock_num > 0
    AND b.stock_org_id = 10047
    )
    AND (a.goods_name LIKE '%奶%'
    OR a.brand_name LIKE '%奶%'
    OR EXISTS (
    SELECT 1
    FROM t_goods_type b
    WHERE a.goods_type_id_2 = b.goods_type_id
    AND b.goods_level = 2
    AND b.goods_type LIKE '%奶%'
    ))

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?