使用条件在一个查询中选择3个表

时间:2012-09-10 15:59:52

标签: php mysql sql

如何在一个查询中选择3个表并以价格显示所有产品?

下面是我的数据库结构(MySql):

类别

+-------------+------------+
 category_id  | parent_id  |
+-------------+------------+
  1           |      0     
  2           |      1
  3           |      1
  4           |      1
  5           |      2
  6           |      3

products_to_categories

+-------------+------------+
 product_id   | category_id|
+-------------+------------+
  54          |      0     
  55          |      2
  56          |      2
  57          |      2
  58          |      3
  59          |      3
  60          |      4

产品

+-------------+------------+
 product_id   |    price   |
+-------------+------------+
  54          |      10.50     
  55          |      11.20
  56          |      1.00
  57          |      22.20
  58          |      32.0
  59          |      32.0
  60          |      22.0

以下是我的情况;

1. table categories : parent_id = '1'  
(result : 2,3,4)

2. table products_to_categories : category_id = result categories(result : 2,3,4) 
(result : 55,56,57,58,59,60)

3. table products : inner join or left join table product to display price where product_id = result products_to_categories(result : 55,56,57,58,59,60)

最终输出

  55 - 11.20
  56 - 1.00
  57 - 22.20
  58 - 32.0
  59 - 32.0
  60 - 22.0

在我发布此问题之前,这是我之前的查询(我坚持如何进入条件2)

$sql_all = mysql_query("SELECT cat.parent_id,cat.category_id FROM categories cat WHERE cat.parent_id='1' ");
while($row = mysql_fetch_array($sql_all)) {
echo $row['categories_id'].'<br/>'; 
}

感谢。

3 个答案:

答案 0 :(得分:2)

试试这个,

SELECT  c.*
FROM    categories a
        INNER JOIN products_to_categories b
            ON a.category_id = b.category_id
        INNER JOIN products c
            ON b.product_id = c.product_id
WHERE  a.parent_id = 1

这将显示来自products = 1的parent_id表的所有记录。

答案 1 :(得分:1)

查看以下查询:

SELECT pro.product_id, SUM(pro.price) 
FROM categories cat 
JOIN products_to_categories ptc USING(category_id)
JOIN products pro ON ptc.product_id = pro.product_id
WHERE cat.parent_id='1'

使用上述解决方案,您可以在将来轻松扩展,以防您希望GROUP BY特定产品......

答案 2 :(得分:1)

以下查询应该带来您想要的结果。

SELECT p.product_id, p.price
FROM products p
JOIN products_to_categories pc ON (pc.product_id = p.product_id)
JOIN categories c ON ((c.category_id = pc.category_id) AND (c.parent_id = "1"))

当然,您可以将parent_id 1 更改为任何其他值,并相应地获取结果。

注意:我相信在这种情况下,您可以通过在JOIN子句中声明parent_id条件而不是WHERE子句来获得更好的性能。