查询1:
SELECT b.id,
b.bid,
b.productname,
b.brandname,
b.producttype, b.sku,
b.cat_id,
b.brandname,
b.costprice,
b.pweight,
b.monthly,
b.discountcodes,
b.seller_id FROM `buyde_product` b
where b.sku in ( SELECT buyde_new_new_sku.sku FROM buyde_new_new INNER JOIN buyde_new_new_sku ON buyde_new_new.cat_id = buyde_new_new_sku.cat_id)
最初,我编写了上面的查询,因为当时我只需要上面的详细信息,现在我想从buyde_brand
表中再添加一个细节,所以我想使用左联接,然后使用下面的查询,但是在PHPMyAdmin中尝试时会出现一个错误。
有人能看到我的代码我哪里错了吗?
SELECT b.id,
b.bid,
b.productname,
b.producttype, b.sku,
b.cat_id,
b.brandname,
b.costprice,
b.pweight,
b.monthly,
ba.brandname,
ba.bid,
b.discountcodes,
b.seller_id FROM `buyde_product` b
where b.sku in ( SELECT buyde_new_new_sku.sku FROM buyde_new_new INNER
JOIN buyde_new_new_sku ON buyde_new_new.cat_id = buyde_new_new_sku.cat_id)
LEFT JOIN `buyde_brand` ba
ON b.bid = ba.bid
错误:在phpmyadmin中
#1064 -您的SQL语法有错误;请检查与您的MariaDB服务器版本相对应的手册,以便在第16行使用接近“左侧联接
buyde_brand
ba ON b.bid = ba.bid LIMIT 0,25”的语法。
更新:SELECT b.id, b.bid, b.productname, b.producttype, b.sku, b.cat_id, b.brandname, b.costprice, b.pweight, b.monthly, ba.brandname, ba.bid, b.discountcodes, b.seller_id FROM
buyde_productb LEFT JOIN
buyde_brandba ON b.bid = ba.bid
如果运行上述查询时,请删除
where b.sku in ( SELECT buyde_new_new_sku.sku FROM buyde_new_new INNER JOIN buyde_new_new_sku ON buyde_new_new.cat_id = buyde_new_new_sku.cat_id)
这一部分,然后它运行,但我需要首先获取按照这个条件,然后想要添加出价从buyde_brand
发布于 2017-06-21 23:06:24
在查询的条件(WHERE
)之后设置LEFT JOIN
。您必须在查询的表部分设置LEFT JOIN
。见以下内容:
SELECT
b.id,
b.bid,
b.productname,
b.producttype, b.sku,
b.cat_id,
b.brandname,
b.costprice,
b.pweight,
b.monthly,
ba.brandname,
ba.bid,
b.discountcodes,
b.seller_id
FROM `buyde_product` b LEFT JOIN `buyde_brand` ba ON b.bid = ba.bid
WHERE b.sku IN (
SELECT buyde_new_new_sku.sku
FROM buyde_new_new INNER JOIN buyde_new_new_sku ON buyde_new_new.cat_id = buyde_new_new_sku.cat_id
)
此查询还应适合您的新要求,首先筛选buyde_product
表,然后在此筛选表上筛选LEFT JOIN
。这个解决方案的结果应该是一样的。另一种解决方案是将原始查询放入子select和该子select上的LEFT JOIN
中。
发布于 2017-06-21 23:10:12
您的SQL语法错误;正确的顺序是SELECT
- FROM
- JOIN
- WHERE
(- GROUP BY
- ORDER BY
)。在查询中,将LEFT JOIN
放在WHERE
子句之后,这是不正确的。你应该这样写:
SELECT b.id,
b.bid,
b.productname,
b.producttype, b.sku,
b.cat_id,
b.brandname,
b.costprice,
b.pweight,
b.monthly,
ba.brandname,
ba.bid,
b.discountcodes,
b.seller_id
FROM `buyde_product` b
LEFT JOIN `buyde_brand` ba
ON b.bid = ba.bid
where b.sku in ( SELECT buyde_new_new_sku.sku FROM buyde_new_new INNER
JOIN buyde_new_new_sku ON buyde_new_new.cat_id = buyde_new_new_sku.cat_id)
https://stackoverflow.com/questions/44692313
复制相似问题