最新昆明理工大学数据库报告.docx

上传人:b****3 文档编号:4147311 上传时间:2022-11-28 格式:DOCX 页数:19 大小:416.51KB
下载 相关 举报
最新昆明理工大学数据库报告.docx_第1页
第1页 / 共19页
最新昆明理工大学数据库报告.docx_第2页
第2页 / 共19页
最新昆明理工大学数据库报告.docx_第3页
第3页 / 共19页
最新昆明理工大学数据库报告.docx_第4页
第4页 / 共19页
最新昆明理工大学数据库报告.docx_第5页
第5页 / 共19页
点击查看更多>>
下载资源
资源描述

最新昆明理工大学数据库报告.docx

《最新昆明理工大学数据库报告.docx》由会员分享,可在线阅读,更多相关《最新昆明理工大学数据库报告.docx(19页珍藏版)》请在冰豆网上搜索。

最新昆明理工大学数据库报告.docx

最新昆明理工大学数据库报告

 

《数据库原理》上机实验报告

 

专业:

自动化、测控

学号:

姓名:

班级:

指导老师:

 

昆明理工大学信息工程与自动化学院

2014年12月

一、实验目的与要求:

●熟练使用SQL定义子语言、操纵子语言命令语句

●掌握关系模型上的完整性约束机制

●掌握一定的数据库管理技术

●能完成简单的数据库应用开发

二、实验内容及学时安排(总学时:

8)

(一)数据定义子语言实验(2学时)

实验1:

利用SQL语句创建Employee数据库

程序:

createdatabaseemployee

结果:

实验2:

利用SQL语句在Employee数据库中创建人员表person、月薪表salary及部门表dept。

要求:

按表1、表达、表3中的字段说明创建

表1person表结构

字段名

数据类型

字段长度

允许空否

字段说明

P_no

Char

6

NotNull

工号,主键

P_name

Varchar

10

NotNull

姓名

Sex

Char

2

NotNull

性别

Birthdate

Datetime

8

Null

出生日期

Prof

Varchar

10

Null

职称

Deptno

Char

4

NotNull

部门代码,外键(参照dept表)

表2salary表结构

字段名

数据类型

字段长度

允许空否

字段说明

P_no

Char

6

NotNull

工号,主键,外键(参照person表)

Base

Dec

5

Null

基本工资

Bonus

Dec

5

Null

奖金,要求>50

Fact

Dec

5

Null

实发工资=基本工资+奖金

Month

Int

2

NotNull

月份

表3dept表结构

字段名

数据类型

字段长度

允许空否

字段说明

Deptno

Char

4

NotNull

部门代码,主键,

Dname

Varchar

10

NotNull

部门名称

程序:

