如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
第二篇数据库理论和操作第六章关系数据库基础理论和操作6.1关系数据库的构成6.1.1数据结构关系模型的逻辑数据结构非常单一,就是二维表现实世界的实体和实体间的各种联系均用二维表来表示,在磁盘上以文件的形式存储。例如,表6.1和表6.2分别代表学校的系和教师两个关系。表6.1学校的系关系表6.2教师关系关系(Relation):一个关系就是一张二维表。元组(Tuple):表中的行称为元组。一行为一个元组,对应存储文件中的一个记录值。例如,表6.1的系关系有三个元组,表6.2的教师关系有七个元组。属性(Attribute):表中的列称为属性。每一列有一个属性名,例如表6.1中各列的属性名分别是系编号、系名。这里的属性与前面讲的实体的属性相同,又称为字段(Field)。域(Domain):域是属性的取值范围。例如,性别只能取男或女。关键字(Key):能唯一标识一个元组的属性或属性组合。例如,系关系中的系编号就是关键字。若一个关系有多个关键字,可以选定一个为主关键字(PrimaryKey)。关系模式(RelationModel):对关系的描述称为关系模式。格式为:关系名(属性名1,属性名2,……属性名n)例如,表6.1的关系模式为:系(系编号,系名)。元数:关系模式中属性的数目。例如,系关系是2元关系,教师关系是9元关系。6.1.2数据操作关系模型给出了关系操作的能力,可以分为两类:一类是传统的集合运算,如并(Union)、交(Intersection)、差(Difference)等,另一类是专门的关系运算,如选择(Select)、投影(Project)、连接(Join)等查询操作和增加(Insert)、删除(Delete)、修改(Update)等操作。为了进行关系操作,必须使用关系操作的语言,称为关系数据语言,简称关系语言。最常用的语言是SQL(StructuredQueryLanguage),即结构化查询语言。建立关系模型最重要的一步是定义表、视图和索引。表(Table)中存储着物理上存在的数据,又称为基本表。建立了基本表之后,还可以建立视图(View)和索引(Index)。所谓视图,是查询基本表所产生一个虚拟表,它的定义保存在数据库中。所谓索引,是建立在表的关键字或一些属性上的指针,通过它可以快速查找到所需的记录。例如,建立在表6.2的“教师编号”字段上的索引如图6.1所示。6.1.3数据定义视图和索引都依附于基本表,所以SQL一般不提供修改视图和索引定义的操作.标准SQL的数据定义语句如表6.3所示。数据库由表、索引、视图、各种参照关系、存储过程、触发器组成,它可以看成一个“容器”,如图6.2所示。6.2数据库的界面操作在VisualFoxPro中,数据库文件的扩展名是.dbc。在建立数据库时,还会自动建立一个扩展名为.dct的数据库备注文件和一个扩展名为.dcx的数据库索引文件。6.2.1建立数据库利用菜单方式建立数据库的方法有两种:通过主菜单“文件”下的“新建”命令,打开“新建”对话框建立;通过“项目管理器”建立;1、通过“新建”对话框建立数据库单击主菜单“文件”下的“新建”命令,或者单击常用工具栏上的新建按钮,或者按快捷键Ctrl+N,可以打开“新建”对话框。在对话框中选择“数据库”单选按钮,再单击“新建文件”按钮,系统将打开“创建”对话框,如图6.3所示。图6.3通过“新建”对话框建立数据库在“创建”对话框中,可以自己定义数据库的名称和存储文件夹。我们不妨在当前目录下,建立一个名为student的数据库。将默认的数据库名改为“student”,单击“确定”按钮,再单击“保存”按钮,系统将打开“数据库设计器”窗口,如图6.4所示。2、通过“项目管理器”建立数据库通过“新建”对话框建立的数据库,不属于任何项目。而通过“项目管理器”建立的数据库,则属于当前项目。如图6.5所示,在“数据”选项卡中选择“数据库”,然后单击“新建”按钮,在弹出的“数据库向导”对话框中单击“新建数据库”按钮,系统同样会打开图6.3所示的“新建”对话框,下面的步骤和第一种方法类似。新建数据库之后,系统也会打开“数据库设计器”窗口。图6.5通过“项目管理器”建立数据库6.2.2关闭和打开数据库新建立的数据库自动处于打开状态。当创建或添加student数据库到“学生管理”项目中后,“数据”选项卡右边第四个按钮是“关闭”按钮,如图6.6左边所示。如果要关闭数据库,可以单击“关闭”按钮,此时该按钮变成“打开”按钮,单击它,可以重新打开数据库。也可以用菜单命令打开数据库。单击“文件”菜单下的“打开”命令,在“打开”对话框中的“文件类型”列表中选择“数据库(*.dbc)”,如图6.7所示,选择要打开的数据库即可,此时会打