mysql学生选课系统的关系模型_使用PowerDesigner搭建学生选课管理系统(学生老师管理员一体系结构)由基础设计至数据库生成(SQL语句源代码的生成)全过程实例操作...

思考构图大小及范围

首先,我们大致的写出要建的几张表,并自定义其Code(所谓Code其实就是自定义一个字段名,因为SQL语句不能由中文)

我们可以将不同的表按照不同的类型分开,这样一个类型的表可以一起建并且相互之间的关系不会弄混

4d80f5b15b76d8761b84af43a987f3b2.png

制作概念模型

我们建立管理员表、老师表、学生表,起初每张表的属性没有必要填的过于全面,我们开始要注重的是表之间的关系,表的属性可以在后面添加

1、建第一类表

老师和学生之间是多对多的关系(n:n)

学生和管理员之间是多对多的关系(n:n)

管理员和老师之间是多对多的关系(n:n)

2f89c096ba24f4fac0995ebb9415fa64.png

2、建第二类表,并完善一、二类表相互之间的关系

班级和专业之间是多对一的关系(n:1)

专业和学院之间是多对一的关系(n:1)

学生和班级之间是多对一的关系(n:1)

学生和专业之间是多对一的关系(n:1)

学生和学院之间是多对一的关系(n:1)

老师和学院之间是多对一的关系(n:1)

管理员和学院之间无关系

c43ba146213f835402dd15eed872451b.png

3、建第三类表,并完善类表相互之间的关系

开课和老师之间是多对多的关系(n:n)

开课和管理员之间是多对多的关系(n:n)

选课和学生之间是多对多的关系(n:n)

选课和管理员之间是多对多的关系(n:n)

课程和学生之间是多对多的关系(n:n)

课程和老师之间是多对多的关系(n:n)

课程和管理员之间是多对多的关系(n:n)

成绩和学生之间是多对多的关系(n:n)

成绩和老师之间是多对一的关系(n:1)

成绩和管理员之间是多对多的关系(n:n)

6d3cf3333c9887528277f568d5373467.png

4、建第四类表,并完善类表相互之间的关系

公告和老师之间是多对一的关系(n:1)

公告和管理员之间是多对多的关系(n:n)

1d1b9be0a459f6e51318196b125f431f.png

属性的添加

给每一张表添加属性

其中name(名字)

code(数据库中的字段名)

Data Type(数据类型)

length(数据类型的长度)

M:Mandatory 是否为必填项 即非空

P:Primary Identifer 是否为主键

D:Displayed 是否可见

每一张表的主键,都不允许被其它任何一张表作为属性使用

学生表

1238fae91749caeea048f726f371c3a2.png

老师表

224df8c330d1fdfb2f411efd5e4c409c.png

管理员表

2adb9ad20d2968794db0199e12a78286.png

班级表

4049fc8b8492c27597d7c3591a90376d.png

专业表

7ea9ec89068c47a3d3723a695814ca5c.png

学院表

553f2aa72e544223c6eed073042f4940.png

开课表

de57847e6961f6ffabe9f10cf691c34f.png

选课表

b1a9348b19ed8c6cbfa1bda67befcf31.png

课程表

09db6c59203aa47b2d7a76845c030927.png

成绩表

92863def79c477d9aa8b023501f27064.png

公告表

e431e99871ca4b1b3692c6ebb87b2406.png

概念模型整体构图:

b372b362df142a5973220f6d111b434f.png

402331340d9daa9584febf2600090adc.png

模型检测

→ 工具 → 【Check Model】

f034802e383d31ae5c3ba5e901f91c0e.png

出现 [Check Model Parameters] 对话框。

b8fd3f2eaca9699d07bdb5a8fd5fbf8b.png

运行后,警告属于正常现象

67a59930e551726745fa65a37dd48606.png

生成物理模型

→ 工具 → 【Generate Physical Data Model】

d22bcab2b1fc3e05a82768097ba02b35.png

