三、数据需求与数据库设计

article/2025/9/12 4:39:30
  1. 数据需求与数据库设计
    1. 数据需求

项目中主要包含了用户、权限(菜单)、角色三种类型的数据,各种数据包含的数据项如下:

(1)用户:用户名、密码、生日、头像、简介、用户类型

(2)权限:权限名称、描述、链接地址、图标、类型、排序、上级权限

(3)角色:角色名称

    1. 数据库设计
      1. ER图

数据库总体er图如下:

      1. 表设计
  1. 用户表:

CREATE TABLE `t_sys_user` (

  `id` varchar(255) COLLATE utf8_bin NOT NULL,

  `username` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '用户账号',

  `password` varchar(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '用户密码',

  `birthday` datetime DEFAULT NULL,

  `photo` varchar(255) COLLATE utf8_bin DEFAULT NULL,

  `introduce` text COLLATE utf8_bin,

  `usertype` varchar(255) COLLATE utf8_bin DEFAULT '普通用户' COMMENT '1.普通用户;2.超级管理员(不用授权)',

  PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='用户表';

  1. 权限表:

CREATE TABLE `t_sys_permission` (

  `id` varchar(255) NOT NULL COMMENT 'id',

  `name` varchar(255) DEFAULT NULL COMMENT '权限名称',

  `descripion` varchar(255) DEFAULT NULL COMMENT '权限描述',

  `url` varchar(255) DEFAULT NULL COMMENT '授权链接',

  `pid` varchar(255) DEFAULT NULL COMMENT '父节点id',

  `perms` varchar(255) DEFAULT NULL COMMENT '权限标识',

  `type` int(11) DEFAULT '1' COMMENT '类型:1.菜单;2.按钮',

  `icon` varchar(255) DEFAULT NULL COMMENT '菜单图标',

  `order_num` int(11) DEFAULT NULL COMMENT '排序',

  PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='权限表';

(3)角色表:

CREATE TABLE `t_sys_role` (

  `id` varchar(255) NOT NULL COMMENT 'id',

  `name` varchar(255) DEFAULT NULL COMMENT '角色名称',

  PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='角色表';

(4)用户角色表:

CREATE TABLE `t_sys_role_user` (

  `id` varchar(255) NOT NULL,

  `sys_user_id` varchar(255) DEFAULT NULL COMMENT '用户id',

  `sys_role_id` varchar(255) DEFAULT NULL COMMENT '角色id',

  PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户角色中间表';

(5)角色权限表:

CREATE TABLE `t_sys_permission_role` (

  `id` varchar(255) NOT NULL,

  `sys_role_id` varchar(255) DEFAULT NULL COMMENT '角色id',

  `sys_permission_id` varchar(255) DEFAULT NULL COMMENT '权限id',

  PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='角色权限中间表';

      1. 数据导入

(1)安装MySQL

通过安装包“mysql-installer-community-5.7.13.0.exe”,安装mysql5.7,也可以去官网下载安装,但是由于兼容性问题,建议先不要用8.0以上版本。(百度云盘链接:https://pan.baidu.com/s/16sIiQmR-FZ9POXXwf4gKRQ 提取码:cfni

(2)安装navicat

通过安装包“navicat091_lite_cs.exe”安装数据库管理可视化工具,这个是免费版,也可以自己去下载破解版。

(4)创建数据库

用naviat软件连接数据库:

新建一个名称为“oadb”的数据库:

(4)导入表结构和数据:

导入成功后,刷新就能看到表。


http://chatgpt.dhexx.cn/article/uDuS92WN.shtml

相关文章

SQL数据库实战需求分析→数据库设计

从这开始,就真正进入项目实战啦。先说点体会,我刚开始接触编程的时候,都是编写一些小东西,往往都是半天或者一天什么的就编完了,那时候根本没想过做程序之前还要有需求分析。经过快两年的学习,接触的都是比…

数据库性能需求分析及评估模型

数据库作为应用系统当中最重要的一块,也是性能测试非常关注的一块,根据我自己的项目经验,和以往对应用系统的性能需求分析和测试策略制定过程,总结一下如何开展数据库系统的性能需求分析,以及制定数据库能力评估模型。…

互联网应用开发实践:需求分析与数据库设计

在本文中将分析一个用于新生开学分配寝室的“宿舍秒杀”系统。从用户故事开始探索需求,进而分析得到系统的主要功能和非功能性需求。最后,根据需求分析设计数据库,数据库的设计原则是尽可能的方便之后的需求拓展和修改。 用户故事 用户故事一…

数据库应用系统的需求分析

一 需求分析的概念与意义 所谓的需求分析,就是对待开发系统要做什么,完成什么功能的全面描述 软件的一些特性使得需求的获取常常并不容易! 比如软件功能复杂,需求可变性,软件的不可见性 二 获取需求的方法 面谈实地…

数据库设计:需求分析

设计一个性能良好的数据库系统,明确应用环境对系统的要求是首要的和基本的。因此,应该把对用户需求的收集和分析作为数据库设计的第一步。 需求分析的主要任务是通过详细调查要处理的对象,包括某个组织、某个部门、某个企业的业务管理等&…

数据库设计 | 需求分析

一、需求分析要干一个什么样的事情? 通过详细调查现实世界要处理的对象(组织、部门、企业等), 充分了解原系统(手工系统或计算机系统)工作概况, 明确用户的各种需求,然后在此基础上确…

数据库设计之需求分析

需求分析简单地说就是分析用户的需求。根据分析是设计数据库的起点,需求分析结果是否准确反映用户的实际要求将直接影响到后面各阶段的设计,并影响到设计结果是否合理和实用。 1. 需求分析的任务 需求分析的任务是通过详细调查现实世界要处理的对象(组…

数据库技术-数据库需求分析、数据流概念

目录 需求分析 数据流 结构化分析案例-教材销购案例 例题讲解 每文一语 需求分析 1、需求分析的概念与意义 需求是指用户对软件的功能和性能的要求,就是用户希望软件能做什么事情,完成什么样的功能,达到什么性能。 需求分析是在计算机…

matlab gui 教学,新手入门教程(一)文本框和按钮的使用

matlab gui 教学,新手入门教程(一)文本框和按钮的使用 一、新建文件二、添加控件 一、新建文件 1、在MATLAB命令行中输入guide。 2、回车,进入GUI的界面,选择新建GUI–Blank GUI(Default)–浏览(自定义存储…

零基础入门MATLAB(一篇十分钟)

目录 一、复数 二、取整函数 三、无穷量(Inf)和非数值量(NaN) 四、逻辑类型 五、字符和字符串 六、函数句柄 七、结构体 八、数组类型 九、单元数组 十、map容器类型 参考《MATLAB R2020a 完全自学一本通》 一、复数 …

matlab如何使输出结果更美观(symdisp函数——pretty函数升级版)

matlab中有些计算结果比较长,直接查看有些困难,下面介绍pretty和symdisp函数优化输出结果,使结果更为直观。 演示示例1 有一个计算结果如下: >> f1f1 y^5 (- w - y0)*y^4 1800*y^3 (1498200*w - 1800*y0)*y^2 (3600*w…

Matlab中textscan函数用法

目录 语法 说明 示例 读取浮点数 读取不同类型的数据 删除字面文本 跳过每行的其余部分 指定分隔符和空值转换 指定要视为空或注释的文本 将重复的分隔符视为一个分隔符 指定重复的转换设定符并收集数值数据 读取或跳过引用文本和数值字段 读取外语日期 读取非默…

【MATLAB学习笔记01】【快速入门】初识MATLAB的界面和编辑脚本的基础知识

打开MATLAB后,建议各位新手,先随便按下各个按键,熟悉下总体的页面布局,并且对各个按键的功能有点印象,这样可以更容易上手。 主要功能区(下图用红色方框圈出来的位置): 命令行窗口…

零基础入门Matlab(一篇两个小时就能学完的入门博客)

目录 零基础入门matlab前言1.界面认识2.变量命名3.数据类型4.元胞数组和结构体5.矩阵操作6.程序结构7.基本绘图操作7.1.二维平面绘图7.2.三维立体绘图 8.图形的保存与导出9.补充 零基础入门matlab 前言 这篇文章很适合MATLAB的入门学习,这也是我在入门时学习的笔记…

MATLAB中text函数使用

目录 语法 说明 示例 向数据点添加文本说明 向多个数据点添加文本 显示多行文本 指定文本大小和颜色 修改现有文本 text函数的功能是向数据点添加文本说明。 语法 text(x,y,txt) text(x,y,z,txt) text(___,Name,Value) text(ax,___) t text(___) 说明 text(x,y,…

matlab中实现文字和数字和混输出excel

做一个小程序时,需要数据和文字混合输出到,直接构建这样的矩阵在matlab中行不通 于是有了下列的代码: %输出excel表格 excel_outpathF:\Work\paper_work\parallel_simulation\code\excel\test.xlsx;%输出路径 %构建表头 rtnxlswrite(excel_…

使用layui 查询列表分页不能重置问题

使用layui的table.render({})函数可以快速的帮自己建立一个表格 但是我发现自己的表格在使用搜索按钮后,无法定位到搜索当前数据的第一页,这里可以使用监听搜索在执行重载中,将当前页curr重置为1即可

Java代码重置kafka0.10.1.0版本的偏移量offset

如果使用的自动提交偏移量的模式,偏移量会给到kafka或者zk进行管理,其中kafka的偏移量重置给了重新消费kafka内未过期的数据提供了机会,当消费者出错,比如消费了数据,但是中途处理失败,导致数据丢失&#x…

Java重置Mysql主键自增长值

MySql 主键自增重置器(统一处理多个表) resetAutoincrement 是一款基于 Java 开发的程序,其功能为重置 mysql 数据库表的主键自增的值为最近的一个。 介绍 开发背景主要是工作中,测试同学在清理数据的时候,使用的是 D…