java数据库课程设计报告

2,数据库设计

2.1 数据库设计简介

  • 软件的研发步骤

java数据库课程设计报告

  • 数据库设计概念
    • 数据库设计就是根据业务系统的具体需求,结合我们所选用的DBMS,为这个业务系统构造出最优的数据存储模型。
    • 建立数据库中的表结构以及表与表之间的关联关系的过程。
    • 有哪些表?表里有哪些字段?表和表之间有什么关系?
  • 数据库设计的步骤
    • 需求分析(数据是什么? 数据具有哪些属性? 数据与属性的特点是什么)
    • 逻辑分析(通过ER图对数据库进行逻辑建模,不需要考虑我们所选用的数据库管理系统)
    • 如下图就是ER(Entity/Relation)图:

java数据库课程设计报告

    • 物理设计(根据数据库自身的特点把逻辑设计转换为物理设计)
    • 维护设计(1.对新的需求进行建表;2.表优化)
  • 表关系
    • 一对一
      • 如:用户 和 用户详情
      • 一对一关系多用于表拆分,将一个实体中经常使用的字段放一张表,不经常使用的字段放另一张表,用于提升查询性能

java数据库课程设计报告

    • 上图左边是用户的详细信息,而我们真正在展示用户信息时最长用的则是上图右边红框所示,所以我们会将详细信息查分成两周那个表。
    • 一对多
      • 如:部门 和 员工
      • 一个部门对应多个员工,一个员工对应一个部门。如下图:

java数据库课程设计报告

    • 多对多
      • 如:商品 和 订单
      • 一个商品对应多个订单,一个订单包含多个商品。如下图:

java数据库课程设计报告

2.2 表关系(一对多)

  • 一对多
    • 如:部门 和 员工
    • 一个部门对应多个员工,一个员工对应一个部门。
  • 实现方式
  • 在多的一方建立外键,指向一的一方的主键
  • 案例
  • 我们还是以 员工表 和 部门表 举例:

java数据库课程设计报告

  • 经过分析发现,员工表属于多的一方,而部门表属于一的一方,此时我们会在员工表中添加一列(dep_id),指向于部门表的主键(id):

java数据库课程设计报告

  • 建表语句如下:
  • — 删除表

    DROP TABLE IF EXISTS tb_emp;

    DROP TABLE IF EXISTS tb_dept;

    — 部门表

    CREATE TABLE tb_dept(

    id int primary key auto_increment,

    dep_name varchar(20),

    addr varchar(20)

    );

    — 员工表

    CREATE TABLE tb_emp(

    id int primary key auto_increment,

    name varchar(20),

    age int,

    dep_id int,

    — 添加外键 dep_id,关联 dept 表的id主键

    CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES tb_dept(id)

    );

  • 查看表结构模型图:

java数据库课程设计报告

2.3 表关系(多对多)

  • 多对多
    • 如:商品 和 订单
    • 一个商品对应多个订单,一个订单包含多个商品
  • 实现方式
  • 建立第三张中间表,中间表至少包含两个外键,分别关联两方主键
  • 案例
  • 我们以 订单表 和 商品表 举例:

java数据库课程设计报告

  • 经过分析发现,订单表和商品表都属于多的一方,此时需要创建一个中间表,在中间表中添加订单表的外键和商品表的外键指向两张表的主键:

java数据库课程设计报告

  • 建表语句如下:
  • — 删除表

    DROP TABLE IF EXISTS tb_order_goods;

    DROP TABLE IF EXISTS tb_order;

    DROP TABLE IF EXISTS tb_goods;

    — 订单表

    CREATE TABLE tb_order(

    id int primary key auto_increment,

    payment double(10,2),

    payment_type TINYINT,

    status TINYINT

    );

    — 商品表

    CREATE TABLE tb_goods(

    id int primary key auto_increment,

    title varchar(100),

    price double(10,2)

    );

    — 订单商品中间表

    CREATE TABLE tb_order_goods(

    id int primary key auto_increment,

    order_id int,

    goods_id int,

    count int

    );

    — 建完表后,添加外键

    alter table tb_order_goods add CONSTRAINT fk_order_id FOREIGN key(order_id) REFERENCES tb_order(id);

    alter table tb_order_goods add CONSTRAINT fk_goods_id FOREIGN key(goods_id) REFERENCES tb_goods(id);

  • 查看表结构模型图:

