mysql电商数据库结构_高性能可扩展MySQL数据库设计及架构优化——电商实例数据库结构...

高性能可扩展MySQL数据库设计及架构优化——电商实例数据库结构

高性能可扩展MySQL数据库设计及架构优化——电商实例数据库结构设计

电商实例数据库结构设计

[var1]

1、用户模型设计

(1) 主要作用:管理和维护用户信息。

84c020391d780386302c83b0cdf6f75a.png

0bc7d6aae7b8088fd3ad129273012628.png

2、用户实体

c742e886c211d9a9df85c42801520411.png

思考:如何把用户的属性存到表中?

6e8a0fc08858aba805bb9641b1264183.png

优点:易于数据存取

问题:

(1) 数据插入异常

PK:用户登录名

用户表:{登录名 ... ... 会员级别,级别积分上限,级别积分下限}

insert into 用户表(会员级别) values('青铜');

(2) 数据更新异常

要修改某一行的值时,不得不修改多行数据。

用户等级:青铜级 ----> 注册会员

Update 用户表 set 等级 = '注册会员' where 等级 = '青铜级';

(3) 数据删除异常

删除某一数据时不得不同时删除另一数据

如何删除用户等级名为青铜的等级?

delete from 用户表 where 用户等级='青铜';

(4) 数据存在冗余(很容易出现相同级别,级别的上限和下限不同的情况)

(5) 数据表过宽,会影响修改表结构的效率

解决方式:

(1) 数据库的设计范式

设计范式是数据库设计的规范;

有多种设计范式,如数据库设计第一范式,第二范式和第三范式等

数据库设计最低要求满足第三范式的要求。

(2) 第三范式(3NF)

一个表中的列和其他列之间既不包含部分函数依赖关系,也不包含传递函数依赖关系,那么这个表的设计就符合第三范式。

2194e57875028c5dd7ec8895b6fa660a.png

{级别积分上限,级别积分下限}与{登录名}之间存在传递依赖关系,不符合第三范式

(3) 拆分原用户表以符合第三范式

8e7316b1e36700254c4e3fc65bd49430.png

(4) 尽量做到冷热数据分离,减少表的宽度

ed1b38df187b6f599a50f9e015a8bf49.png

用户登录表:{登录名,密码,用户状态}

用户地址表:{省,市,区,邮编,地址}

用户信息表:{用户名,证件类型,证件号码,手机号,邮箱,性别,积分,注册时间,生日,会员级别,用户余额}

用户登录表(customer_login):

CREATE TABLE customer_login(

customer_id int UNSIGNED AUTO_INCREMENT NOT NULL COMMENT '用户ID',

login_name VARCHAR(20) NOT NULL COMMENT '用户登录名',

password char(32) not null COMMENT 'md5加密的秘钥',

user_stats TINYINT NOT NULL DEFAULT 1 COMMENT '用户状态',

modified_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后修改时间',

PRIMARY KEY pk_customerid(customer_id)

) ENGINE = INNODB COMMENT = '用户登录表';

用户信息表(customer_inf):

CREATE TABLE customer_inf(

customer_inf_id int UNSIGNED AUTO_INCREMENT NOT NULL COMMENT '自增主键ID',

customer_id int UNSIGNED NOT NULL COMMENT 'customer_login表的自增ID',

customer_name VARCHAR(20) NOT NULL COMMENT '用户真实姓名',

identity_card_type TINYINT NOT NULL DEFAULT 1 COMMENT '证件类型:1 省份证,2 军官证,3 护照',

identity_card_no VARCHAR(20) COMMENT '证件号码',

mobile_phone INT UNSIGNED COMMENT '手机号',

customer_email VARCHAR(50) COMMENT '邮箱',

gender CHAR(1) COMMENT '性别',

user_point INT NOT NULL DEFAULT 0 COMMENT '用户积分',

register_time TIMESTAMP NOT NULL COMMENT '注册时间',

birthday DATETIME COMMENT '会员生日',

customer_level TINYINT NOT NULL DEFAULT 1 COMMENT '会员级别:1 普通会员,2 青铜会员,3 白银会员,4 黄金会员,5 钻石会员',

user_money DECIMAL(8,2) NOT NULL DEFAULT 0.00 COMMENT '账户余额',

modified_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后修改时间',

PRIMARY KEY pk_customerinfid(customer_inf_id)

) ENGINE = INNODB COMMENT = '用户信息表';

