第三章表的建立与维护.ppt

  1. 1、本文档共44页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第三章表的建立与维护

;;一个单词 一个字母 一个数字 一个日期 一个NULL值,它表示该单元中没有数据;;设计数据库实际上就是设计数据库中的表。在设计表时,要使用尽可能少的表数量,在达到设计要求的前提下,使每个表中包含的列的数量尽可能地少。合理的表结构,可以大大提高整个数据库数据的查询效率。 为了提高数据库的效率,设计出高质量的存储数据的表,在设计表时,应该从整体上考虑下面7个因素。 ;ER图是描述数据库中所有实体以及实体之间关系的图形,是辅助设计关系模型的工具。 表就是关系模型,也对应着模型中的实体,是存储数据的对象。 在设计表时,应该综合考虑这些问题: 数据库中将要包含哪些数据? 数据库中应该包含多少表? 每一个表将要包含哪些数据? 表和表之间是否存在关系?如果存在关系,那么存在什么样的关系?;确定了表之后,就要确定表的内容。每一个表包含多个列,每一个列都有一个数据类型,数字数据类型的列还需要确定列的精度和约度,这些都是设计表时必不可少的因素。 数字列应该使用数字数据类型,字符列应该使用字符数据类型,日期列应该使用日期数据类型。 对于数字列,需要认真考虑其精度和约度,对于字符列,应该考虑其是否使用定长字符列和字符长度。 考虑这些因素的目标是:使得表中的列的数量尽可能地少。如果列的数量过多,应该考虑将该表分解成两个表或多个表。;列允许空值,表示该列可以不包含任何的数据,空值既不是数字0,也不是空字符,而是表示未知。如果允许列包含空值,表示可以不为该列输入具体的数据;如果不允许列包含空值,在输入数据时必须为该列提供数据。 例如,在包含订单的orders表中,订单代码、产品代码、客户代码等列不允许空置,但是订单描述列则可以包含空值。 考虑这个因素的目标是,尽可能地不使用允许空值的列,因为空值列有可能带来意想不到的查询效果。如果不得不允许某些列为空,那么应该使得这些列的数量最少。;主键是唯一确定每一行数据的方式,是一种数据完整性对象。 主键往往是一个列或多个列的组合。一个表中最多只能有一个主键。 一般地,应该为每一个表都指定主键,借此可以确定行数据的唯一性。 ;约束、默认值、规则等都是数据完整性对象,用来确保表中的数据质量。 对表中数据的查询操作,只能在满足定义的约束、默认值、规则等条件下,才能执行成功。 这些因素的考虑往往与表中数据的商业特性相关。 ;在ER图中,需要绘制出实体之间的关系。在表的设计时,实体之间的关系需要借助主键——外键对来实现。因此,该因素也是确保ER图完整实施的一个重要内容。只有通过这种关系,才能确保表和表之间强制的商业性关系。 ;索引也是一种数据库对象,是加快对表中数据检索的手段,是提高数据库使用效率的一种重要方法。 在哪些列上使用索引,在哪些列上不使用索引,是使用聚集索引,还是使用非聚集索引,是否使用全文索引,等等。 对这些因素的认真考虑和实现,也是对表质量的更高的要求。;3.1.2 表的数据类型;3.1.3 创建表;使用SQL Server Management Studio创建表 ;在这个交互式多媒体中,你可以了解如何使用SQL Server Management Studio创建表,请注意你需要为表指定一个自动增长的列作为ID,同时另外一列将拥有默认值。;use xscj go create table student (学号 char(10) not null, 姓名 varchar(8) not null, 性别 char(2) not null, 专业 varchar(30), 出生日期 smalldatetime not null, 简历 text );*;*;*;计算列由可以使用同一表中的其他列的表达式计算得来。表达式可以是非计算列的列名、常量、函数,也可以是用一个或多个运算符连接的上述元素的任意组合。表达式不能为子查询。 例如,在 AdventureWorks 示例数据库中,Sales.SalesOrderHeader 表的 TotalDue 列具有以下定义:TotalDue AS Subtotal + TaxAmt + Freight。; 一般情况下,计算列是未实际存储在表中的虚拟列。每当在查询中引用计算列时,都将重新计算它们的值。数据库引擎在 CREATE TABLE 和ALTER TABLE 语句中使用 PERSISTED 关键字来将计算列实际存储在表中。 如果在计算列的计算更改时涉及任何列,将更新计算列的值。 ;*; 指定 SQL Server 数据库引擎将在表中物理存储计算值,而且,当计算列依赖的任何其他列发生更新时对这些计算值进行更新。;*;临时表,在数据库,顾名思义就是起到建立一个临时性的存放某数据集的作中。 临时表一般分为:事务临时表的管理、会话临

文档评论(0)

shaoye348 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档