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…

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

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

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桌面应用程序和低端的服务器应用程序…

java开发一款雷电游戏

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

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

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

java开发一个连连看小游戏

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

java枚举的特点_Java中有些好的特性(二):枚举

前言我在写上一篇时,开始选了一个很土的名字“Java超过C#的地方”,然后引起了某些同学的不满,后来修改了个名。我在这里再次申明一下,我没有贬低任何语言之意,纯粹是从一个.NET程序员的角度去看Java,看看是…

java开发一款推箱子游戏

导读:社会在进步,人们生活质量也在日益提高。高强度的压力也接踵而来。社会中急需出现新的有效方式来缓解人们的压力。此次设计符合了社会需求,Java推箱子游戏可以让人们在闲暇之余,体验游戏的乐趣。具有操作简单,易于上手的特点。 推箱子游戏的玩法十分简单——控制人物绕…

java ee技术_Java EE 6与Spring Framework:技术决策过程

java ee技术在过去的几个月中,我们经历了这个决策过程:为Java平台上的企业开发选择哪种技术堆栈? 有多种选择。 但是,我们深入讨论的是:纯Java EE 6堆栈与带有Java EE的Spring。 以下博客文章总结了当您考虑这些技术堆…

java开发一款坦克大战游戏

导读:随着人们对生活质量的要求一天比一天高,为了让人们更好地开掘自身的智慧,游戏就此进入了大众的视野,在人们的生活中有着重要的位置,已然变得必不可少。游戏产业推动高新技术不断升级,极大地促进了经济的增长,推动了“第四产业”的经济腾飞。坦克大战游戏是童年时期…

java大转盘抽奖概率算法_幸运大转盘抽奖 抽奖算法 程序实现逻辑

近期碰到的一个需求,实现一个类似大转盘抽奖的功能,需自定义奖项,各奖项中奖概率,当日抽奖最大次数,抽奖成本等。分享一个简单的java代码的实现的思路,有不足之处感谢各位指正。初步方法首先要定义几个奖品…

java开发银行柜员业务绩效考核系统

导读:当今社会己进入信息社会时代,信息己经受到社会的广泛关注,被看作社会和科学技术发展的三大支柱(材料、能源、信息)之一。信息是管理的基础,是进行决策的的基本依据。在一个组织里,信息己作为人力、物力、财力之外的第四种能源,占有重要的地位。然而,信息是一种非…

一文教你使用java开发一款坦克大战游戏

导读:随着人们对生活质量的要求一天比一天高,为了让人们更好地开掘自身的智慧,游戏就此进入了大众的视野,在人们的生活中有着重要的位置,已然变得必不可少。游戏产业推动高新技术不断升级,极大地促进了经济…

Java 8流中的常见SQL子句及其等效项

功能编程允许使用通用语言进行准声明性编程 。 通过使用功能强大的流畅API(例如Java 8的Stream API )或jOOλ的顺序Stream扩展Seq或更复杂的库(例如javaslang或functionaljava) ,我们可以以一种非常简洁的方式来表示数…

混合使用Azure LB和ILB访问相同web服务(3)

接下来我们来配置Azure Load balancer,就是面向公网的负载均衡器: 1.在该测试中,为了保持内网访问和外网访问一样的体验,本地端口和public端口和ILB一样,同样是80: PS C:\> Get-AzureVM -ServiceName …

mysql日活统计函数_如何通过简化日活模型,预估一个产品的日活(DAU)?

本文笔者通过简化日活模型,粗略地估算出未来一段时间的产品日活规模。进而通过日活的规模,再去估算一些潜在收益,以及运营成本等等数据。这段时间,经常有人问到以下的问题:按照现在的推广和留存,我们在未来…

罐中研讨会:设置JBoss BPM Suite全天研讨会

是否在寻找一种简单的方法来宣传,展示或演示JBoss业务流程管理套件(BPM Suite)产品的入门难度? 别无所求,因为我们召集了这个研讨会,因此您可以围绕JBoss BPM Suite构建一个晚上,半天或全天的…