实验2数据库的建立和维护实验.doc

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

实验 :数据库的建立和维护实验本实验需要 2 学时。 一、实验目的 要求学生熟练掌握使用 SQL 、 Transact-SQL 和 SQL Server 企业管理器数据库、修改数据和删除数据操作。 二、实验内容和步骤 Create database 姓名_数据库名_2 On (name=STUDENT_01_data, filename=e:\姓名\data\姓名_数据库名_2.mdf, size=10, maxsize=unlimited, filegrowth=10%) log on (name=student1_log, filename=e:\姓名\data\姓名_数据库名.mdf, size=2, maxsize=5, filegrowth=1) 2. 创建表 以上面创建的数据库为例,创建表。创建表实际上就是创建表结构,再向表中输入数据。既可以使用企业管理器创建表,也可以用Transact-SQL命令创建表。 (1). 使用企业管理器创建表 (2). 使用Transact-SQL命令创建表 【例1】 创建图书信息表Books。 CREATE TABLE books ( 编号 char(15) CONSTRAINT PK_Books PRIMARY KEY, 书名 varchar(42) NULL , 作者varchar(8) NULL , 出版社 varchar(28)NULL , 定价real NULL CONSTRAINT CK_Books CHECK(定价0) ) 上面例子创建了一个包含5个列的books表,记录了图书的编号、书名、作者、出版社、定价等基本信息。在编号列上定义了一个主键约束,约束命名为PK_Books;列定价上定义了检查约束,命名为CK_Books,使定价的值不能是0或负数。 【例2】 创建图书借阅信息表Borrowinf。 CREATE TABLE borrowinf (读者编号 char(10) NOT NULL REFERENCES Readers(编号) ON DELETE CASCADE , 图书编号char (15) NOT NULL FOREIGN KEY (图书编号) REFERENCES Books(编号) ON DELETE NO ACTION, 借期 datetime NULL DEFAULT (getdate()) , 还期 datetime NULL ) 上面例子创建了一个包含5个列的borrowinf表,记录了读者借阅图书的情况,包含读者编号、图书编号、借期、还期等基本信息。列读者编号通过REFERENCE关键字定义了一个外键,它引用Readers表编号列的值。在图书编号列上定义外键的时候使用了“FOREIGN KEY”子句,也可以象读者编号列那样不使用这一子句。在借期列上定义了默认值,用到了系统函数getdate(),用于获得当前日期。定义了这一默认值后,当向表中插入记录时,如果指明了借书日期,则使用该日期填充借期列,否则,为借期列上添上通过系统函数得到的当前日期。 在这个例子中ON DELETE子句特别值得注意,在有关章节将要介绍SQL Server 2000的参照完整性实现了级联修改和级联删除的功能,ON DELETE子句就是用于指定当删除表中被其他表外键引用的行时采取什么动作,ON DELETE子句有两个选项。 ● NO ACTION:被其他表处键引用的行不能被删除,这是SQL Server 7.0以前版本的做法。 ● CASCADE:被其他表外键引用的行可以被删除,而且其他表中通过外键引用了该行的行都将被删除,读者编号列上的外键引用了readers表的编号列,ON DELETE子句的值为 CASCADE,所以在readers表中删除一个读者记录时,如果这个读者在Borrowinf表中已有借阅记录,则borrowinf表中的这些记录也都将一同被删除。图书编号列上的外键引用了books表的编号列,ON DELETE子句的值为NO ACTION,这说明在books表中删除一个图书记录时,如果在borrowinf表中已有该书的借阅记录,则这一删除操作不能被执行。 【例3】 创建读者信息表readers。 CREATE TABLE readers ( 编号char (10) NOT NULL PRIMARY KEY, 姓名char (8) NULL , 读者类型 int NULL , 限借阅数量 int NULL , 借阅期限 int NULL ) 上面例子创建了一个包含5个列的readers表,用来记录读者的信息,包含编号、姓名、读者类型、限借阅数量、借阅期限等基本信息,主键是编

文档评论(0)

170****0532 + 关注
实名认证
内容提供者

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

版权声明书
用户编号:8015033021000003

1亿VIP精品文档

相关文档