资源描述:
《广药数据库实验答案参考》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、专业资料--实验三参考答案(一)、数据库、表的创建及删除1.将数据库bookdb的相关属性(系统默认设置),填入下表:项目内容数据库所有者XP-201104281226Administrator(Windows身份登录SQLserver)数据库名称bookdb数据库逻辑文件名bookdb数据文件物理名D:ProgramFilesMicrosoftSQLServerMSSQL.1MSSQLDatabookdb.mdf(本机SQLSERVER系统安装目录在D盘)数据库初始大小3MB数据文件最大值不限制增长数据文件增长量1MB日志逻辑文件名bookdb_log日志文件物理名D:
2、ProgramFilesMicrosoftSQLServerMSSQL.1MSSQLDatabookdb_log.ldf(本机SQLSERVER系统安装目录在D盘)日志文件初始大小1MB日志文件最大值2,097,152MB日志文件增长量10%*/--根据“二、实验内容”的要求,使用T-SQL命令创建/删除数据库EDUC,创建数据表student、course、sc。--2.删除bookdb数据库。DROPDATABASEbookdb--3.创建数据库EDUC。CREATEDATABASEEDUCONPRIMARY(NAME='EDUC_data',FILENAME='C:ED
3、UC_data.mdf',SIZE=4MB,MAXSIZE=10MB,FILEGROWTH=1MB)LOGON(NAME='EDUC_log',FILENAME='C:EDUC_log.ldf',SIZE=1MB,word完美格式专业资料MAXSIZE=UNLIMITED,FILEGROWTH=10%)--4.创建数据表Student。USEEDUCCREATETABLEStudent(Snovarchar(20)NOTNULLCONSTRAINTPK_StudentPRIMARYKEY,Snamevarchar(10)NOTNULL,Sageint,Ssexvarchar(2),Sd
4、eptvarchar(30))--5.创建数据表Course。CREATETABLECourse(Cnovarchar(15)NOTNULLCONSTRAINTPK_CoursePRIMARYKEY,Cnamevarchar(30),Cpnovarchar(15),Ccreditint)--6.创建数据表SC。CREATETABLESC(Snovarchar(20)NOTNULL,Cnovarchar(15)NOTNULL,GradeDECIMAL(9,2),CONSTRAINTPK_SCPRIMARYKEY(Sno,Cno))--(二)、修改基本表的定义--1.修改列属性--(1)用S
5、SMS将Student表中的Sage字段设为不能为空(notnull)。ALTERTABLEStudentALTERCOLUMNSageintNOTNULL--(2)用SQL语句将Student表中的属性Snovarchar(20)改成char(8)类型。--先删除Sno上的各种约束(此例中Sno上的约束有:主键)ALTERTABLEStudentDROPCONSTRAINTPK_Student--CONSTRAINT也可省略--再修改Sno列word完美格式专业资料ALTERTABLEStudentALTERCOLUMNSnoCHAR(8)NOTNULL--需设置为不允许空,否则不能在
6、该列上创建主键--最后,恢复(添加)Sno上的主键约束ALTERTABLEStudentADDCONSTRAINTPK_StudentPRIMARYKEY(Sno)--2.添加列--(1)用SSMS在Course表中添加一列year,类型为varchar(4),默认置为空。ALTERTABLECourseADDyearvarchar(4)NULL--(2)用SQL语句在year字段添加约束,year的属性值在2006-2012之间。ALTERTABLECourseADDCONSTRAINTCK_yearCHECK(yearBETWEEN2006AND2012)--3.删除列--(1)用S
7、QL语句将Course表中的year字段删除。--先删除year上的各种约束(CHECK约束)ALTERTABLECourseDROPCONSTRAINTCK_year--再删除yearALTERTABLECourseDROPCOLUMNyear--COLUMN不能省略word完美格式专业资料--实验四参考答案--1.统计各门课程所选修的人数,并把结果存储在一张新表中。(提示:用Select……Into……,groupby)SELE