数据库原理与应用——实验一

实验一题目内容

实验一 关系数据库管理系统的使用
数据库管理系统是数据库系统的核心,是为数据库的建立、使用和维护而配置的软件,它建立在操作系统的基础上,是位于操作系统与用户之间的一层数据管理软件,负责对数据库进行统一的管理和控制。根据所依赖的数据模型,主要有三种数据库管理系统,层次系统,网状系统和关系系统, 其中关系系统是目前使用最广泛最重要的一种数据库管理系统.
SQL Server 2008是一个功能强大、操作方便的数据库管理系统,其日益受到广大数据库用户的青睐,因此为了更好地掌握数据库原理课程中的概念和理论,了解和掌握SQL Server 2008的主要功能是非常必要的。
实验的目的:加强理解数据库,数据库管理系统,数据库系统等概念; 熟悉数据库管理系统的功能; 学习使用数据库管理系统.教学时间为3课时.
实验内容:
学习数据库管理系统SQL Server的使用,进行数据库定义,创建和管理维护;学习在数据库中建立关系,建立索引等数据库对象等.
实验要求:

  1. 通过本实验的学习,读者应该掌握以下内容:
    SQL Server 2008的体系结构
    SQL Server 2008的安装
  2. 熟悉SQL Server服务启动、服务器注册。对management studio进行熟悉,能通过菜单界面完成各种操作; 进一步了解数据库管理系统的功能。
    实验指导:
    实验操作题目:使用Management studio完成以下操作
    ⑴ 创建教师数据库teacher。
    ⑵ 在teacher内创建:
    教师基本情况表(jbqk),包括教师编号(teacher_no)、教师姓名(teacher_name)、教师所在部门编号(department_no)、教师职称(teacher_grade)。
    教师部门信息表(bmxx),包括部门编号(department_no)、部门名称(department_name)、部门描述(department_ms)。
    开课情况表(kkqk),包括开课号(lessonID), 教师编号(teacher_no)、所上课程(course_kc)、上课地点(classroom)、上课时间(lessonTime),课时数(course_ks)、限定人数(total_number)。
    课程信息表(kcxx), 包括课程号码(courseID), 课程名称(coursename),课程简介(description),课程学分(credit)
    选课信息表(xkxx),包括开课号(lessonID),学号(sno),成绩(grade)
    学生信息表(xsxx),包括学号(sno),姓名(sname),系别(deptNO),专业班级(specialtyclass),性别(gender),出生日期(DOB)

设计要求:
①每个表至少输入10条记录。要求记录要符合现实意义。
②向各表中插入一条记录,再删除各表中的第5条记录。

实验一具体操作

【项目内容】
实验操作题目:
使用Management studio完成以下操作
⑴ 创建教师数据库teacher。
⑵ 在teacher内创建:
教师基本情况表(jbqk),包括教师编号(teacher_no)、教师姓名(teacher_name)、教师所在部门编号(department_no)、教师职称(teacher_grade)。
教师部门信息表(bmxx),包括部门编号(department_no)、部门名称(department_name)、部门描述(department_ms)。
开课情况表(kkqk),包括开课号(lessonID), 教师编号(teacher_no)、所上课程(course_kc)、上课地点(classroom)、上课时间(lessonTime),课时数(course_ks)、限定人数(total_number)。
课程信息表(kcxx), 包括课程号码(courseID), 课程名称(coursename),课程简介(description),课程学分(credit)
选课信息表(xkxx),包括开课号(lessonID),学号(sno),成绩(grade)
学生信息表(xsxx),包括学号(sno),姓名(sname),系别(deptNO),专业班级(specialtyclass),性别(gender),出生日期(DOB)
设计要求:
①每个表至少输入10条记录。要求记录要符合现实意义。
②向各表中插入一条记录,再删除各表中的第5条记录。

