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因为查询了三张表导致速度很慢要五六秒才能反映过来
我的解决办法是把三张表搜素的关键冗余到一张表然后查询
我先想知道这样做是对还是错
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有意义吗? 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优化了,是这个设计有问题。三张表联查数据一旦上万直接就死机。
这个sql 不是我写的,我现在要做的是优化它。大致要做的事一个商品多条件搜索功能,有三张表。商品表、库存表、商品类别表。因为商品表存的是商品类别的主键,但是搜索的时候是可以按照商品类别来搜索的,所以查询商品类别表。商品有两万五千多个,这条sql语句查询出来大概十秒左右。