0

我在数据库中有三个表:

  • 产品表 - +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

我正在尝试左、内和右连接,但没有任何效果。

4

1 回答 1

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' 
...
于 2012-10-19T10:02:03.020 回答