学生、教师和教务处的数据对象(实体集)用关系(表)来定义。ER中实体集的属性对应于表中的列(字段、属性);ER中实体集中的每个实体实例对应于表中的行(元组、记录)。例如,学生信息表包括学号、姓名、性别、班级、班主任、照片、入学年份等列。
选课情况、成绩情况、综合信息等也是通过表来描述。例如,选课表包括学号、姓名、班级、课程名称、任课老师、学分、成绩、学期等列。成绩表则包括学号、姓名、班级、课程名称、成绩、班平均分、最高分、最低分、不及格人数等列。
在关系模式中,联系也可以用表来描述。例如,选课联系可以通过选课表来描述,其中有来自学生和课程两个实体的属性,而成绩是选课联系自身的描述属性。
表的取值范围称为域。例如,成绩的范围一般是0-100。
在应用程序中,可以通过TQuery或TADOquery部件来执行SQL程序。这些部件的SQL属性只能包含一条完整的SQL语句,不允许被设置成多条SQL语句。如果数据库服务器支持在SQL属性中设置多条SQL语句,那么编程时也可以这样设置。
在设置完TQuery或TADOquery部件的SQL属性之后,可以通过调用其Open方法或ExecSQL方法来执行SQL程序。Open方法只能用来执行SQL语言的查询语句,并返回一个查询结果集,而ExecSQL方法还可以用来执行其它常用的SQL语句。
在设计过程中,设置完TQuery或TADOquery部件的SQL属性之后将其Active属性的值置为True,这样便可以执行SQL属性中的SQL程序。如果应用中有与TQuery或TADOquery部件相连的数据浏览部件,那么在这些数据浏览部件中会显示SQL程序的执行结果。
在应用程序运行过程中,通过程序调用TQuery或TADOquery组件的Open方法或ExecSQL方法可以执行其SQL属性中的SQL程序。当然在设计应用程序时,程序设计人员是无法确定TQuery或TADOquery组件中的SQL语句是否会返回一个查询结果的。对于这种情况应当用Try…Except模块来设计程序。在Try部分调用Open方法,而在Except部分调用ExceSQL方法,这样才能保证程序的正确运行。
关于nSQL中的SUM和AVG运算符限制
对于使用nSQL进行数据库查询的情况,有些特殊限制需要注意。例如,在SQL语句中不能直接使用聚集运算符SUM或AVG进行运算。如果是针对Sybase数据库进行查询,被查询的表中只能存在一个索引。如果应用程序中的TQuery或TADOquery组件要求返回一个动态的查询结果数据集,但在SQL命令中违反了上述约束条件,那么在本地数据库查询时,BDE只能返回只读的数据集。而对于数据库服务器中的查询,则可能只能返回错误代码。当Tquery或TADOquery组件成功返回动态查询结果数据集时,其CanModIfy属性的值会被设置为True。
关于MSSQLServer的概述
SQLServer是一个功能强大的后台数据库管理系统,操作简便,受到广大数据库用户的喜爱。随着技术的发展,越来越多的开发工具提供了与SQLServer的接口。SQLServer最初是由Microsoft、Sybase和Ashton-Tate三家公司共同开发的,于1988年推出了首个OS/2版本。随着WindowsNT的推出,Microsoft和Sybase在SQLServer的开发上走上了不同的道路,Microsoft专注于开发推广SQLServer的WindowsNT版本。
SQLServer2000是Microsoft公司推出的版本的数据库管理系统,它继承了SQLServer7.0的优点,并增加了许多先进的功能,如使用方便、可伸缩性好、与相关软件集成程度高。此版本可以在从运行MicrosoftWindows98的膝上型电脑到运行MicrosoftWindows2000的大型多处理器的服务器等多种平台上使用。MSSQLServer不仅可以应用于大中型数据库管理中,建立分布式关系数据库,还可以开发桌面数据库。尽管其基本结构采用关系型数据库模式,但其操作方式和精神更偏向于面向对象。也就是说,SQLServer的所有功能都可以基于已经建立好的对象来实现,是一个相当面向对象的系统结构。
SQLServer的主要管理工具——企业管理器
SQLServer企业管理器是SQLServer的主要管理工具,它提供了一个遵循MMC标准的用户界面,使用户可以:
定义SQLServer实例组;
将个别服务器注册到组中;
为每个已注册的服务器配置所有SQLServer选项;
创建并管理所有SQLServer数据库、对象、登录、用户和权限;
定义并执行所有SQLServer管理任务;
通过唤醒调用SQL查询分析器,交互地设计并测试SQL语句、批处理和脚本;
唤醒调用为SQLServer定义的各类向导。
图书管理系统设计分析
借阅者与图书管理系统
一、借阅者信息
借阅者信息包括:借书证号、姓名、性别、身份证号、联系电话以及密码等关键信息。这些信息是借阅者进行借阅操作的基础,也是系统进行身份验证的依据。
二、身份信息管理
身份信息包括:身份编号、身份描述以及最大借阅数等。一个借阅者只能拥有一种身份,但一种身份可以被多个借阅者所拥有。
三、图书类别管理
图书类别由图书类别编号和类别描述构成,用于对图书进行分类管理。
四、ER模型中的实体关系
在ER模型中,需要刻画实体之间的关联。这包括考察局部结构中任意两个实体类型之间是否存在联系,如有联系则需确定其具体类型(如1:N,M:N,1:1等)。还需考虑一个实体类型内部及多个实体类型之间的联系。这些联系的定义如图4-5所示。
五、全局ER模式设计
设计全局ER模式的步骤包括:确定公共实体类型,合并局部ER模式,消除冲突以及优化全局ER模式。其中,合并的原则是先合并那些现实世界中有联系的部分,再从公共实体类型开始合并,最后加入独立的局部结构。设计的目的是为了消除冲突,形成一个能被所有用户共同理解和接受的概念模型。
六、关系数据库的逻辑设计
关系数据库的逻辑设计过程是将ER图转化为关系模式的过程。这个过程需要导出初始关系模式,如图书信息表、借阅者基本信息表、借阅情况信息表等,并产生子模式以描述用户所用到的数据部分及其与概念模式中相应数据的联系。根据设计中的问题,还需加入其他关系模式以适应系统需求。
七、数据库实现
选用Microsoft SQL Server 2000(企业版)数据库进行逻辑设计。首先创建基本数据库表,然后根据全局ER图建立各个表之间的联系。在实现过程中,为提高效率,需对数据库表结构进行优化,如加入索引字段以唯一标识一条借书记录。
八、数据库应用程序设计
在编写数据库应用程序时,可以采用数据模块来集中管理数据源。数据模块是一个用来集中管理数据源的窗体,可被需要的地方随时引入。考虑到系统的实际需求和管理上的便利性,本系统大多采用动态生成ADOQuery来实现,并使用SQL语句进行动态查询,从而避免数据控件的混淆和浪费资源。
九、系统窗体模块与启动画面实现
系统窗体模块由多个组件和窗体组成,它们共同完成系统的各项功能。启动画面的实现则是为了给用户一个良好的第一印象,加深软件的亲和力。在Form1窗体中加入了Image和Time组件以实现动态的启动画面。具体的源代码和实现方式略过不提。
以上是对原文章的重写,尽量保持了原文的意思和结构,同时对语言进行了调整和优化。这是一个关于图书馆综合管理系统的实现,包括用户登录、密码认证、借阅者服务、工作人员操作、图书馆管理员管理等模块。
用户登录窗体的实现:为三种不同的用户(一般用户,工作人员,管理员)提供选择以进入不同的模块,满足不同用户的需求。
用户密码认证窗体的实现:让工作人员或图书馆管理员按照用户名和密码进行登录,并且根据用户名检查Keyer表中的“权限”字段,以分辩进入图书馆管理人员模块还是进入工作人员模块。
借阅者服务模块的实现:借阅者服务窗体的功能主要是图书的查询,个人借阅情况查看及个人部分信息的修改。
借阅者登录功能的实现:这个功能的实现与工作人员和管理人员登录功能实现的方法大致一样,并且还要简单。是从User表中查到到借阅证号与密码,看与用户输入的是否一致。如果一致,那么用户就可查看自已的借阅情况并维护自己的部分信息。
借阅者借阅情况功能的实现:当借阅者正确登录到系统后,此功能将被激活,使用户能查看到自身的借阅情况。
借阅者个人资料维护功能的实现:此功能实现当前借阅者部份资料的修改,但借书证号和身份类别这样的信息不允许修改,这是图书馆管理员模块的功能。
工作人员-图书借阅/归还模块的实现:工作人员进行图书借阅功能和图书归还功能的实现。
图书馆管理员模块的实现:图书馆管理员图书管理功能的实现、工作人员和管理员管理功能的实现、修改图书类别及统记功能的实现、借阅者管理功能的实现、维护借阅者管理功能的实现、身份维护功能的实现、借阅者统计功能的实现、统计借阅过期记录功能的实现。
系统信息显示的实现:显示本系统的信息。