- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验四 用SQL语句创建SQL Server 数
据库和表(2学时)
一. 实验的目的
熟悉企业管理器环境。
掌握使用查询分析器的方法
熟练掌握数据库创建、表创建与修改、索引创建与删除的语法
熟悉SQL SERVER的数据类型
熟练使用SQL SERVER的联机帮助系统
二、相关知识点
建立数据库
创建数据库的语句请参见SQLSERVER的帮助CREATE DATABASE,以下仅作参考
定义表的语句:
CREATE TABLE 表名
(列名 数据类型[ 列级完整性约束条件 ]
[,列名 数据类型[ 列级完整性约束条件] ] …
[,表级完整性约束条件 ] );
[例]
修改表的语句:
ALTER TABLE 表名
[ ADD 新列名 数据类型 [完整性约束 ] ]
[ DROP 完整性约束名 ]
[ ALTER COLUMN列名 数据类型 ];
[例]
删除表的语句:
DROP TABLE表名
增加、删除索引
三. 实验内容
创建学生-课程数据库(命名为S_T),然后在S_T数据库中创建学生情况表Student,课程表Course,学生选课表SC。
各种表的表结构如下:
表3-1 student表结构
列名 描述 数据类型 长度 是否允许为空值 默认值 说明 Sno 学号 Char 11 N 主键 Sname 姓名 Char 8 N Ssex 性别 Char 2 N Sage 年龄 Tinyint N Sdept 所在系 Char 10 N
表3-2 Course表结构
列名 描述 数据类型 长度 是否允许为空值 说明 Cno 课程号 Char 3 N 主键 Cname 课程名 Char 20 N Cpno 先修课 Char 10 Ccredit 学分 Tinyint 取值1-6的整数 表3-3 SC表结构
列名 描述 数据类型 长度 是否允许为空值 说明 Sno 学号 Char 11 N 外键 Cno 课程号 Char 3 N 外键 Grade 成绩 numeric (3,1) 0-100之间
修改表结构
将course表的cpno的长度改为3
将student表中的sdept列的长度改为50
给student表中的ssex列的增加默认约束,默认值为“男”
为course表增加一列teacher,char(8)
删除course表的teacher列
为sc增加主键约束,约束建立在sno,cno两列上,命名为s_c
答案
--修改表中字段列的长度
--将course表的cpno的长度改为3
--将student表中的sdept列的长度改为50
alter table course alter column Cpno char(3)
alter table student alter column sdept char(50)
--修改表位列增加约束
--给student表中的ssex列的增加默认约束,默认值为“男”
alter table student add constraint df_stu_sex default(男) for Ssex
--修改表增加新列
--为course表增加一列teacher,char(8)
alter table course add teacher char(8)
--修改表删除列:? 删除course表的teacher列
alter table course drop column teacher
--修改表添加主键约束:? 为sc增加主键约束,约束建立在sno,cno两列上,命名为s_c
alter table SC add constraint pk_SC_sc primary key(Sno,Cno)
完成课后练习的SPJ数据库及相应的S、P、J表的建立,并按照以下的要求补充:
为每个表设一个主键
为S表增加一个唯一索引s_sno
为p表增加一个索引p_pno,要求降序
为J表增加一个索引j_jno
为SPJ表加外键约束
为SPJ表增加列qty的检查约束,要求qty0
为SPJ表增加索引spj_sno_pno_jno,要求索引列sno用降序,pno、jno用升序
预习INSERT INTO语句的用法,完成以上所有数据库表的记录输入
答案
use master --进入当前需要使用的数据库
go
--创建spj数据库
create database spj
ON --数据文件
(
name=spj_db,
filename =E:\SQL Server2005\database\spj_db.mdf,
size =3,
文档评论(0)