12bbe3cedb4bf8c74cd2304e94384e15.png

物理模型整体构图:

ba829c786b3793818291ba76cd9db3ef.png

a2d6847f0d7c4475d2e0d7a4390bde0c.png

pk: 主键

fk: 外键

生成数据库

→ 数据库 → 【Generate Database】

45918d7822e93971b42a217b5ea33f51.png

05c91c0781961abeaffcb6625dd1ab0d.png

生成的sql语句如下:

d56ca171269ea3f3007b5c0bc7bab85b.png

工作空间、概念模型、物理模型、sql源代码:

链接:https://pan.baidu.com/s/1O0dLB3km5h2xN045Go2qbA

提取码:ukkp

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357818.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java实现飞机大战游戏

导读:现如今,随着智能手机的兴起与普及,加上5G(the 5th Generation mobile communication ,第5代移动通信技术)网络的深入,越来越多的IT行业开始向手机行业转移重心。而手机行业中游戏方面的利润所占比重较大,并且手机游戏大多数则是由Java语言开发研制的。所以我想顺应…

merge语句使用_使用SQL:2003 MERGE语句的奥术魔术

merge语句使用时不时地,由于以下任何原因,我们不得不将INSERT与UPDATE区分开来感到尴尬: 我们必须至少发表两个声明 我们必须考虑性能 我们必须考虑比赛条件 我们必须在[UPDATE; 如果UPDATE_COUNT 0 THEN INSERT]和[INSERT; 如果例外然后…

UVA 10917 Walk Through the Forest

最短路DP Walk Through the ForestTime Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld & %llu[Submit] [Go Back] [Status] Description Problem C: A Walk Through the Forest Jimmy experiences a lot of stress at work these days, especially sin…

python定义区间[-5、5_有一个数 x 在区间 [-5,0] 内 , 写出其条件表达式 。 (5.0分)_学小易找答案...

【其它】2018应心ABC反应时任务实验数据.sav 请利用上面的实验数据文档,完成本次实验的报告撰写,并上传。 【单选题】“ab”+”c”*2 结果是: (3.0分) 【判断题】元组可以作为集合的元素。 (2.0分) 【判断题】函数中必须包含return语句。 (3.5分) 【判断题】加法运算符可以用来…

java实现愤怒的小鸟游戏

导读:Java语言是一门面向对象的编程语言,它不但汲取了C++语言的各种精髓,而且还抛弃了C++语言里晦涩难懂的多继承和指针等概念,所以Java语言具有的特征便是:功能超强和易用实用。 Jbox2D中不仅集成了大量物理运动学和机械运动学计算,而且也将物理仿真包集成到

为什么应始终将连接池与Oracle XE一起使用

介绍 Oracle Express Edition是Oracle Enterprise Edition的免费版本,其较小的尺寸使其非常方便地测试各种Oracle功能。 根据Oracle文档 ,Express Edition最多可以使用一个CPU和1 GB RAM,但是实际上存在其他限制并不总是很明显。 数据库连接…

异想维度 java_Java实现多字段(维度)复杂排序

//Java 实现多字段排序HashMap map1 new HashMap();map1.put("dataindex0", null);map1.put("dataindex1", 6);map1.put("dataindex2", 1.1);map1.put("id", 1);HashMap map2 new HashMap();map2.put("dataindex0", "…

Linux下mysql的root密码忘记解决方法

方法一: 1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库。 因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的 状态下,其他的用户也可以任意地登录和修改MySQL的信息…

一文教你用java实现愤怒的小鸟游戏

导读:Java语言是一门面向对象的编程语言,它不但汲取了C语言的各种精髓,而且还抛弃了C语言里晦涩难懂的多继承和指针等概念,所以Java语言具有的特征便是:功能超强和易用实用。Jbox2D中不仅集成了大量物理运动学和机械运…

java中大数开方_大数开方(Java版)

Java代码:适合被开方数不超过1000位的。import java.util.*;import java.math.*;public class Main{public static void main(String[] args){Scanner cinnew Scanner(System.in);int tcin.nextInt();BigInteger remainBigInteger.ZERO;BigInteger oddBigInteger.ZE…

WinForm - 两个窗体之间的方法调用

方法1: 所有权法//Form1://需要有一个公共的刷新方法public void Refresh_Method(){  //...} //在调用Form2时,要把Form2的所有者设为Form1Form2 f2 new Form2() ;f2.Owner this;f2.ShowDialog() ; //Form2://在需要对其调用者&#xff0…

一文教你用java实现儿时的超级玛丽游戏

导读:近年来,Java作为一种新的编程语言,以其简单性、可移植性和平台无关性等优点,得到了广泛地应用。J2SE称为Java标准版或Java标准平台。J2SE提供了标准的SDK开发平台。利用该平台可以开发Java桌面应用程序和低端的服务器应用程序…

'mysql_attr_use_buffered_query'_php中mysql操作的buffer知识

php与mysql的连接有三种方式,mysql,mysqli,pdo。不管使用哪种方式进行连接,都有使用buffer和不使用buffer的区别。什么叫使用buffer和不使用buffer呢?客户端与mysql服务端进行查询操作,查询操作的时候如果获…

java开发一款雷电游戏

导读:电脑游戏,是指在计算机上能够运转的游戏软件。这种软件具有较强的娱乐性。电脑游戏的创新和发展与硬件、软件的发展紧密相关。它能够给玩家提供一个虚拟的环境,使游戏带给了人们很多的享受和欢乐。雷电游戏因为操作简单,节奏明快,一直是纵轴射击游戏的经典之作。经常…

glassfish_具有GlassFish和一致性的高性能JPA –第2部分

glassfish在我的四部分系列的第二部分中,我将解释将Coherence与EclipseLink和GlassFish结合使用的第一个策略。它描述了配置带有Coherence的JPA支持的Cache所必须采取的步骤,以及如何在GlassFish中使用它。高性能数据存储。 一般的做法 您可以将Coherenc…

java开发一个连连看小游戏

导读:连连看是一种消除类益智游戏,核心要求是在规定的时间内,消除游戏界面中选中的两张相同的图案,直至完全消除所有图案。这款游戏操作简单(只需单击鼠标左键操作)、面向人群广泛,在限时操作的游戏要求下,吸引玩家自发地锻炼观察能力、判断能力和反应能力,故从推出至今…

将java.util.concurrent.BlockingQueue用作rx.Observable

在Java中,经典的生产者-消费者模式相对简单,因为我们有java.util.concurrent.BlockingQueue 。 为了避免繁忙的等待和容易出错的手动锁定,我们只需利用put()和take() 。 如果队列已满或为空,它们都将阻塞。 我们需要的…

Mac OS X 10.10如何打开虚拟内存

转载请注明出处:http://www.cnblogs.com/blazer/p/5103608.html 禁用虚拟内存sudo launchctl unload -w /System/Library/LaunchDaemons/com.apple.metadata.mds.plist删除交换文件sudo rm /private/var/vm/swapfile*启用虚拟内存sudo launchctl load -w /System/L…

java 1.5.0 gcj_CentOS安装JAVA后JAVA版本不对的问题

今天用CentOS安装JDK,发觉在安装完成后,输入java命令来验证是否安装成功时,出现Usage: gij [OPTION] ... CLASS [ARGS] ...to invoke CLASS.main, orgij -jar [OPTION] ... JARFILE [ARGS] ...to execute a jar fileTry gij --help‘ for mor…

java开发一款模拟写字板系统

导读:目前,很多新的技术领域都涉及到了Java语言,Java语言是面向对象编程,并且涉及到网络、多线程等重要的基础知识,因此Java语言也是学习面向对象编程和网络编程的首选语言。此简易JAVA写字板程序,使用Java程序编写,能够进行输入文字操作,并具有新建文件,打开文件,保…