用户级别表(customer_level_inf):

CREATE TABLE customer_level_inf(

customer_level TINYINT NOT NULL AUTO_INCREMENT COMMENT '会员级别ID',

customer_name VARCHAR(10) NOT NULL COMMENT '会员级别名称',

min_point INT UNSIGNED NOT NULL DEFAULT 0 COMMIT '该级别最低积分',

max_point INT UNSIGNED NOT NULL DEFAULT 0 COMMENT '该级别最高积分',

modified_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后修改时间',

PRIMARY KEY pk_customerlevelid(customer_level)

) ENGINE = INNODB COMMENT = '用户级别信息表';

用户地址表(customer_addr)

CREATE TABLE customer_addr(

customer_addr_id INT UNSIGNED AUTO_INCREMENT NOT NULL COMMENT '自增主键ID',

customer_id INT UNSIGNED NOT NULL COMMENT 'customer_login表的自增ID',

zip SMALLINT NOT NULL COMMENT '邮编',

province SMALLINT NOT NULL COMMENT '地区表中省份的id',

city SMALLINT NOT NULL COMMENT '地区表中城市的id',

district SMALLINT NOT NULL COMMIT '地区表中的区id',

address VARCHAR(200) NOT NULL COMMIT '具体的地址门牌号',

is_default TINYINT NOT NULL COMMENT '是否默认',

modified_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后修改时间',

PRIMARY KEY pk_customeraddrid(customer_addr_id)

) ENGINE = INNODB COMMENT = '用户地址表';

用户积分日志表(customer_point_log)

CREATE TABLE customer_point_log(

point_id INT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '积分日志ID',

customer_id INT UNSIGNED NOT NULL COMMENT '用户ID',

source TINYINT UNSIGNED NOT NULL '积分来源:0 订单,1 登录, 2 活动',

refer_number INT UNSIGNED NOT NULL DEFAULT 0 COMMENT '积分来源相关编号',

change_point SMALLINT NOT NULL DEFAULT 0 COMMENT '变更积分数',

create_time TIMESTAMP NOT NULL COMMENT '积分日志生成时间',

PRIMARY KEY pk_pointid(point_id)

)ENGINE=INNODB COMMENT '用户积分日志表';

用户余额变动表(customer_balance_log)

CREATE TABLE customer_balance_log(

balance_id INT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '余额日志ID',

customer_id INT UNSIGNED NOT NULL COMMENT '用户ID',

source TINYINT UNSIGNED NOT NULL DEFAULT 1 COMMENT '记录来源:1 订单, 2 退货单',

source_sn INT UNSIGNED NOT NULL COMMENT '相关单据ID',

create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '记录生成时间',

amount DECIMAL(8,2) NOT NULL DEFAULT 0.00 COMMENT '变动金额',

PRIMARY KEY pk_balanceid(balance_id)

)ENGINE=INNODB COMMENT '用户余额变动表';

用户登录日志表(customer_login_log)

CREATE TABLE customer_login_log(

login_id INT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '登录日志ID',

customer_id INT UNSIGNED NOT NULL COMMENT '登录用户ID',

login_time TIMESTAMP NOT NULL COMMENT '用户登录时间',

login_ip INT UNSIGNED NOT NULL COMMENT '登录IP',

login_type TINYINT NOT NULL COMMENT '登录类型:0 未成功, 1 成功',

PRIMARY KEY pk_loginid(login_id)

)ENGINE=INNODB COMMENT '用户登录日志表';

[var1]

[var1]

[var1]

[var1]

[var1]

[var1]

[var1]

高性能可扩展MySQL数据库设计及架构优化——电商实例数据库结构相关教程

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值