Java从零开始(47)数据库设计

实战 – 数据库设计

经过上一小节的需求分析,我们将系统分为了鉴权模块、商品模块和分类模块,本节中,我们将围绕功能模块,进行数据库设计。你将学习到实际开发中的一些数据库设计技巧。请确保在你的开发环境下,已经准备好了一个 MySQL 数据库。

1. 创建库

首先,我们先给商品管理项目创建一个数据库,命名为 goods_cmscmsContent Management System(内容管理系统)的缩写。

链接数据库,执行以下 SQL:

CREATE DATABASE `goods_cms` CHARACTER SET 'utf8mb4' COLLATE 'utf8mb4_general_ci';

2. 创建表

2.1 通用字段

有一定数据库设计经验的同学都知道,一个数据库中的数据表都会有一些通用字段。关于通用字段有哪些、如何命名以及如何选定字段类型都有一定的套路,不仅受个人开发习惯的影响,也受到团队开发规范的约束。

该项目,所有的数据表都包含以下字段:

字段名称 字段类型 字段长度 允许为 NULL 默认值 注释
id int 0 表主键,自增长
create_time timestamp CURRENT_TIMESTAMP 创建时间
update_time timestamp CURRENT_TIMESTAMP 更新时间
delete_time timestamp 删除时间

另外,除了通用字段,该项目中的所有表都以 imooc 开头。

2.2 用户表

由于该系统鉴权模块使用用户名和密码进行鉴权,需要设计一个用户表 user,用户表包含如下字段(已省略通用字段):

字段名称 字段类型 字段长度 允许为 NULL 默认值 注释
nickname varchar 50 空字符串 昵称
username varchar 50 用户名
password char 32 密码

Tipspassword 字段的类型为 char,这是因为我们在实现代码时,将使用 MD5 算法进行加密,加密后的密码长度为 32,因此使用定长字符串更加节省存储空间。

链接 MySQL 并选择 goods_cms 数据库,执行以下 SQL:

-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`nickname` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '' COMMENT "昵称",
`username` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT "用户名",
`password` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT "密码",
`create_time` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP,
`update_time` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP,
`delete_time` timestamp(0) NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE
= InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES (1, '小慕', 'admin', '123456', '2020-07-20 16:53:19', '2020-07-20 16:53:19', NULL);

2.3 商品表

商品模块需要一个商品表 goods,商品表包含如下字段(已省略通用字段):

字段名称 字段类型 字段长度 允许为 NULL 默认值 注释
name varchar 100 商品名
description varchar 255 空字符串 简介
category_id int 11 0 分类 id
price dicimal 10, 2 价格
stock int 11 0 库存

链接 MySQL 并选择 goods_cms 数据库,执行以下 SQL:

-- ----------------------------
-- Table structure for goods
-- ----------------------------
DROP TABLE IF EXISTS `goods`;
CREATE TABLE `goods` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '',
`description` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '',
`category_id` int(11) NULL DEFAULT 0,
`price` decimal(10, 2) NOT NULL,
`stock` int(11) NULL DEFAULT 0,
`create_time` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP,
`update_time` timestamp(0) NOT NULL DEFAULT CURRENT_TIMESTAMP,
`delete_time` timestamp(0) NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE
= InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of goods
-- ----------------------------
INSERT INTO `goods` VALUES (1, '测试商品1', '', 0, 12.30, 3, '2020-07-20 16:53:19', '2020-07-20 16:53:19', NULL);
INSERT INTO `goods` VALUES (2, '测试商品2', '', 0, 33.20, 10, '2020-07-20 17:17:53', '2020-07-20 17:17:53', NULL);
INSERT INTO `goods` VALUES (3, '测试商品3', '', 0, 20.00, 50, '2020-07-20 17:18:09', '2020-07-20 17:18:09', NULL);

2.4 分类表

分类模块需要一个商品表 category,分类表包含如下字段(已省略通用字段):

字段名称 字段类型 字段长度 允许为 NULL 默认值 注释
name varchar 100 商品名
description varchar 255 空字符串 简介

链接 MySQL 并选择 goods_cms 数据库,执行以下 SQL:

-- ----------------------------
-- Table structure for category
-- ----------------------------
DROP TABLE IF EXISTS `category`;
CREATE TABLE `category` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '',
`description` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

至此,我们的数据库和表已经建立完成。

3. 小结

本小节,我们一起创建了数据库和表,表结构比较简单,下一小节,我们将着手业务代码的实现。

微信公众号

Java从零开始(47)数据库设计
扫码关注


原文始发于微信公众号(老徐说):Java从零开始(47)数据库设计

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/19283.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!