【方案设计】
关系名 属性的名字 属性含义 域 是否主码 是否外码
Jbqk teacher_no 教师编号 Char(12) 是
teacher_name 教师姓名 Char(30)
department_no 教师所在部门编号 Char(12) 是-bmxx( department_no)
teacher_grade 教师职称 Char(20)
Bmxx department_no 部门编号 Char(12) 是
department_name 部门名字 Char(20)
department_ms 部门描述 Char(50)
Kkqk lessonID 开课号 Char(12) 是
teacher_no 教师编号 Char(12) 是
-jbqk(teacher_no)
course_kc 所上课程 Char(12) 是
-kcxx(courseID)
classroom 上课地点 Char(20)
lessonTime 上课时间 Char(20)
course_ks 课时数 Int(10)
total_number 限定人数 Int(10)
Kcxx courseID 课程号码 Char(12) 是
coursename 课程名称 Char(30)
coursedescription 课程简介 Char(100)
credit 课程学分 Char(10)
Xkxx lessonID 开课号 Char(12) 是
sno 学号 Char(12) 是
-xsxx(sno)
grade 成绩 Char(12)
Xsxx sno 学号 Char(12) 是
sname 姓名 Char(30)
deptNO 系别 Char(12)
specialtyclass 专业班级 Char(20)
gender 性别 Char(10)
DOB 出生日期 Date

【实验(实训)过程】(步骤、记录、数据、程序等)
首先在数据库中创建以下的表格,按照bmxx->jbqk->kcxx->kkjk->xkxx->xsxx的顺序创建,其中用于连接两个表格的同一性质的数据需要用同样的数据类型。

USE TEACHER
GO

create table bmxx
(
department_no char(12),
department_name char(20),
department_ms char(50),
constraint pk_bmxx primary key(department_no),
)

create table jbqk
(
teacher_no char(12),
teacher_name char(30),
department_no char(12),
teacher_grade char(20),
constraint pk_jbqk primary key(teacher_no),
constraint fk_jbqk foreign key(department_no) references bmxx(department_no),
)

create table kcxx
(
courseID char(12),
coursename char(30),
coursedescription char(100),
credit char(10),
constraint pk_kcxx primary key(courseID),
)

create table kkqk
(
lessonID char(12),
teacher_no char(12),
course_kc char(12),
classroom char(20),
lessonTime char(20),
course_ks int(10),
total_number int (10),
constraint pk_kkqk primary key(lessonID),
constraint fk_kkqk foreign key(teacher_no) references jbqk(teacjer_no),
constraint fk_kkqk foreign key(course_kc) references kcxx(courseID),
)

create table xkxx
(
lessonID char(12),
sno char(12),
grade char(12),
constraint pk_xkxx primary key(lessonID),
constraint fk_xkxx foreign key(sno) references xsxx(sno),
)

create table xsxx
(
sno char(12),
sname char(30),
deptNO char(12),
specialtyclass char(20),
gender char(10),
DOB datetime,
constraint pk_xsxx primary key(sno),
)

其次,每个表至少输入10条记录。要求记录要符合现实意义。随意输入相关的信息得到以下的表格:

第二步,向各表中插入一条记录,再删除各表中的第5条记录。

insert into bmxx(department_no,department_name,department_ms) values ('0000','department0','just for insert')
insert into jbqk(teacher_no,teacher_name,department_no,teacher_grade) values ('000','Z','00001','headmaster')
insert into kcxx(courseID,coursename,coursedescription,credit) values('Z0026','math','study math','10')
insert into xsxx(sno,sname,deptNO,specialtyclass,gender,DOB) values ('26','EMMA','S26','CLASS26','male','2000-05-01')
insert into xkxx(lessonID,sno,grade) values  ('Z26','26','100')
delete bmxx where department_no ='00004'
delete jbqk where department_no = '00004'
delete kcxx where courseID='E0005'
delete xsxx where sno='05'
delete xkxx where sno='05'

【结论】(结果、分析)
得到以下表结果:

分析:
(1)对于每个表格数据的插入,主要采用的是insert into <表名称> (表内属性)values(属性值1,属性值2…)的语句进行插入。
(2)插入语句所得的数据结果会按照表格的具体内容进行排列,有的插入数据会出现在表格的最前面一排,有的插入数据会出现在表格的最后一排,主要看插入数据的内容与原来表格数据的大小关系。
(3)插入语句的使用需要按照表格内容进行。由于在某些表格中存在的属性是其他表格的外码,所以在插入内容时如果存在外码,则改属性值在输入时需要严格按照数据类型进行同样格式内容的修改,且最好先修改外码对应的表格。
删除语句主要采用的是delete <表名称> where <属性名> = <属性值>,在删除表格内数据的时候,需要按照插入的表格数据进行,比较不容易出错。主要是选中第五行中的数据的一个属性值,针对该属性值填写以上的删除语句,对该行数据进行删除。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值