createtabledept(

Deptnochar(4)notnull,

Dnamevarchar(10)notnull,

createtableperson(

P_nochar(6)notnullprimarykey,

P_namevarchar(10)notnull,

SexChar(10)notnull,

Birthdatedatenull,

Profvarchar(10)null,

Deptnochar(4)notnull,

Foreignkey(Deptno)Referencesdept(Deptno)

createtablesalary(

P_nochar(6)notnullprimarykey,

BaseDec(5)null,

BonusDec(5)null,

FactDec(5)null,

MonthIntnotnull,

Foreignkey(P_no)Referencesperson(P_no)

结果:

(二)数据操纵子语言实验(4学时)

实验3:

利用SQL语句向表person、salary和dept中插入数据。

要求:

按表4、表5、表6中的数据插入。

表4表person中的数据

P_no

P_name

Sex

BirthDate

Prof

Deptno

000001

王云

1973-4-7

中级

0001

000002

谢志文

1975-2-14

中级

0001

000003

李浩然

1970-8-25

高级

0002

000004

廖小玲

1979-8-6

初级

0002

000005

梁玉琼

1970-8-25

中级

0003

000006

罗向东

1979-5-11

初级

0003

000007

肖家庆

1963-7-14

高级

0003

程序:

insertintoperson(P_no,P_name,Sex,Birthdate,Prof,Deptno)

values('000001','王云','男','1973-4-7','中级','0001')

其他person表的数据插入同上。

结果:

表5表salary中的数据

P_no

Base

Bonus

Fact

S_month

000001

2100

300

1

000002

1800

300

1

000003

2800

280

1

000004

2500

250

1

000005

2300

275

1

000006

1750

130

1

000007

2400

210

(五)DIY手工艺品的“价格弹性化”

在上海,随着轨道交通的发展,地铁商铺应运而生,并且在重要的商业圈已经形成一定的气候,投资经营地铁商铺逐渐成为一大热门。

在人民广场地下“的美”购物中心,有一家DIY自制饰品店---“碧芝自制饰品店”。

1

附件

(二):

2003年,上海市总人口达到1464万人,上海是全国第一个出现人口负增长的地区。

程序:

insertintosalary

values('000001','2100','300','2400','1')

其他salary表的数据插入同上。

1、你一个月的零用钱大约是多少?

结果:

表6表dept中的数据

Deptno

Dname

0001

(三)上海的文化对饰品市场的影响人事部

0002

4.WWW。

google。

com。

cn。

大学生政策2004年3月23日财务部

我们长期呆在校园里,没有工作收入一直都是靠父母生活,在资金方面会表现的比较棘手。

不过,对我们的小店来说还好,因为我们不需要太多的投资。

0003

市场部

程序:

insertintodept

大学生个性化消费增多是一种趋势。

当前社会、经济飞速发展,各种新的消费品不断增多,流行文化时尚飞速变化,处于校园与社会两者之间的大学生肯定会受影响。

目前在大学校园,电脑、手机、CD、MP3、录音笔被称为大学生的“五件武器”。

除了实用,这也是一种表明自己生活优越的炫耀性的东西。

现下很大一部分大学生中的“负债消费”表现的典型的超前享乐和及时行乐——其消费项目多半是用于奢侈浪费的非必要生活消耗。

如举办生日宴会、打网球、保龄球、上舞厅跳舞、进夜总会唱“卡拉OK”等。

“负债消费”使很多学生耽于物欲,发展严重者轻则引起经济纠纷,动武斗殴,影响同窗友谊,重则引发犯罪事件,于社会治安不利。

values('0001','人事部')

其他dept表的数据插入同上。

2、你大部分的零用钱用于何处?

结果:

实验4:

(1)利用SQL语句修改表中的数据。

要求:

将salary表中工号为000006的员工工资增加为1800元,奖金增加为160元。

程序:

updatesalary

setBase=1800,Bonus=160

whereP_no=000006

结果:

(2)利用SQL语句删除表中的数据。

要求:

删除person表中工号为000007的员工数据。

程序:

delete

fromperson

whereP_no=000007

结果:

(3)利用SQL语句查询person表中的所有数据。

程序:

select*

fromperson

结果:

实验5:

条件查询

要求:

(1)查询person表中所有不重复的职称。

程序:

selectdistinctprof

fromperson

结果:

查询person表中职称为中级的所有员工数据。

程序:

select*

fromperson

whereProf='中级'

结果:

(2)查询person表中具有高级职称的男员工信息。

程序:

select*

fromperson

whereProf='高级'andsex='男'

结果:

(3)查询person表中姓名为王云、谢志文、罗向东的员工数据。

程序:

select*

fromperson

wherep_name='王云'orp_name='谢志文'orp_name='罗向东'

结果:

实验6:

使用ORDERBY排序

要求:

利用SQL语句将工号在000003和000006之间的员工的月收入按实发工资升序排序。

程序及结果如下:

实验7:

利用SQL语句查询各部门的实发工资总数。

程序及结果如下:

实验8:

利用SQL语句查询人事部所有员工信息。

程序:

select*

fromperson

wheredeptno=0001

结果:

实验9:

表的内连接查询:

要求:

利用SQL语句查询person表中职称为中级的员工信息。

程序及结果如下:

实验10:

表的外连接查询:

要求:

利用SQL语句查询每个员工1月份的工资和奖金

程序及结果如下:

实验11:

子查询:

要求:

利用SQL语句查询比工号为000005的员工实发工资高的所有员工信息。

程序及结果如下:

(三)数据完整性实验(1学时)

实验12:

定义外键约束

要求:

(1)创建表时将person表的deptno列定义为外键,并参考dept表的列deptno。

程序:

createtableperson(

P_nochar(6)notnullprimarykey,

P_namevarchar(10)notnull,

SexChar(10)notnull,

Birthdatedatenull,

Profvarchar(10)null,

Deptnochar(4)notnull,

Foreignkey(Deptno)Referencesdept(Deptno)

(2)将salary表中的P_no设为外键,并使其参照person表中的列P_no。

程序:

createtablesalary(

P_nochar(6)notnullprimarykey,

BaseDec(5)null,

BonusDec(5)null,

FactDec(5)null,

MonthIntnotnull,

Foreignkey(P_no)Referencesperson(P_no)

其依赖关系为

实验13:

测试对主表进行插入、更新及删除操作时的影响。

(请写明原因)

要求:

(1)向表dept中插入一行数据(‘0004’,‘研发部’),测试是否影响从表。

程序:

insertintodept(Deptno,Dname)

values('0004','研发部')

结果:

dept表的结果为

Person表的结果为:

Salary表的结果为

故向表dept中插入一行数据(‘0004’,‘研发部’),并未影响从表。

原因是因为person表参照的是dept表,salary表参照的是person表,并且person表和salary表中均没有与新插入数据有关联的数据,所以,当dept表插入新数据时,person表和salary表的数据不会发生改变。

(2)将表dept中的部门号0003改为0006,测试是否影响从表。

程序:

updatedept

setDeptno='0006'

whereDeptno='0003'

结果:

故将表dept中的部门号0003改为0006,会影响到从表。

原因是各表之间已经建立联系,person表参照的是dept表,person表中已有Deptno='0003'的数据,当dept表中的Deptno='0003'数据发生改变时,person表中数据也会发生改变,由于有约束,所以限制了程序的执行。

(3)删除表dept中部门号为0001的员工的数据,测试是否影响从表。

程序:

delete

fromdept

wheredeptno='0001'

结果:

故删除表dept中部门号为0001的员工的数据,会影响到从表。

原因是各表之间已经建立了联系,person表参照的是dept表,且person表中已有deptno=‘0001’的数据,当dept表中deptno=‘0001’的数据发生改变时,person表中数据势必会发生改变。

由于有约束,所以限制了程序的执行。

实验14:

测试对从表进行插入、更新及删除操作时的影响。

(请写明原因)

(1)向表person中插入一行数据(‘000012’,‘宋全礼’,‘男’、‘1980-7-17’,‘初级’,‘0005’),测试是否违背参照完整性。

程序:

insertintoperson(P_no,P_name,Sex,Birthdate,Prof,Deptno)

values('000012','宋全礼','男','1980-7-17','初级','0005')

结果:

向表person中插入一行数据(‘000012’,‘宋全礼’,‘男’、‘1980-7-17’,‘初级’,‘0005’),会影响到其他从表。

原因是各表之间已经建立连接,person表参照的是dept表,person表中的数据依赖于dept表中的数据,改变person表中的数据势必会影响dept表,违背了参照完整性。

由于有约束,所以限制了程序的执行。

(2)删除表中工号为000005的员工数据,测试是否违背参照完整性。

程序:

delete

fromperson

whereP_no='000005'

结果:

删除表中工号为000005的员工数据,会影响到person表的数据。

原因是各表之间已经建立了联系,salary表参照的是person表,且,salary表中已有P_no='000005'的数据,当person表中删除P_no='000005'的数据时,势必会影响到salary表,违背了参照完整性。

由于有约束,所以限制了程序的执行。

(四)用MicrosoftAccess设计Employee数据库系统(5学时)

创建表

Person表

Salary表

Dept表

(1)创建关联

(2)用查询设计工具创建查询

Person表的查询

Salary表的查询

Dept表的查询

(3)创建简单的窗体

表person的窗体

表salary的窗体

表dept的窗体

(4)创建基本报表

表person的报表

表salary的报表

表dept的报表

 

三、总结与体会

通过这次实验,我学到了很多东西,包括建表,导入数据,查询,插入。

最重要的是我们有机会用电脑自己进行实践,没接触的时候总是觉得它比较深奥或是不可接近的新型语言,但是通过这次实验,我发现只要我们有心去做一件事,就有做成的一天。

SQLServer数据库的实验学习使我对数据库的有了新的进步,以后再看到也就不至于什么也不懂。

数据库是一个存储数据的大仓库,它不但包括数据,还包括数据间的各种关系,以及各种操作。

从实验中让我更明白一些知识,表是数据最重要的一个数据对象,表的创建好坏直接关系到数数据库的成败,表的内容是越具体越好,但是也不能太繁琐,以后在实际应用中多使用表,对表的规划和理解就会越深刻。

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > PPT模板 > 图表模板

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1