通过属性搜索商品mysql设计

2019-10-24 01:14:29

商品detail表这里写图片描述
包含了商品的id,和扩展字段

商品属性表
这里写图片描述

属性是可以动态扩展的,问题:属性是搜索条件 问:请展示出 材质为塑料 防水为YES,颜色为绿色的商品详细信息,按照sort_filed排序

sql编写:

SELECT
    gd.goods_id,
    gd.sort_filed 
FROM
    (
SELECT
    goods_id 
FROM
    `goods_attr` 
WHERE
    ( attr_name = '材质' AND attr_value = '塑料' ) 
    OR ( attr_name = '颜色' AND attr_value = '绿色' ) 
    OR ( attr_name = '防水' AND attr_value = 'YES' ) 
GROUP BY
    goods_id 
HAVING
    COUNT( goods_id ) = 3 
    ) attr
    LEFT JOIN goods_detail gd ON attr.goods_id = gd.goods_id 
ORDER BY
    gd.sort_filed

继续优化将attr_name 和attr_value设置索引

  • 2020-04-22 10:49:10

    css按钮特效大全

    打开这个连接,你会发现很多按钮动画脚本,基本这些动画就够大家用的了。

  • 2020-04-27 09:26:49

    transform与transition区别与详解

    对元素进行移动、缩放、转动、拉长或拉伸。 方法:translate(): 元素从其当前位置移动,根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数 有两个div,它们的css样式如下,transition:过渡 元素从一种样式逐渐改变为另一种的效果 有一个div,它的css样式如下:

  • 2020-04-27 11:02:21

    CSS 气泡对话框

    点击上面地址,我们可以看到一个灵活的css气泡,拖动按钮,改变气泡效果。

  • 2020-04-27 16:59:23

    Docker部署nuxtjs

    将一下文件拷贝至服务器目录/app |名称|描述| |-|-| |.nuxt|编译后生成的目录,开发模式和发布模式通用,注意发布前使用npm run build 防止将dev目录发布| |static| 静态资源文件,通过/可直接访问| |package.json|npm 包管理配置文件| |nuxt.config.js|Nuxt.js 默认的配置涵盖了大部分使用情形,可通过 nuxt.config.js 来覆盖默认的配置。| |node_modules|依赖模块|

  • 2020-04-28 10:47:16

    currentColor css 的使用

    以前我们在如何动态设置伪元素的颜色上非过不少心思,看完下面的文章,你就会超级见到那的设置伪元素的颜色了。