java数据库课程设计报告

2.4 表关系(一对一)

  • 一对一
    • 如:用户 和 用户详情
    • 一对一关系多用于表拆分,将一个实体中经常使用的字段放一张表,不经常使用的字段放另一张表,用于提升查询性能
  • 实现方式
  • 在任意一方加入外键,关联另一方主键,并且设置外键为唯一(UNIQUE)
  • 案例
  • 我们以 用户表 举例:

java数据库课程设计报告

  • 而在真正使用过程中发现 id、photo、nickname、age、gender 字段比较常用,此时就可以将这张表查分成两张表。

java数据库课程设计报告

建表语句如下:

create table tb_user_desc ( id int primary key auto_increment, city varchar(20), edu varchar(10), income int, status char(2), des varchar(100) ); create table tb_user ( id int primary key auto_increment, photo varchar(100), nickname varchar(50), age int, gender char(1), desc_id int unique, -- 添加外键 CONSTRAINT fk_user_desc FOREIGN KEY(desc_id) REFERENCES tb_user_desc(id) );

查看表结构模型图:

java数据库课程设计报告

2.5 数据库设计案例

根据下图设计表及表和表之间的关系:

java数据库课程设计报告

经过分析,我们分为 专辑表 曲目表 短评表 用户表 4张表。

java数据库课程设计报告

一个专辑可以有多个曲目,一个曲目只能属于某一张专辑,所以专辑表和曲目表的关系是一对多。

一个专辑可以被多个用户进行评论,一个用户可以对多个专辑进行评论,所以专辑表和用户表的关系是 多对多。

一个用户可以发多个短评,一个短评只能是某一个人发的,所以用户表和短评表的关系是 一对多。

java数据库课程设计报告

本文【java数据库课程设计报告】由作者: 递归 提供,本站不拥有所有权,只提供储存服务,如有侵权,联系删除!
本文链接:https://www.cuoshuo.com/blog/4513.html

(0)
上一篇 2023-03-14 09:02:16
下一篇 2023-03-15 08:01:31

