具有多个选项的 Mysql 产品过滤器
Posted
技术标签:
【中文标题】具有多个选项的 Mysql 产品过滤器【英文标题】:Mysql product filters with multiple options 【发布时间】:2013-10-20 10:47:13 【问题描述】:例如,我有一个电视列表,每台电视都有一些属性,例如:品牌(三星、索尼等)、尺寸(80 厘米、116 厘米等)、SmartTv(是、否)。
我有以下架构:
CREATE TABLE `products` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(150) NOT NULL,
)
CREATE TABLE `attributes` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(20) character set latin1 NOT NULL
)
CREATE TABLE `attributes_entity` (
`product_id` int(11) NOT NULL,
`attribute_id` int(11) NOT NULL,
`value_id` int(11) NOT NULL,
)
CREATE TABLE `attributes_values` (
`id` int(11) NOT NULL auto_increment,
`value` varchar(255) default NULL,
)
如果我想要三星的所有电视,我会这样说:
SELECT
`p`.`id`,
`p`.`name`
FROM `attributes_entity` `ae`
INNER JOIN `products` `p` ON `ae`.`product_id`=`p`.`id`
INNER JOIN `attributes` `a` ON `ae`.`attribute_id`=`a`.`id`
INNER JOIN `attributes_values` `av` ON `ae`.`value_id`=`av`.`id`
WHERE (`a`.`name`='samsung' AND `av`.`value`='samsung')
这很好,但如果我想要的话:所有三星电视都是 smartTv:
SELECT
`p`.`id`,
`p`.`name`
FROM `attributes_entity` `ae`
INNER JOIN `products` `p` ON `ae`.`product_id`=`p`.`id`
INNER JOIN `attributes` `a` ON `ae`.`attribute_id`=`a`.`id`
INNER JOIN `attributes_values` `av` ON `ae`.`value_id`=`av`.`id`
WHERE (`a`.`name`='samsung' AND `av`.`value`='samsung')
//imposible query
and (`a`.`name`='smartv' AND `av`.`value`='yes')
我应该如何修复带有多个 AND 的查询?
【问题讨论】:
你听说过FULLTEXT
搜索..??
【参考方案1】:
第一个想法,我想不到 - 尝试用内部查询替换您的连接,并计算匹配属性的数量:
SELECT `p`.`id`, `p`.`name`
FROM `products` `p`
WHERE `p`.`id` IN (SELECT `ae`.`product_id`
FROM `attributes_entity` `ae`
INNER JOIN `attributes` `a` ON `ae`.`attribute_id`=`a`.`id`
INNER JOIN `attributes_values` `av` ON `ae`.`value_id`=`av`.`id`
WHERE ((`a`.`name`='samsung' AND `av`.`value`='samsung') OR
(`a`.`name`='smartv' AND `av`.`value`='yes'))
HAVING COUNT(*) >= 2 -- number of matching attributes required
);
【讨论】:
是的,对于我的示例,您的查询可以工作,但是对于像这样的复杂过滤,我应该怎么做:获取所有电视,品牌:三星或索尼,并且是智能电视,尺寸为 81 厘米。谢谢 继续向内部查询添加 OR 子句,并相应地增加 COUNT(*)。以上是关于具有多个选项的 Mysql 产品过滤器的主要内容,如果未能解决你的问题,请参考以下文章