第5章 数据库及其操作
数据库5章数据库设计
E-R图向关系模型的转换:
码原则:
一个实体型转换为一个关系模式:实体的属性就是关系的 属 性,实体的码就是关系的码。
一个联系转换为一个关系模式:与该联系相连的各实体的码以 及联系的属性转换为该关系的属性。该关系的码有五种情况:
若联系是1:1:则每个实体的码均是该关系的候选码。 若联系是1:n:则关系的码是n端实体的码。 若联系是m:n:则关系的码是参加联系的诸实体的码的集合。 若联系是三个或三个以上的实体的一个多元联系可以转换为一个关系模
① 确定局部E-R图实体之间的函数依赖。 ② 求F的最小依赖集Fm,求其差集,即
D=F-Fm ③ 逐一考察D中每一函数依赖,确定是否为冗余,若是,就把 它去掉。
5.4 逻辑结构设计
任务:将基本E-R模型转换为DBMS所支持的数据模型。 关系型逻辑结构设计的步骤:
1) 将概念结构转换为关系模型 2) 优化模型 3) 设计适合DBMS的子模式
第五章 数据库设计
5.1 数据库设计概述 5.2 需求分析 5.3 概念结构设计 5.4 逻辑结构设计 5.5 数据库物理设计
数据库技术的研究领域
数据库管理系统软件的研制(×)
DBMS的研制包括DBMS本身以及以DBMS为核心的饿一组相互联系的软 件系统。目标是扩大功能、提高性能和用户的生产率。
5.2 需求分析
5.数据库应用系统的数据字典 包括:
数据项 数据结构 数据流 数据存储 处理过程
5.2 需求分析
例:下图给出了某机器制造厂的零配 件采购子系统的数据流图。该子系统 要处理的工作是生产部门提出的生产 计划根据零配件当前价格计算成本送 主管部门审批,对已批准生产计划制 定采购计划,准备好订货单给供应商。
数据库原理及应用第5章
五
表(a)
表(b)
章
关
系 数
A
B
C
D
A
B
C
D
据
• A →AB1在表(a)关B系1 上成立,C但1 A →B在D表1(b)关系上不A成1 立。 B1
C1
D1
库
的
A1
B1
C2
D2
A1
B2
C2
D2
规
A2
B2
C3
D3
A2
B2
C3
D3
范
化
A3
B2
C4
D4
D4
A3
B1
C4
理
论
14
函数依赖(续)
第
五
章
• 定义5.2
规
F
范
化
理
论
P
传递
17
函数依赖(续)
第
例: 在关系SC(Sno, Cno, Grade)中,
五
由于: Sno Grade, Cno Grade,
章
因此: (Sno, Cno) Grade
但:
F
关
(Sno, Cno) Sno, (Sno, Cno) Cno
系
数
例: 在关系Std(Sno, Sdept, Mname)中, 有:
五
章 • 练习:已知R(ABCD),F={B→C,D →A,BD →ABCD},求R的候选码。
B ABCD, D ABCD, BD ABCD
关
所以,R的候选码为BD
系 数 据 库
• 例: 全码
F
考虑关系模式R(P,W,A)
– 其中: P—演奏者, W—作品, A—听众
第五章SQL server数据库基础
第五章SQL server数据库基础理论讲解部分5.1 数据库简介5.2 安装SQL server 20055.2.1 SQL server 2005的主要版本●企业版●标准版●工作组版●精简版5.2.2 安装前的准备1.安装SQL server 2005的硬件和软件要求2.安装SQL server的安全注意事项5.2.3 安装过程1.第一阶段:预安装阶段1)从光盘引导2)安装必备组件3)系统配置检查2.第二阶段:正式安装阶段1)注册信息2)选择要安装的组件3)设置实例名4)设置服务账户5)设置身份验证模式6)设置排序规则7)开始安装8)安装完成5.2.4 验证数据库安装成功●安装完成后,将能在“开始---程序“菜单项中看到microsoft SQL server 2005的程序组,启动相关程序,如图5.18所示。
●通过SQL server安装日志文件信息,查看是否存在错误信息。
安装日志的主日志位于:%programfiles%\microsoft SQL server \90\setup bootstrap\LOG\summary.txt具体组件的安装日志位于以下目录:%programfiles%\microsoft SQL server \90\setup bootstrap\LOG\files●最后通过启动和停止数据库服务,检查是否有错误发生,如果没有问题,则证明数据库安装成功。
5.2.5 启动和停止数据库服务SQL server主要是通过windows服务来运行的,在完成数据库安装后,需要手动检查服务是否真的安装成功,是否正在运行,是否已跟据实际环境的需要配置为自动或手动启动。
可以通过以下三种方法启动或停止数据库服务。
●单击“控制面板---管理工具---服务“,启动或停止SQL server服务,如图5.19所示。
●单击“开始-- microsoft SQL server 2005---配置工具--- SQL serverconfiguration manager”,启动或停止SQL server服务,如图5.20所示,假如某些服务没有显示,可能是没有安装或者是安装过程出现了问题。
第5章 数据库完整性
第5章数据库安全性(2课时)数据库的数据保护主要包括数据的安全性和数据的完整性。
数据的安全性是为了保护数据库防止恶意的破坏和非法访问,防范对象是非法用户和非法操作。
数据库的完整性是指数据的正确性和相容性,是为了防止数据库中存在不符合语义的数据,也就是防止数据库中存在不正确的数据,防范对象是不合语义的、不正确的数据。
举例说明数据的完整性(三种完整性各一例)。
为维护数据库的完整性,DBMS必须具备三个功能:1 提供定义完整性约束条件的机制完整性约束条件也称为完整性约束规则,是数据库必须满足的语义约束条件。
SQL标准使用了一系列概念来描述完整性,包括关系模型的实体完整性、参照完整性和用户定义完整性。
这些完整性一般由SQL的DDL语句来实现。
它们作为数据库模式的一部分存入数据字典中。
2 提供完整性检查的方法DBMS中检查数据是否满足完整性约束条件的机制称为完整性检查。
一般在INSERT、UPDA TE、DELETE语句执行后开始检查,也可以在事务提交时检查。
检查这些操作执行后数据库中的数据库是否违背了完整性约束条件。
3 违约处理DBMS若发现用户的操作违背了完整性约束条件,就采取一定的动作,如拒绝(NOACTION)执行该操作,或级联(CASCADE)执行其他操作,进行违约处理以保证数据的完整性。
目前商用的DBMS产品都支持完整性控制,即完整性定义、检查控制和违约处理都是由DBMS来实现,不必由应用程序来完成,从而减轻了应用程序员的负担。
5.1 实体完整性是关系的两个不变性之一,关系的主属性的取值不能相同,主属性不能取空值,保证在一个关系中不存在两个完全相同的元组。
5.1.1 实体完整性定义关系模型的实体完整性在CREATE TABLE中用PRIMARY KEY定义。
对单属性构成的码有两种说明方法:一种是定义为列级约束条件;一种是定义为表级约束条件。
对多个属性构成的码只有一种说明方法:定义为表级约束条件。
大学计算机教程第六版 第5章数据库技术应用
3.连接运算(Join简记为JN)
连接是从关系R与S的笛卡尔积中,选取R的第i 个属性值和S的第j个属性值之间满足一定条件表达 式,构成关系子集。
关系R与T作θ连接。如表5.13和表5.14所示。
5.6.1 数据库设计理论的应用 数据库数据相关性称为数据依赖。数据依赖主
要分为内在关系的函数依赖(简记FD)和多值依赖 (简记MVD)。
把关系看成一个集合,集合运算如并、交、差、 笛卡尔积等运算,均可用到关系运算中。
设有三个关系实例R、S和T,如表5.6所示。
关系R和S的并是由属于R或S或同时属于R和S的 元组组成的集合,记为R∪S,如表5.7所示。
2. 差运算(Difference)
关系R和S的差是由属于R而不属于S的所有元组 组成的集合,记为R-S,如表5.8所示。
3. 交运算(Intersection)
关系R和S交是由同时属于R和S的元组组成的集 合,记为R∩S,如表5.9所示。
4. 笛卡尔积
关系R和S的笛卡尔积R×S的结果如表5.10所 示。
1.选择运算(Selection 简记为SL)
选择条件用F表示,在关系R中挑选满足条件F的 所有元组,组成一个新的关系,这个关系是关系R 的一个子集,记为:
设D1,D2,…Dn为n个集合,称D1×D2×…×Dn={(d1, d2, …dn)∈Di,(i=1,2, …n)}为集合D1,D2,…Dn 的笛卡尔积。
其中,Di(i=1,2,…n)可能有相同的,称它们为域, 域是值的集合。
笛卡尔积可表示为一个二维表。如果给出三个域:
D1={王欣,刘伟平} D2={张德君,李波} D3={网络技术应用,数据库原理} 则D1,D2,D3的笛卡尔积为D1×D2×D3={ (王欣,张德君,网络技术应用),(王欣,张德君,数据库原理), (王欣,李波,网络技术应用),(王欣,李波,数据库原理),(刘 伟平,张德君,网络技术应用),(刘伟平,张德君,数据库原理), (刘伟平,李波,网络技术应用),(刘伟平,李波,数据库原理)}
第五章 数据库设计
运动会方面,实体集包括:运动员(编号,姓名,性别,队 伍号),比赛项目(项目名,比赛场地)。其中,一个比赛项 目可供多名运动员参加,一名运动员可参加多个项目。
根据上述条件,分别设计运动队和运动会两个局部E-R图。
第三节 概念结构设计 参赛项目 性别 队伍号 队伍名 教练名 运动员 性别 队伍号 运动员 m 参加 n n 属于
第三节 概念结构设计 分解变换。如果实体集的属性较多,可以进行分解。例如, 对于员工实体集,其属性为员工号、姓名、性别、生日、(所 属)支行名、岗位、工资、奖金。 性别 生日 支行名 岗位 工资 奖金
姓名 员工号 员工
第三节 概念结构设计 可以把员工信息分解为两部分,一部分属于固定信息,一部 分属于变动信息。为了区别这两部分信息,产生一个新的实体 和一个新的联系。
在视图合并阶段,设计者把所有视图有机地合并成统一的概 念模型,这个最终的概念模型支持所有的应用。
第三节 概念结构设计 概念结构设计的策略主要分为自顶向下、自底向上、自内向 外和混合策略四种。 这些方法中最常用的是自底向上方法:首先设计局部概念模 式,然后综合局部概念模式成全局概念模式,最后对全局概念 模式进行评估和优化。
P2 P1 D2明细 D3账目 E2会 E1客 D1付款 打印账目 账务处理 单 户 计
第二节 需求分析 元数据是描述数据的数据,通常由数据结构的描述组成,主 要描述数据及其使用环境,例如数据精度、来源、产生时间、 使用范围、注解等。 数据字典是一种用户可以访问的、记录数据库和应用程序元 数据的集合,通常是用来解释数据表、数据字段等数据结构的 意义,数据字段的取值范围、数据值代表的意义等。 简而言之,数据字典是描述数据的信息集合,是系统中所有 数据的定义集合。
数据字典通常由数据项、数据结构、数据流、数据存储和处 理过程组成。
Chapter5-大数据技术原理与应用-第五章-NoSQL数据库-pdf
缺点 使用者
功能较少,大都不支持强事务一致性
Ebay(Cassandra)、Instagram(Cassandra)、NASA(Cassandra)、 Twitter(Cassandra and HBase)、Facebook(HBase)、Yahoo! (HBase)
《大数据技术原理与应用》
厦门大学计算机科学系
本PPT是如下教材的配套讲义: 21世纪高等教育计算机规划教材 《大数据技术原理与应用 ——概念、存储、处理、分析与应用》 (2015年6月第1版) 厦门大学 林子雨 编著,人民邮电出版社 ISBN:978-7-115-39287-9
第五章 数据库完整性
例2:将SC表中的SNO、cno属性组定义为码 create table sc (sno char(9) not null, cno char(4) not null, grade smallint, primary key(sno,cno) )
8
5.1.2 实体完整性的违约处理
对于实体完整性的检查,包括:
在子表中修改外码(也是主属性)的策略
6. 在参照关系(子表)中修改外码(同时是主码 属性 )。与在参照关系中插入元组类似,可以 有2种策略: 受限修改 递归修改 RDBMS在实现参照完整性时: 需要向用户提供定义主码、外码的机制。 向用户提供按照自己的应用要求选择处理依 赖关系中对应的元组的方法。
6
5.1 实体完整性
5.1.1 定义实体完整性 例1:将student表中的sno属性定义为码 create table student (sno char(9) primary key, sname char(20) not null, ssex char(2), sage smallint, sdept char(20) )
26
5.4 完整性约束命名子句
1. 完整性约束命名子句 Constraint <完整性约束条件名><完整性约 束条件> 例5.10 建立学生登记表 student,要求学号在 90000—99999 之间,姓名不能取空值,年 龄小于30,性别只能是“男”或者“女”
5
数据库完整性控制机制
DBMS完整性控制机制: 1. 提供定义完整性约束条件的机制:提供定义数 据完整性约束条件的方法,完整性约束条件作为 模式的一部分存入数据库中; 2. 提供完整性检查的方法:进行完整性检查,检 查数据是否满足约束条件; 3. 进行违约处理:若有违反,采取相应措施(拒 绝、报告、改正)处理。 完整性子系统:DBMS中执行完整性控制的子系统。 其功能为监督事务的执行,测试其是否违反完整性 约束条件;若有违反,则分情况进行预定的处理。
第5章 创建数据库
第5章创建数据库创建数据库就是为数据库确定名称、大小、存放位置、文件名和所在文件组的过程。
在一个SQL Server 2008实例中,最多可以创建32767个数据库,数据库的名称必须满足系统的标识符规则。
在命名数据库时,一定要使数据库名称简短并有一定的含义。
在SQL Server 2008中创建数据库的方法主要有两种:一是在SQL Server Management Studio窗口中使用现有命令和功能,通过方便的图形化向导创建;二是通过编写Transact-SQL 语句创建。
5.1使用图形化向导创建SQL Server Management Studio是SQL Server系统运行的核心窗口,它提供了用于数据库管理的图形工具和功能丰富的开发环境,方便数据库管理员及用户进行操作。
首先来介绍如何使用SQL Server Management Studio来创建自己的用户数据库。
在SQL Server 2008中,通过SQL Server Management Studio创建数据库是最容易的方法,对初学者来说简单易用。
下面以创建本书的示例数据库【图书管理系统(BookDateBase)】数据库为例,对这种方法作详细介绍。
具体的操作步骤如下所示:(1)从【开始】菜单中选择【程序】|Microsoft SQL Server 2008|SQL Server Manage ment Studio命令,打开Microsoft SQL Server Management Studio窗口,并使用Windows 或SQL Server身份验证建立连接。
如图5-1所示。
图5-1连接服务器身份验证(2)在【对象资源管理器】窗格中展开服务器,然后选择【数据库】节点。
(3)在【数据库】节点上右击,从弹出的快捷菜单中选择【新建数据库】命令,如图5-2所示。
图5-2选择【新建数据库】命令(4)执行上述操作后,会弹出【新建数据库】对话框,如图5-3所示。
数据库系统概论 课件 第05章_数据库完整性
列值非空(NOT NULL约束) 列值唯一(UNIQUE约束) 检查列值是否满足一个布尔表达式(CHECK约束)
SQL Server 实现用户定义数据完整性的主要方法 有:约束、默认、规则、自定义数据类型和触发器
1、不允许取空值
DB
例5 在定义“学生”表时,说明学号Sno为主键,姓
数据库系统原理
DB
Principles of Database System
第五章 数据库完整性
第五章
DB
数据库完整性
数据库的完整性(Integrity)
数据的正确性、有效性和相容性
防止不合语义的数据进入数据库
例:学生的年龄必须是整数,取值范围为14-35;
学生的性别只能是男或女; 学生的学号一定是唯一的; 学生所在的系必须是学校开设的系;
DB
FOREIGN KEY(<列名>) REFERENCES <表名> [(<列名>)] [ ON DELETE <参照动作> ] [ ON UPDATE <参照动作> ] 其中 第一个“列名”是外部关键字 第二个“列名”是被参照表中的主键或候选键 。
参照动作
DB
NO ACTION(拒绝)
CASCADE(级联)
FOREIGN KEY(Sno) REFERENCES Student(Sno),
FOREIGN KEY(Cno) REFERENCES Course(Cno)
);
5.2.2 参照完整性检查和违约处理
DB
一个参照完整性将两个表的相应元组联 系起来了
对被参照表和参照表进行增删改操作时
有可能破坏参照完整性 因此,必须进行检查
数据库原理及应用第5章课后习题答案
习题51、 理解并给出下列术语的定义:1)设R(U)是一个属性集U 上的关系模式,X 和Y 是U 的子集。
若对于R(U)的任意一个可能的关系r ,r 中不可能存在两个元组在X 上的属性值相等, 而在Y 上的属性值不等, 则称 X 函数确定Y 或 Y 函数依赖于X ,记作X →Y 。
2) 完全函数依赖在R(U)中,如果X →Y ,并且对于X 的任何一个真子集X ’,都有Y 不函数依赖于X ’ ,则称Y 对X 完全函数依赖,记作Y X F −→−3) 部分函数依赖若X →Y ,但Y 不完全函数依赖于X ,则称Y 对X 部分函数依赖,记作Y X p−→−4) 传递函数依赖在R(U)中,如果X →Y ,(Y ⊆X) , Y →X ,Y →Z , 则称Z 对X 传递函数依赖。
记为:Z X T −→−注: 如果Y →X , 即X ←→Y ,则Z 直接依赖于X 。
5)候选码设K 为R (U,F )的属性或属性组合。
若U K F →, 则K 称为R 的侯选码。
6)主码:若候选码多于一个,则选定其中的一个作为主码。
7)外码:关系模式 R 中属性或属性组X 并非 R 的码,但 X 是另一个关系模式的码,则称 X 是R 的外部码(Foreign key )也称外码8)如果一个关系模式R 的所有属性都是不可分的基本数据项,则R ∈1NF.9)若R ∈1NF ,且每一个非主属性完全函数依赖于码,则R ∈2NF 。
10)如果R(U,F )∈2NF ,并且所有非主属性都不传递依赖于主码,则R(U,F )∈3NF 。
11)关系模式R (U ,F )∈1NF ,若X →Y 且Y ⊆ X 时X 必含有码,则R (U ,F ) ∈BCNF 。
12)关系模式R<U ,F>∈1NF ,如果对于R 的每个非平凡多值依赖X →→Y (Y ⊆ X ),X 都含有码,则R ∈4NF 。
2、 关系规范化的操作异常有哪些?1) 数据冗余大2) 插入异常3) 删除异常4) 更新异常3、 第一范式、第二范式和第三范式关系的关系是什么?4、 已知关系模式R(A,B,C,D,E)及其上的函数依赖集合F={A->D,B->C,E-> A},该关系模式的候选码是什么?候选码为:(E,B)5、 已知学生表(学号,姓名,性别,年龄,系编号,系名称),存在的函数依赖集合是{学号->姓名,学号->性别,学号->年龄,学号->系编号,系编号->系名称},判断其满足第几范式。
数据库第五章习题及答案
第五章 关系数据理论一、 单项选择题1、设计性能较优的关系模式称为规范化,规范化主要的理论依据是 ( )A 、关系规范化理论B 、关系运算理论C 、关系代数理论D 、数理逻辑2、关系数据库规范化是为解决关系数据库中( )问题而引入的。
A 、插入、删除和数据冗余B 、提高查询速度C 、减少数据操作的复杂性D 、保证数据的安全性和完整性3、当关系模式R (A ,B )已属于3NF ,下列说法中( )是正确的。
A 、它一定消除了插入和删除异常B 、一定属于BCNFC 、仍存在一定的插入和删除异常D 、A 和C 都是4、在关系DB 中,任何二元关系模式的最高范式必定是( )A 、1NFB 、2NFC 、3NFD 、BCNF5、当B 属性函数依赖于A 属性时,属性A 与B 的联系是( )A 、1对多B 、多对1C 、多对多D 、以上都不是6、在关系模式中,如果属性A 和B 存在1对1的联系,则说( )A 、A B B 、B A C 、A B D 、以上都不是7、关系模式中,满足2NF 的模式,( )A 、可能是1NFB 、必定是1NFC 、必定是3NFD 、必定是BCNF8、关系模式R 中的属性全部是主属性,则R 的最高范式必定是( )A 、2NFB 、3NFC 、BCNFD 、4NF9、关系模式的候选关键字可以有( c ),主关键字有( 1个 )A 、0个B 、1个C 、1个或多个D 、多个10、如果关系模式R 是BCNF 范式,那么下列说法不正确的是( )。
A 、R 必是3NFB 、R 必是1NFC 、R 必是2NFD 、R 必是4NF11、图4.5中给定关系R ( )。
A 、不是3NFB 、是3NF 但不是2NFC 、是3NF 但不是BCNFD 、是BCNF12、设有如图4.6所示的关系R ,它是( )A 、1NFB 、2NFC 、3NFD 、4NF二、 填空题1、如果模式是BCNF ,则模式R 必定是(3NF ),反之,则( 不一定 )成立。
Visual FoxPro VF 第5章 数据库及其操作(1)
例:16、在Visual FoxPro中,下面描述正确的 是______。(09-3) A、数据库表允许对字段设置默认值 B、自由表允许对字段设置默认值 C、自由表或数据库表都允许对字段设置默 认值 D、自由表或数据库表都不允许对字段设置 默认值
例:20、以下关于空值(NULL值)叙述正确 的是______。(09-3) A、空值等于空字符串 B、空值等同于数值0 C、空值表示字段或变量还没有确定的值 D、Visual FoxPro不支持空值
例:21、在Visual FoxPro中,有关参照完整性的删除规 则正确的描述是______。(09-3) A、如果删除规则选择的是"限制",则当用户删除父 表中的记录时,系统将自动删除子表中的所有相关记录 B、如果删除规则选择的是"级联",则当用户删除父 表中的记录时,系统将禁止删除与子表相关的父表中的 记录 C、如果删除规则选择的是"忽略",则当用户删除父 表中的记录时,系统不负责检查子表中是否有相关记录 D、上面三种说法都不对
例:11、不带条件的DELETE命令(非SQL命 令)将删除指定表的___当前___记录。(069) 试比较: 不带条件的DELETE命令(是SQL命令)将删 除指定表的__所有___记录。
例:22、在Visual FoxPro中以下叙述错误的 是______。(06-4) A、关系也被称作表 B、数据库文件不存储用户数据 C、表文件的扩展名是.dbf D、多个表存储在一个物理文件中
6、索引 主索引 在指定字段或表达式中不允许出现重复值的索引。建立主索引的字 段是主关键字,一个表只能有一个主关键字,即一个表只能创建一 个主索引。 注:只能为数据库中的每一个表建立一个主索引。 候选索引 候选索引象主索引一样要求字段值的唯一性并决定处理记录的顺序。 在数据库和自由表中可以建立多个候选索引。 惟一索引 索引项的唯一。 普通索引 普通索引可以决定记录的处理顺序,它不仅允许字段中出现重复值, 并且索引项中也允许出现重复值。在一个表中可以建立多个普通索 引。
数据库系统概论 第5章
当一个关系模式在连接的过程中没有丢掉有用信息的, 称为无损连接分解否则称为有损连接分解。 3NF的优点就是其总可以在满足无损连接并保持依赖的 前提下得到3NF设计。其缺点是,若没有消除所有的传递 依赖,则必须要用空值来表示数据项间的某些可能有意义 的联系。此外,3NF还存在信息重复的问题。 若必须在BCNF和保持依赖的3NF间作选择的话,通常 倾向于选择3NF。因为若不能有效地检验依赖的保持情况, 我们要么牺牲系统性能,要么破坏数据库中的数据的完整 性,这当然都不好。相比之下,3NF中允许传递依赖造成 少量冗余反到是可以容忍的。所以,我们常选择保持依赖 而放弃BCNF。
假定有一个实际问题,有关系模式: 借书人(姓名,地址,书名,日期) 即 BORROW(NAME,ADDR,TITLE,DATE) 其中:NAME和TITLE是整个模式的关键字(主码)。
NAME 张 平 张 平 张 平 张 平 张 平 张 平 李少林 李少林 ADDR A1 A1 A1 A1 A1 A1 A2 A2 TITLE T1 T2 T3 T4 T5 T6 T3 T7 DATE D1 D2 D3 D4 D5 D6 D4 D7
一个低一级范式的系模式的集合,这种 过程就叫规范化。各种范式之间的关系为:
1NF 2NF
3NF BCNF 4NF
5NF
例:以下两例为非1NF关系。借书人
部门名 部门号
经理
正经理 副经理
张 平 李文化
DN1 DN2
D1 D2
M1 M2
5.2.5 3NF
定义:关系模式R(U,F)中若不存在这样的码X,属 性组Y及非主属性Z(Z Y)使得X→Y(Y→X)Y→Z 成立,则称R(U,F) ∈3NF。 简言之,不存在非主属性部分依赖和传递依赖于 码的第一范式称为第三范式。 从定义中还可得出结论:不存在非主属性的模式 为第三范式。
MySQL数据库系统与应用李海翔 第5章 数据类型、表的操作和存储引擎
5.2 表的操作
第5章 数据类型、表的操作和 存储引擎
学习目标:了解信息、数据和数据管理的基本概念,了解数据管理技术 的发展历史,理解数据库系统的基本概念,理解概念模型、逻辑模型的相关 概念,理解数据库的体系结构。
5.1 数据类型
5.1 数据类型
5.1.1 数值类型 1.整数类型及其取值范围
5.1 数据类型
2.浮点数类型和定点数类型及其取值范围
列的定义包括列名、数据类型、指定默认值、注释列名等属性组成,各项 之间用空格分隔。格式如下:
column_name data_type [DEFAULT default_value] [AUTO_INCREMENT] [COMMENT 'String'] …
able_option:对表的操作,包括存储引擎、默认字符集、校对规则等,各 项之间用空格分隔。格式如下:
5.2 表的操作
USE student_db; CREATE TABLE class (
ClassID CHAR(8) PRIMARY KEY COMMENT '班级编号', ClassName VARCHAR(20) NOT NULL COMMENT '班级名称', DepartmentName VARCHAR(20) NOT NULL, Grade CHAR(4) NOT NULL, ClassNum SMALLINT
SQL Server数据库管理教程 第5章
认情况下,SQL Server 2012会将文件存储 于C:\Program Files\Microsoft SQL Server \ MSSQL10.MSSQLSERVER \ MSSQL \ DATA文件夹中,单击“路径”选项右边的 按钮,在弹出的对话框中可为数据文件或日
志文件指定其他路径。
4)在“选项”选项页中,可以定义所创建数据库的排序规则、恢复模 式、兼容级别等选项。在此均保持默认选项。 5)在“文件组”选项页中,可以查看数据库中现有的文件组,也可以 分别通过“添加”和“删除”按钮添加和删除文件组 6)全部设置完毕后,单击“确定”按钮即可完成jw数据库的创建。
3)通过ALTER语句来增加数据库容量。
【例5-5】 使用Transact-SQL语句将jw数据库的主数据文件jw.mdf 的初始大小设置为5 MB。 ALTER DATABASE jw MODIFY FILE (NAME=jw_data, SIZE=5MB)
3.收缩数据库容量
收缩数据库的方式有以下三种。
逻辑名:表示相应数据文件的逻辑名称,它必须在数据库中是唯一的,
且须符合标识符命名规则。
文件类型:其中“数据”表示数据文件,“日志”表示日志文件。 文件组:用于存放数据文件的文件组。默认情况下,数据文件存放于
PRIMARY文件组中,日志文件不属于任何一个文件组。
初始大小:文件的初始大小。需注意的是,主数据文件的初始大小至少
FILENAME='path'
[,SIZE=database_size] [,MAXSIZE=database_maxsize]
[,FILEGROWTH=growth_increment])
[,FILEGROUP filegroup_name [(NAME=datafile_name,
第5章 数据库的基本操作
3.数据库与表
5.2.2 在数据库中建立表
例6:在已创建的D:\XSCJGL\DB\CJGL.DBC数据库 中建立学生信息表XSXI.DBF(表的结构参见第四 章),要求存储在D:\XSCJGL\DB\TABLES文件夹 下。
5.2.3 向数据库添加自由表
例7:将自由表KCXI.DBF添加到CJGL.DBC数据库 中。
3.以命令方式设置当前数据库
设置当前数据库,可使用下面的SET命令。 如SET DATABASE TO CJGL,表示将 CJGL.DBC设置为当前数据库。 格式:SET DATABASE TO[<数据库名>] 功能:指定已打开的某一数据库为当前数据库。 说明:如果省略数据库名,将取消当前数据库 的设置,即所有打开的数据库均不为当前数据 库。
4.以命令方式关闭数据库
格式:CLOSE DATABASES[ALL] 功能:关闭当前数据库和它包含的表; 若没有当前数据库,将关闭所有工作区中打开 的自由表和索引; 若命令中包含ALL选项,将关闭所有打开的数 据库及其包含的表,并关闭相关的索引文件和 格式文件。
5.以命令方式修改数据库
&&建立索引标识为XBBJ的惟一索引,该索引标识追加到XSXI.CDX文件
3.索引的使用
(1)索引文件的打开与关闭 格式:SET INDEX TO [<索引文件列表 >|?][ADDITIVE] 功能:打开当前表的一个或多个索引文件。这 里的索引文件类型指的是单索引文件或非结构 化复合索引文件。
&&按学号相等建立当前表与成绩信息表的一对多关系
接下来,执行下面的命令: SELECT A BROWSE &&浏览成绩信息表 SELECT B BROWSE &&浏览学生信息表
大一计算机第五章数据库基础考试知识
第五章数据库基础5.1 数据库系概述5.1.1 常用术语1. 数据库(DataBase,DB)长期保存在计算机外存上的、有结构的、可共享的数据集合。
2. 数据库管理系统(DataBase Management System,DBMS)对数据库进行管理的软件系统。
数据库的一切操作,如查询、更新、插入、删除以及各种控制,都是通过DBMS进行的。
DBMS是位于用户(或应用程序)和操作系统之间的软件。
借助于操作系统实现对数据的存储和管理,使数据能被各种不同的用户所共享,DBMS提供给用户可使用的数据库语言。
3. 应用程序(DataBase System,DBS)利用各种开发工具开发的、满足特定应用环境的数据库应用程序。
4. 数据库系统相关人员数据库管理员应用程序开发人员最终用户5. 数据库系统(DataBase System,DBS)由硬件系统、数据库管理系统、数据库、数据库应用程序、数据库系统相关人员等构成的人-机系统。
数据库产品(一整套数据库应用解决方案)桌面型数据库网络数据库MS Access SQL Server Oracle MySql5.1.2 数据库技术的产生和发展数据管理技术经历了三个发展阶段•人工管理阶段文件管理阶段数据库系统阶段1.人工管理阶段时间:20世纪50年代中期以前硬件:只有卡片、纸带、磁带等存储设备软件:没有操作系统,没有进行数据管理的软件应用:以科学计算为目的特点:程序和数据放在一起数据不能共享2.文件系统阶段时间:20世纪60年代中期硬件:磁带、磁盘等大容量存储设备软件:有了操作系统应用:不仅用于科学计算,还用于数据管理.特点:程序与数据分离数据有一定的独立性实现了以文件为单位的数据共享数据有一定的独立性3.数据库系统阶段时间:20世纪60年代后期硬件:出现了大容量且价格低廉的磁盘软件:有了数据库管理系统DBMS应用:各个方面.特点:数据结构化数据共享性高,冗余小数据独立性高数据由DBMS统一管理控制为用户提供了友好的数据库系统的特点–(1) 采用一定的数据模型,最大限度地减少数据的冗余(2) 最低的冗余度(3) 有较高的数据独立性用户面对的是简单的逻辑结构操作而不涉及数据具体的物理存储结构(4) 安全性设置用户的使用权限在数据库被破坏时,系统可把数据库恢复到可用状态。
数据库第5章
1-6 郑州轻工业学院软件职业技术学院
总的来说计算机安全涉及的问题
计算机系统本身的技术问题
计算机安全理论与策略
计算机安全技术
管理问题
安全管理 安全评价 安全产品
数据库原理
1-7 郑州轻工业学院软件职业技术学院
计算机安全涉及问题(续)
法学
计算机安全法律
犯罪学
计算机犯罪与侦察 安全监察
能访问他有权存取的数据,必须预 先对每个用户定义存取权限。
检查存取权限
对于通过鉴定获得上机权的用户
(即合法用户),系统根据他的存 取权限定义对他的各种操作请求进 行控制,确保他只执行合法操作。
数据库原理
1-22 郑州轻工业学院软件职业技术学院
常用存取控制方法
自主存取控制(Discretionary Access
5.3.2 授权(Authorization)与回收
在数据库系统中,定义用户存取权限称为授权 (Authorization)。 第三章讨论 SQL 的数据控制功能时,我们已知道授权有两种: 系统特权和对象特权。 系统特权是由DBA授予某些数据库用户,只有得到系统特 权,才能成为数据库用户。 对象特权可以由DBA授予,也可以由数据对象的创建者授 予,使数据库用户具有对某些数据对象进行某些操作的 特权。 在系统初始化时,系统中至少有一个具有DBA特权的用户,DBA 可以通过GRANT语句将系统特权或对象特权授予其他用户。 对于已授权的用户可以通过REVOKE语句收回所授予的特权。
用户标识和鉴定的方法有多种,为了获得更强的安全性, 往往是多种方法并举,常用的方法有以下几种:
数据库原理
1-18 郑州轻工业学院软件职业技术学院
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
5.4.2 “查询设计器”界面
1,上部窗格
2,字段选项卡
3,联接选项卡
4,筛选选项卡
5,排序依据选项卡 6,分级依据选项卡 7,杂项选项卡
1,内部连接:只有满足条件的记录才连接在查询结果 中 2,左连接:将左表的每条记录都与右表的所有记录比 较,若满足条件则连接成一条记录。若右边表有多个 记录满足条件则形成多个记录,若右边表没有满足条 件的记录。则新记录中字段为右边表中字段的字段值 为NULL 3,右连接:与左连接类似,只是改成为右表与左表 (即将1中的“左”改为“右”,“右”改为“左”) 4,完全连接:先右连接,然后左连接,重复记录不列 入查询结果中。
5,在索引选项卡中将其改为主索引
用命令方式建立主索引
格式:alter table 表名 add primary key 索引关 键字 tag 索引标识 例5-2:以命令方式完成例5-1 open database 图书管理 use student alter table student add primary key 学号 tag 学 号
2,向数据库中添加表
(1)用命令方式 格式:ADD TABLE<数据表名> 功能:向已打开的数据库中添加指定的表。
(2)菜单方式:打开数据库后使用“数据库” 菜单中的添加表命令或使用快捷菜单中的添加 表命令或使用数据库设计器中的工具栏中的添 加表工具。
例:创建“教学管理”数据库,并把学生表和 成绩表添加该数据库中
数据库中各种数据的定义和设置信息均保存在 数据字典中,包括数据库表的属性、字段属性、 记录规则、表间关系及参照完整性。 5.2.1 长表名和长字段名
数据库表名与字段名最长可达128个字符
5.2.2 设置字段属性
在表设计器中选择字段后可设置该字段的属性
字段显示属性的设置
1,格式
用于设置该字段在浏览窗口、表单或报表中显 示时的格式,包括大小、字体或样式 A:只允许输入文字字符,不允许输入数字、 空格和标点符号。 D:使用系统当前的日期格式 L:在数值前显示0而不是空格 !:把输入的小写字母转换成大写字母
例5-6:在图书管理数据库的student表和borrow 表中通过两表间按学号建立的联系,在2006年 以前借书的学生记录中提取学号、姓名、班级、 书名和借书日期5个字段,并以班级排序组成一 个名为“视图1”的视图
OPEN DATABASE 图书管理 create sql view 视图3; as select student.学号,姓名,班级,书名,借书日期; from student,borrow ; where student.学号=borrow.学号 and year(借书 日期)<2006
5.1.2 数据库的打开与关闭
1,打开数据库命令 格式:OPEN DATABASE <数据库名>
2,关闭数据库命令
格式1:CLOSE DATABASE
功能:关闭所有打开的数据库及库中的表 格式2:CLOSE 3,修改数据库命令 格式:MODIFY DATABASE<数据库名> ALL
4,删除数据库命令
(2)若主表中的数据改变将导致关联表中出现孤 立记录,则主表中不能改变此数据
(3)对主表作删除操作时,其对应的子表必须没 有相应的记录存在。
2,参照完整性的设置
在数据库设计器中选择相应的关系,从右
键菜单中选择“编辑参照完整性”,在参照 完
整性生成器中设置。
5.4 查询的建立与运行
5.4.1 使用查询设计器 利用“查询设计器”进行查询的基本步骤为 1,建立查询:使用“文件/新建/查询/新建文 件”,或在命令窗口中输入: create quey 2,指定表 3,选择字段 4,设置其它选项 5,运行查询
视图的分类:
本地视图:从本地计算机上直接提取数据
远程视图:可以从支持开放数据库连接ODBC 的远程数据源中提取数据。 视图的优点: 1,提供数据库使用的灵活性:可以为同一个 数据库建立多个不同类型的视图,供不同的用 户使用。
2,减少用户对数据库物理数据结构的依赖: 使应用程序不会因数据库表结构的修改而改变。
2,用命令方式创建视图
格式:create sql view <视图名>; as select <字段名表>; from <表名表>; where <条件>
例5.7 在图书管理数据库的student表中 提取年龄在20岁以下(包括20岁)的学生 记录,将其中的班级、学号、姓名、出生 日期4个字段内容组成一个名为“视图2”的 视图 open database 图书管理 create sql view 视图2; as select 班级,学号,姓名,出生日期; from student; where 年龄<=20
3,支持网络应用。
5.5.2 视图的创建
1,用视图设计器创建视图
视图的创建方法与查询的创建方法类似,只增 加了以下两点: (1),必须先打开数据库后才可以建立视图。
(2),视图设计器比查询设计器多了一个更 新条件选项卡。 视图不用专门的文件来保存其数据,也不存在 输出去向的问题。
2,用命令方式创建视图
2,输入掩码 用于限定数据的输入范围,可以屏蔽非法输入。如 999.9表示整数部分可以输入三位小数部分可以输入 一位。 输入掩码中用到的字有: X:允许输入字符 9:允许输入数字
#:允许输入数字、空格与正负号 $:自动显示SET CURRENCY命令设定的货币符号 *:在指定宽度中在数值之前显示*号 .:指定小数点的位置 ,:用逗号分隔数值的整数部分。
3,标题:指定显示表时字段的标题
4, 字段有效性
包括规则、信息和默认值三个文本框。 规则框:用于对该字段输入数据的有效性进行 检查的规则。即输入数据应满足的规则。如: 性别="男".or.性别="女" 信息框:输入不满足规则时的显示信息
默认值:用于指定该字段的默认值。当增加新 记录时,新记录中该字段的值为默认值中内容。
格式:create sql view <视图名> [remote]
[connection <新建连接名>] as<select-SQL命令>
功能:按照as<select-SQL命令>规定的要求,创 建一个指定名称的本地视图或远程视图 [remote][connection <新建连接名>] :用指定的连 接或创建一个新的连接建立一个远程视图 as<select-SQL命令>;用SQL语句定义视图。
例5-5:在职工档案表zgda中,分别查询男职工 的平均年龄和工资总额,以及职工的平均年龄 和工资总额 添加表: zgda 字段:性别,avg(年龄),sum(基本工资) 分组依据:性别
5.4.3 查询菜单的使用
1,查看SQL:打开查询设计器后执行“查 询”菜单中的“查看SQL”命令 2,查询去向:浏览、临时表、表、图形、 屏幕、报表、标签
例5-4 在图书管理数据库中,查询男生借书情况, 并按借书日期升序输出其学号、书名和借书日期 操作步骤: 1,打开图书管理数据库 2,执行“文件/新建/查询/新建文件” 3,将student表和borrow表添加到查询设计器中 并按学号建立关联 4,在字段选项卡中增加:学号、书名和借书日 期;在筛选选项卡中输入条件,如图5-16在排序 依据选项卡中添加按借书日期排升序。
3,从数据库中移去表
(1)使用命令方式:
格式:remove table <数据表名>[delete]
功能:将指定表从当前数据库中移去。若选择 delete短语,则从磁盘中将表文件删除 (2)菜单方式 打开数据库后选择要移去的表,然后执行相应 的命令(数据库菜单或快捷菜单中的删除或移 去命令等)。
5.2 数据字典
5.3.2 创建永久关系
方法:在数据库设计器中,将主表的主索引或候选索 引拖动到子表的对应索引上。
当子表中建立的索引是普通索引或唯一索引时, 建立的关联为一对多关系,若两者均为主索引或候选 索引时建立的是一对一关系
例5-3:在图书管理数据库中,在student表和borrow 表之间通过学号建立一个永久关系。
则当姓名为空时才可以执行删除操作
触发器中的文本框中输入的可以是逻辑表达式, 也可以是自定义函数,当其值为假时将禁止相 应的操作。
5.3 表间关系与参照完整性
自由表间无法建立永久关联,但数据库表 可以,其关联关系保存在数据库中。 5.3.1 建立关联前的准备 数据库表间的永久关系有一对一和一对多
两种。创建关系前必须在主表建立主索引或候
选索引,子表必须建立具有相同索引表达式的
索引(可以是主索引或候选索引或普通索引)
例5-1:在表设计器中,为“图书管理”数据库 中
的student表建立一个以学号为主关键字的主索引。 操作步骤: 1,打开“图书管理”数据库 2,在数据库设计器中双击“学生表” 3,执行“显示”菜单中的“表设计器命令 4,在字段选项卡中以学号字段建立索引
5.2.3 设置记录规则
在表设计器的表选项卡中进行设置: 有效性规则的概念
有效性规则是一个与字段或记录相关的表达式。 用于检查输入时字段值或记录是否有效。有效性 规则只存在于数据库表中 有效规则的不同级别
字段级有效性规则:用于约束一个字段的输入是 否有效 记录级有效性规则:用于检查记录的输入是否有效。
操作步骤:打开数据库->打开学生表并以学号建立主 索引->打开成绩表并学号建立普通索引->在数据库设 计中将学生表中的 索引拖动成绩表的索引上。 关系的修改:在数据库设计器窗口中双击要修改的关 系线可修改关系。
5.3.3 设置参照完整性
1,参照完整性的概念 参照完整性(RI)是指在建立了永久关系的数据 库表间操作应满足的规则。使得当用户进行插入、 更新或删除表中记录时,可保证各相关数据的完整性。 其规则有 (1)在主表中没有相应的记录时,关联表中不得 添加相关的记录