相关推荐

  • 电脑显示器花屏自修方法(电脑显示器花屏横条纹闪)

    显示器花屏是一个让人非常头疼的问题,久而久之可能会影响到电脑的正常使用。花屏可以简单理解为显示器内出现了一些杂乱无章的彩色点和条纹,影响着显示器的视觉效果。那么显示器花屏能修吗? 1、原因分析:显示器花屏的原因有很多,它们可能是由于显示器的芯片出现了错误或者其他故障所导致的,也可能是由于显卡和显示器之间的适配问题所导致的,甚至可能是显示器外壳内部聚集了大量灰…

    2023-03-13
    400
  • 学生成绩信息管理系统

    随着信息化管理模式不断的普及开来,培训机构都在寻找学生信息管理系统来规范学校管理,促进信息化的早日实现,那么像这类学生信息成绩管理系统一般包含的功能有哪些呢? 都说是学生信息管理系统,那么肯定少不了学生功能管理方面了,比如从学生报名缴费开始、到后期的考勤排课管理、课时查询和消耗管理、学生成绩管理、升班转班退班管理这些功能都应该是系统具备的,才能够满足学生日常…

    2023-03-14
    100
  • 苹果电脑如何删除用户_苹果电脑无法删除管理员账户

    Mac在macOS Monterey 或 Big Sur 中没有管理员帐户怎么办?为大家带来了修复方法,一起来看看吧。 缺少Mac管理员帐户?在macOS中创建新的管理员帐户 此过程将涉及启动到恢复模式以从 Mac 中删除设置文件,这允许 macOS 设置助手再次运行,从而允许您在 Mac 上创建新的管理员帐户。这适用于 macOS Monterey 和 B…

    2023-03-10
    500
  • 数据库原理与应用教程第三版答案

    广开-形考-10546管理学基础 1、下述对于信息沟通的认识中,哪一条是错误的() 2、按照沟通的渠道或途径不同,沟通可以分为( ) 3、领导者和非领导者的差异在于领导者具有一些可被确认的基本特性,持这种,的理论被称为() 4、比较链式与网式两种信息沟通网络的特点,可以得出以下结论( ) 5、控制工作中,评估和分析偏差信息时,首先要() 6、预算是一种( )…

    2023-03-18
    100
  • 学软件开发多少钱合适_学编程多少钱学费

    众所周知,IT互联网方向的岗位就业比较好而且薪资也高,所以很多人都想往软件开发这个方向走,但学费并不是特别便宜。下面深圳市科创职业技能培训学校的老师们整理了学软件开发的培训学费,希望对你有所帮助! 要说软件工程师培训班的收费标准,从目前的情况来看,并没有一个标准,基本上都是由培训班自己定,不同培训班、不同的时间和时长,学费也有所差异。 而除了一般的培训机构,…

    2023-03-12
    1100
  • windowsphone开发者选项,手机的开发者选项在哪

    首先,“开发者模式”是对手机进行开发,高级调试时使用的一种模式。新手机都不会显示这个模式。但是,我们为了使手机更流畅,更好地使用手机就有必要打开这个模式。在这篇文章里,我讲一下怎么打开,打开后要设置哪几个地方。 下面进入正题。 1.在手机设置里,找到 “关于手机” 这个选项并点开。 2.找到 “版本信息”并点开。 3.找到 “软件版本号”,并连续点击五次。 …

    2023-03-14
    400
  • php套件安装

    LAMP 套件是一种流行的开源 Web 开发平台,可用于运行和部署动态网站和基于 Web 的应用程序。 (本文字数:9231,阅读时长大约:11 分钟) LAMP套件是一种流行的开源 Web 开发平台,可用于运行和部署动态网站和基于 Web 的应用程序。通常,LAMP 套件由 Apache Web 服务器、MariaDB/MySQL 数据库、PHP/Pyth…

    2023-03-16
    200
  • jsp 一句话木马(asp一句话木马)

    什么是一句话木马? Webshell:webshell就是以网页文件形式存在的一种命令执行环境,也可以将其称之为一种网页后门,顾名思义,web的含义是显然需要服务器开放web服务,shell的含义是取得对服务器某种程度上的操作权限。 Webshell通常被叫做入侵者通过网站端口对网站服务器的某种程度上操作的权限,由于webshell大多数是以动态脚本的形式出…

    2023-03-14
    200
  • svn客户端发送意外返回值413

    SVN库创建完成后,通过SVN客户端来上传和获取相应资源。 SVN客户端提供如下功能: 01客户端的安装 运行TortoiseSVN程序,点击“Next”下是的截图顺序即为安装步骤: 图1: 图2: 图3: 图4: 图5: 点击“finish”按钮之后会提示重启系统 02浏览版本库 1) 对服务器上的文档可以直接在服务器上操作,在本地任意位置右击选择选择“T…

    2023-03-17
    300
  • 安卓手机usb调试选项在哪里打开(usb调试不弹出授权)

    有的时候,我们手机需要与电脑连接,进行一些文件的传送,但是经常会出现失败的情况。而这里面大部分的原因都只有一个,那就是手机usb调试没有打开。对于手机系统来说,即使使用数据线来连接其他设备。 1、 iQOO手机USB调试开关处于隐藏状态,点击打开设置图标 2、 找到打开“系统管理”选项 3、 进一步在下拉菜单找到“关于手机”选项并打开 4、 找到并打开“版本…

    2023-03-16
    100

发表回复

登录后才能评论
返回顶部
错说博客上线啦!