仅当值为null或特定数字时才加入两个表

时间:2012-10-19 09:55:34

标签: sql mysqli

我在数据库中有三个表:

  • 产品表 - +100000条目
  • 属性表(产品的可能属性列表)
  • 产品属性表(包含产品属性的值)

我正在寻找8个随机产品及其中一个属性(attribute_id = 2),但如果产品没有此属性,则应该在返回查询时出现。我一直在尝试一些没有任何成功结果的SQL查询,因为我的返回只显示具有该属性的产品并隐藏其他产品。

我的三张桌子是这样的:

CREATE TABLE `product` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `sku` varchar(20) COLLATE utf8_unicode_ci NOT NULL DEFAULT '',
  `name` varchar(90) COLLATE utf8_unicode_ci NOT NULL DEFAULT '',
  `provider_id` int(11) unsigned DEFAULT NULL,
  `url` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `active` int(1) unsigned NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`),
  UNIQUE KEY `sku_UNIQUE` (`sku`)
) ENGINE=InnoDB AUTO_INCREMENT=123965 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

CREATE TABLE `attribute` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(50) NOT NULL DEFAULT '',
  `data_type` varchar(50) DEFAULT '',
  PRIMARY KEY (`id`), 
) ENGINE=InnoDB AUTO_INCREMENT=30 DEFAULT CHARSET=latin1;

CREATE TABLE `product_attribute` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `product_id` int(11) unsigned NOT NULL,
  `attribute_id` int(11) unsigned NOT NULL DEFAULT '6',
 `value` longtext NOT NULL,
 PRIMARY KEY (`id`),
  UNIQUE KEY `product_id` (`product_id`,`attribute_id`)
) ENGINE=InnoDB AUTO_INCREMENT=869437 DEFAULT CHARSET=latin1;

这是我试过的其中一个问题,我认为它是正确的,但它与其他问题有同样的问题......

SELECT product.id, product.sku, product.name,provider.name as provider_name,
product_attribute.value as author 
FROM (`product`)  
LEFT JOIN `provider` ON `product`.`provider_id` = `provider`.`id` 
LEFT JOIN `product_attribute` ON `product`.`id` = `product_attribute`.`product_id`
 WHERE `product`.`active` = '1' AND `product`.`url` IS NOT NULL 
AND (`product_attribute`.`attribute_id` = 8 OR `product_attribute`.`attribute_id` IS NULL) 
AND `product`.`provider_id` = '7' ORDER BY RAND() LIMIT 8

我尝试左,内,右连接,没有任何作用。我非常感谢你的帮助。

谢谢!

1 个答案:

答案 0 :(得分:4)

您应该将左连接表的条件放在连接中,而不是where子句

...
from product
     left join provider ON product.provider_id = provider.id  
     left join product_attribute on product.id = product_attribute.product_id
               and product_attribute.attribute_id = 8
where `product`.`active` = '1' 
and `product`.`url` IS NOT NULL  
and `product`.`provider_id` = '7' 
...