[网上商城系统 6] 数据表的设计
网上商城系统中我们需要涉及如下几张表 :
1.用户表,用来存放用户的基本信息
2.分类表,用来存放商品的类别,需要说明的是这个表需要带有递归功能,等等我会说明.
3.产品表,用来存放商品的信息
4.购物车表,用来存放购物车内容的信息
5.订单表,用来 存放订单的信息.
6.订单明细表,用来存放购买物品的信息
7.支付表,用来存放用户的支付信息.
8.用户地址表,用来存放用户的地址信息.
先看用户表 :
create table `mmall_user` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户表id', `username` varchar(50) NOT NULL COMMENT '用户名', `password` varchar(50) NOT NULL COMMENT '用户密码,MD5加密', `email` varchar(50) DEFAULT NULL, `phone` varchar(20) DEFAULT NULL, `question` varchar(100) DEFAULT NULL COMMENT '找回密码问题', `answer` varchar(100) DEFAULT NULL COMMENT '找回密码答案', `role` int(4) NOT NULL COMMENT '角色0-管理员,角色1-普通用户', `create_time` datetime NOT NULL COMMENT '创建时间', `update_time` datetime NOT NULL COMMENT '最后一次更新时间', PRIMARY KEY (`id`), UNIQUE KEY `user_name_unique` (`username`) USING BTREE )ENGINE=InnoDB AUTO_INCREMENT=21 DEFAULT CHARSET=utf8;
这里面使用了唯一索引,这是因为在高并发情况下我们不希望让username存在线程安全问题,同时又不希望开发同步代码块来使代码变得复杂,所以我们将这个工作交给MySQL来做,将username设为唯一索引,因为用户名不应该有重复.
分类表 :
CREATE TABLE `mmall_category`( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '类别id', `parent_id` int(11) DEFAULT NULL COMMENT '父类别id当id=0时说明是根节点,一级类别', `name` varchar(50) DEFAULT NULL COMMENT '类别名称', `status` tinyint(1) DEFAULT '1' COMMENT '类别状态1-正常,2-已废弃', `sort_order` int(4) DEFAULT NULL COMMENT '排序编号,同类展示顺序,数值相等则自然排序', `create_time` datetime DEFAULT NULL COMMENT '创建时间', `update_time` datetime DEFAULT NULL COMMENT '更新时间', PRIMARY KEY(`id`) )ENGINE=InnoDB AUTO_INCREMENT=100032 DEFAULT CHARSET=utf8;
这里面为了能够递归,我们设置了一个父节点,当parent_id=0时,该节点为父节点;例如id=10000,parent_id=9999,我们称该节点的父节点为9999.
产品表 :
CREATE TABLE `mmall_product`( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '商品id', `category_id` int(11) NOT NULL COMMENT '分类id,对应mmall_category表的主键', `name` varchar(100) NOT NULL COMMENT '商品名称', `subtitle` varchar(200) DEFAULT NULL COMMENT '商品副标题', `main_image` varchar(500) DEFAULT NULL COMMENT '产品主图,url相对地址', `sub_image` text COMMENT '图片地址,json格式,扩展用', `detail` text COMMENT '商品详情', `price` decimal(20,2) NOT NULL COMMENT '价格,单位(元)保留两位小数,18位,2位小数', `stock` int(11) NOT NULL COMMENT '库存数量', `status` int(6) DEFAULT '1' COMMENT '商品状态,1-在售,2-下架,3-删除', `create_time` datetime DEFAULT NULL COMMENT '创建时间', `update_time` datetime DEFAULT NULL COMMENT '更新时间', PRIMARY KEY(`id`) )ENGINE=InnoDB AUTO_INCREMENT=26 DEFAULT CHARSET=utf8;
购物车表 :
CREATE TABLE `mmall_cart`( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL, `product_id` int(11) DEFAULT NULL COMMENT '商品id', `quantity` int(11) DEFAULT NULL COMMENT '数量', `checked` int(11) DEFAULT NULL COMMENT '是否选择,1=已勾选,0=未勾选', `create_time` datetime DEFAULT NULL COMMENT '创建时间', `update_time` datetime DEFAULT NULL COMMENT '更新时间', PRIMARY KEY(`id`), KEY `user_id_index` (`user_id`) USING BTREE )ENGINE=InnoDB AUTO_INCREMENT=121 DEFAULT CHARSET=utf8;
订单表 :
CREATE TABLE `mmall_order` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '订单Id', `order_no` bigint(20) DEFAULT NULL COMMENT '订单号', `user_id` int(11) DEFAULT NULL COMMENT '用户id', `shipping_id` int(11) DEFAULT NULL, `payment` decimal(20,2) DEFAULT NULL COMMENT '实际付款金额,单位(元),保留两位小数', `payment_type` int(4) DEFAULT NULL COMMENT '支付类型,1-在线支付', `postage` int(10) DEFAULT NULL COMMENT '运费,单位(元)', `status` int(10) DEFAULT NULL COMMENT '订单状态:0-已取消,10-未付款,20-已付款,40-已发货,50-交易成功,60-交易关闭', `payment_time` datetime DEFAULT NULL COMMENT '支付时间', `send_time` datetime DEFAULT NULL COMMENT '发货时间', `end_time` datetime DEFAULT NULL COMMENT '交易完成时间', `close_time` datetime DEFAULT NULL COMMENT '交易关闭时间', `create_time` datetime DEFAULT NULL COMMENT '创建时间', `update_time` datetime DEFAULT NULL COMMENT '更新时间', PRIMARY KEY(`id`), UNIQUE KEY `order_no_index` (`order_no`) USING BTREE )ENGINE=InnoDB AUTO_INCREMENT=103 DEFAULT CHARSET=utf8;
这里的close_time的意思是 : 比如我们下订单了但是还没有付款,如果未付款时间超过了close_time,则该交易会自动关闭.
订单明细表 :
CREATE TABLE `mmall_order_item`( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '订单明细表id', `user_id` int(11) DEFAULT NULL, `order_no` bigint(20) DEFAULT NULL, `product_id` int(11) DEFAULT NULL COMMENT '商品id', `product_name` varchar(100) DEFAULT NULL COMMENT '商品名称', `product_image` varchar(500) DEFAULT NULL COMMENT '商品图片地址', `current_unit_price` decimal(20,2) DEFAULT NULL COMMENT '生成订单时的商品单价,单位(元),保留两位小数', `quantity` int(10) DEFAULT NULL COMMENT '商品数量', `total_price` decimal(20,2) DEFAULT NULL COMMENT '商品总价,单位(元),保留两位小数', `create_time` datetime DEFAULT NULL, `update_time` datetime DEFAULT NULL, PRIMARY KEY(`id`), KEY `order_no_index` (`order_no`) USING BTREE, KEY `order_no_user_id_index` (`user_id`,`order_no`) USING BTREE )ENGINE=InnoDB AUTO_INCREMENT=113 DEFAULT CHARSET=utf8;
支付表 :
CREATE TABLE `mmall_pay_info`( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) DEFAULT NULL COMMENT '用户id', `order_no` bigint(20) DEFAULT NULL COMMENT '订单号', `pay_platform` int(10) DEFAULT NULL COMMENT '支付平台:1-支付宝,2-微信', `platform_number` varchar(200) DEFAULT NULL COMMENT '支付宝支付流水号', `platform_status` varchar(20) DEFAULT NULL COMMENT '支付宝支付状态', `create_time` datetime DEFAULT NULL COMMENT '创建时间', `update_time` datetime DEFAULT NULL COMMENT '更新时间', PRIMARY KEY(`id`) )ENGINE=InnoDB AUTO_INCREMENT=53 DEFAULT CHARSET=utf8;
用户地址表 :
CREATE TABLE `mmall_shipping`( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) DEFAULT NULL COMMENT '用户id', `receiver_name` varchar(20) DEFAULT NULL COMMENT '收货姓名', `receiver_phone` varchar(20) DEFAULT NULL COMMENT '收货固定电话', `receiver_mobile` varchar(20) DEFAULT NULL COMMENT '收货移动电话', `receiver_province` varchar(20) DEFAULT NULL COMMENT '省份', `receiver_city` varchar(20) DEFAULT NULL COMMENT '城市', `receiver_district` varchar(20) DEFAULT NULL COMMENT '区/县', `receiver_address` varchar(200) DEFAULT NULL COMMENT '详细地址', `receiver_zip` varchar(6) DEFAULT NULL COMMENT '邮编', `create_time` datetime DEFAULT NULL, `update_time` datetime DEFAULT NULL, PRIMARY KEY(`id`) )ENGINE=InnoDB AUTO_INCREMENT=32 DEFAULT CHARSET=utf8;
这样我们就创建了该项目需要的数据表,其中我们并没有使用外键,因为这会导致性能的降低.来看看数据库的结构 :

浙公网安备 33010602011771号