最新昆明理工大学数据库报告.docx
- 文档编号:4147311
- 上传时间:2022-11-28
- 格式:DOCX
- 页数:19
- 大小:416.51KB
最新昆明理工大学数据库报告.docx
《最新昆明理工大学数据库报告.docx》由会员分享,可在线阅读,更多相关《最新昆明理工大学数据库报告.docx(19页珍藏版)》请在冰豆网上搜索。
最新昆明理工大学数据库报告
《数据库原理》上机实验报告
专业:
自动化、测控
学号:
姓名:
班级:
指导老师:
昆明理工大学信息工程与自动化学院
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文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 昆明 理工大学 数据库 报告