本节以教育管理系统为例来介绍数据库的创键和数据表的设计
案例需求:
1.教务管理系统用来帮助高校学生选修课程。
2.学生可以通过系统查看所有选修课的相关信息,包括课程名,学时,学分,也可以查看相关授课老师的信息。
3.老师的信息包括教师姓名,性别,学历,职称,还可以通过系统查看自己的考试成绩。
4.老师通过系统可以查看选修自己课程的学生信息,包括学号,性别,姓名,出生日期,班级,也可以通过系统录入学生的考试成绩。
用Widows10控制命令行做数据库!
第一步:创建"教务管理系统"的数据库!


第二步:根据案例要求创建相关数据表
1.创建学生MySQL数据表
①创建学生信息表
| 序号 | 列名 | 数据类型 | 允许空值 | 约束 | 备注 |
| 1 | stnum | char(8) | NO | 主键 | 学号 |
| 2 | stname | varchar(10) | NO | 姓名 | |
| 3 | stgender | char(2) | YES | 性别 | |
| 4 | stbrith | date | YES | 出生日期 | |
| 5 | stclass | varchar(20) | YES | 班级 |
②根据"学生信息表"撰写MySQL数据表

2.创建教师MySQL数据表
①创建教师信息表
| 序号 | 列名 | 数据类型 | 是否允许空值 | 约束 | 备注 |
| 1 | teanum | char(8) | NO | 主键 | 教工号 |
| 2 | teaname | varchar(20) | NO | 教师姓名 | |
| 3 | teagender | char(2) | NO | 性别 | |
| 4 | teaacademic | vrchar(20) | NO | 学历 | |
| 5 | teaprofessional | varchar(8) | YES | default"副教授" | 职称 |
②根据"教师信息表"撰写MySQL数据表

3..创建课程MySQL数据表
①创建课程信息表
| 序号 | 列名 | 数据类型 | 是否允许为NULL值 | 约束 | 备注 |
| 1 | counum | char(4) | NO | 主键 | 课程号 |
| 2 | couname | varchar(40) | YES | 唯一约束 | 课程名 |
| 3 | coutime | int (50) | YES | 学时 | |
| 4 | coucredit | Decimal(3.1) | NO | 学分 | |
| 5 | couteacher | char(4) | NO | 是教师表的外键 | 授课教师 |
②根据"课程信息表"撰写MySQL数据表

4.创建选课信息表
①创建选课信息表
| 序号 | 列名 | 数据类型 | 是否允许为空值 | 约束 | 备注 |
| 1 | counum | char(4) | NO | 主键/课程表的外键 | 课程号 |
| 2 | stnum | char(8) | NO | 主键/学生表的外键 | 学号 |
| 3 | source | int | NO | 成绩 |
②根据"课程信息表"撰写MySQL数据表

第三步:检验"教务管理系统"数据库创建结果
①检验数据库创建结果:

②检查数据表


③检查外键
通过select*from information_schema.KEY_COLUMN_USAGE;这条命令查询数据库中所有表的外键和主键

出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
我正在使用i18n从头开始构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在rubyonrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
如何使用RSpec::Core::RakeTask初始化RSpecRake任务?require'rspec/core/rake_task'RSpec::Core::RakeTask.newdo|t|#whatdoIputinhere?endInitialize函数记录在http://rubydoc.info/github/rspec/rspec-core/RSpec/Core/RakeTask#initialize-instance_method没有很好的记录;它只是说:-(RakeTask)initialize(*args,&task_block)AnewinstanceofRake
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我正在阅读SandiMetz的POODR,并且遇到了一个我不太了解的编码原则。这是代码:classBicycleattr_reader:size,:chain,:tire_sizedefinitialize(args={})@size=args[:size]||1@chain=args[:chain]||2@tire_size=args[:tire_size]||3post_initialize(args)endendclassMountainBike此代码将为其各自的属性输出1,2,3,4,5。我不明白的是查找方法。当一辆山地自行车被实例化时,因为它没有自己的initialize方法
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