商品分类,使用无限分类

即:

-------如何创建数据表

  

pid---父级分类id,如果是顶级分类则为0

path---1,用户分类的排序 。

排序示例:

实现逻辑:获取type表的所有分类,order by path ,   得到了type列表,然后path有几个逗号就加几个---,

这样,父级分类下就是子级分类,子级分类下是孙级分类,分类得到了有效的排序。

2,点击父级分类,展示所有它和它的所有子级分类所辖的商品

实现逻辑: 子级分类的path  like %父级分类的path%,再通过where的or语句(where (id=1 or id=2) ),可以实现点击父级分类,显示它和它所有子级分类的商品

level---表示当前分类是几级分类,一般用于展示

sql代码

商品表
create table goods(
id int unsigned auto_increment primary key,
goods_type_id int unsigned not null default 0 comment '商品分类外键',
brand_id int unsigned not null default 0 comment '品牌外键',
name varchar(100) not null default '' comment '商品名称',
title varchar(255) not null default '' comment '商品标题',
img varchar(150) not null default '' comment '商品缩略图', old_price decimal(10,2) unsigned not null default 0 comment '原价',
pricr decimal(10,2) unsigned not null default 0 comment '售价',
stock int unsigned not null default 0 comment '库存',
warnstock int unsigned not null default 0 comment '预警库存' , status tinyint unsigned not null default 0 comment '商品状态 ,1-在售 0-下架', sell_num int unsigned not null default 0 comment '销量', detail varchar(999) not null default '' comment '商品详情', create_time int(10) unsigned not null default 0 comment '商品创建时间',
update_time int(10) unsigned not null default 0 comment '商品更新时间' ) 无限分类
create table goods_type(
id int unsigned auto_increment primary key,
name varchar(20) not null default '' comment '分类名',
pid int unsigned not null default 0 comment '父级分类id(0:顶级分类)',
path varchar(20) not null default '' comment '分类路径(排序)',
level int unsigned not null default 0 comment '分类等级(1:顶级分类)'
) 品牌表
create table brand(
id int unsigned auto_increment primary key,
name varchar(20) not null default '' comment '品牌名',
logo_img varchar(150) not null default '' comment '品牌logo图',
info varchar(255) not null default '' comment '品牌简介',
create_time int(10) unsigned not null default 0 comment '品牌创建时间',
update_time int(10) unsigned not null default 0 comment '品牌更新时间'
)

goods:

brand:

goods_type:

php商城数据库的设计 之无限分类的更多相关文章

  1. php不用递归完成无限分类,从表设计入手完整演示过程

    无限分类是什么就不废话了,可以用递归实现,但是递归从数据库取东西用递归效率偏低,如果从表设计入手,就很容易做到网站导航的实现,下面是某论坛导航,如下图 网上无限分类大多不全面,今天我会从设计表开始, ...

  2. ThinkPHP无限分类模块设计

    public function catelist(){ $cate=D('Cate'); //var_dump($cate->gettree());exit; $cateres=$cate-&g ...

  3. PHP实现无限分类

    PHP实现无限分类 无限分类 递归 无限级分类是一种设计技巧,在开发中经常使用,例如:网站目录.部门结构.文章分类.笔者觉得它在对于设计表的层级结构上面发挥很大的作用,比如大家在一些平台上面,填写邀请 ...

  4. SQL Server 进阶 01 数据库的设计

    SQL Server 进阶 01 数据库的设计 本篇目录 课程内容回顾及介绍 为什么需要规范的数据库设计 设计数据库的步骤 绘制E-R(实体-关系)图 实体-关系模型 如何将E-R图转换为表 数据规范 ...

  5. 数据库schema设计与优化

    原文地址 1. 前言 对于数据库而言,在日常开发中我们主要的关注点有两块,一个是schema的结构设计,另一个就是索引的优化,这两块是影响我们最终系统结构和性能的关键部分,自然也是我们花费精力最多的部 ...

  6. MySql无限分类数据结构--预排序遍历树算法

    MySql无限分类数据结构--预排序遍历树算法 无限分类是我们开发中非常常见的应用,像论坛的的版块,CMS的类别,应用的地方特别多. 我们最常见最简单的方法就是在MySql里ID ,parentID, ...

  7. PHP+Mysql无限分类的方法汇总

    无限分类是个老话题了,来看看PHP结合Mysql如何实现.第一种方法这种方法是很常见.很传统的一种,先看表结构表:categoryid int 主键,自增name varchar 分类名称pid in ...

  8. PHP无限分类分类导航LINK的代码实现

    1. 代码数据库的结构: 2.要达到的效果 /** * @param php无限分类分类导航LINK的代码实现 */ include('db.inc.php'); function getCatePa ...

  9. php三种无限分类

    无限分类,是指从一个最高分类开始,每个子分类都可以分出自己的若干个子分类,可以一直分下去,称为无限级分类: 下面是对省市县的无限极分类的列子.数据库如图: 代码示例如下: /** * @Descrip ...

随机推荐

  1. 在MATLAB R2018b中配置VLFeat

    在MATLAB R2018b中配置VLFeat 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ VLFeat官网:http://www.vlfeat.o ...

  2. 获取properties文件的内容

    获取properties文件的内容 public void test() throws Exception{ String resource = "application.propertie ...

  3. react admin

    react admin 管理后台的快速创建方式

  4. [CF546C] Soldier and Cards - 模拟

    两个人玩牌,首先两个人都拿出自己手牌的最上面的进行拼点,两张拼点牌将都给拼点赢得人,这两张牌放入手牌的顺序是:先放对方的牌再放自己的.若最后有一个人没有手牌了,那么他就输了,求输出拼点的次数和赢得人的 ...

  5. PHPstorm配置xdebug问题小记

    安装的是符合自己环境的xdebug,因为是按照xdebug官网的步骤安装的:安装什么版本检测地址:https://xdebug.org/wizard.php,安装操作复制phpinfo()内容之后点击 ...

  6. Docker镜像加速-配置阿里云镜像仓库

    Docker默认远程仓库是https://hub.docker.com/ 比如我们下载一个大点的东西,龟速 由于是国外主机,类似Maven仓库,慢得一腿,经常延迟,破损: 所以我们一般都是配置国内镜像 ...

  7. oracle三个网络配置文件(listener.ora、tnsname.ora、sqlnet.ora)的作用

    oracle网络配置 三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下. 1.  sqlne ...

  8. 谷歌浏览器安装apizza

    接口测试是卡发中不可缺少的一环,那么常用的postman是英文就很不方便一些小伙伴的使用,所以此工具和postman功能相同且升级并且是中文模式 安装: 链接:https://pan.baidu.co ...

  9. Outlook365(Oulook2016 或2013) 写邮件输入收件人时的推荐联系人如何清理?

    · 在Outlook365(Oulook2016 或2013) 中写邮件,输入收件人邮箱地址时,会出现“最近联系人”  “其他建议”等推荐的联系人,可以方便选择.如果里面有很多邮箱地址的已经无效的话, ...

  10. 网络流EK算法模板

    \(EK\)算法的思想就是每一次找一条增广路进行增广. 注意几个点: 存图时\(head\)数组要设为\(-1\). 存图的代码是这样的: inline void add(int u, int v, ...