实验四 视图、索引及数据更新
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验四视图、索引及数据更新
一、实验目的:
熟练掌握索引的建立与删除的方法,熟练掌握SQL的应用,熟练
掌握数据插入、修改和删除的使用,为后继学习作准备。
二、实验属性(验证性)
1.了解并掌握SQL查询分析器及企业管理器的使用;
2.掌握基本表的定义、删除与修改。
三、实验仪器设备及器材
1.安装有windows操作系统计算机。
2.安装有Oracle11g和SQL Server的计算机。
3.安装有Visual Studio .net和Java编译器(eclipse、Netbean等)的
编译器。
4.计算机具备网络环境。
四、实验要求(预习、实验前、实验中、实验后等要求)
1.预习教材第三章,熟悉SQL语句。
2.熟悉.net、Java和Delphi 开发环境。
3.能够熟练掌握.net、Java和Delphi环境下的数据库的编程。
4.掌握建立索引的二种方法,即在基本表中建立和用命令方式建立。
5.掌握删除索引的方法。
6.掌握sql视图建立、修改和删除;
7.掌握sql视图查询。
8.掌握sql数据插入、修改和删除语句的一般格式及使用方法。
五、实验原理
SQL语言应用。
六、实验步骤:
(1)启动Oracle的SQL Developer或者SQL Plus,或者SQL Server 查
询分析器;
(2)对于Oracle11g的SQL Plus需要进行登录,对于Oracle11g的SQL
Developer需要进行建立连接。
如果选择SQL SERVER查询分析器,需要选择数据库;
1 建立索引
建立唯一索引:
例3.1为学生选课数据库中的Students,Courses,SC三个表建立索引。其中Students表按Sname升序建唯一索引,Courses表按Cname升序建唯一索引,SC 表按Sno(学号)升序和Cno(课程号)号降序建唯一索引。
create unique index turing.myIndex
on turing.Student(Sname);
查看自己建立的索引:
SQL>desc dba_indexes [或者SQL>desc all_indexes, SQL>desc user_indexes]
select index_name,index_type,table_name
From user_indexes
Where index_name=’YOUR_INDEX_NAME’;
select t.column_name,t.Index_name,i.index_type
from dba_ind_columns t, dba_indexes i
where (t.index_name=i.index_name) and
(t.table_name=i.table_name ) and
(t.table_name='STUDENT')
建立位图索引:(选做,理解位图索引的意义,什么情况下才使用位图索引?)
例3.2为学生选课数据库中的Student的ssex列上建立位图索引。
create bitmap index turing.bm_ixdex_student
on turing.student(ssex)
tablespace turing.tbs_test
local(partition ix_p1 tablespace tbs_01
partition ix_p2,
partition ix_p3 tablespace tbs_02
partition ix_p4,
partition ix_p5 tablespace tbs_03
)
查看位图索引的创建情况。建立位图索引时,如果报以下错误:“ORA-00439: 未启用功能: Bit-mapped indexes”,是因为该Oracle版本不具有bitmap index功能或未装bitmap index功能,使用以下查询可以确定:以dba身份连入Oracle,执行以下查询:
select *
from v$option
Where PARAMETER='Bit-mapped indexes';
如果value的值为true表示,安装了bitmap index功能;如果value 值为false表示版本不具有bitmap index功能或未装bitmap index功能。使用oracle 的installer把bitmap index功能选上,安装就可以了。
2 删除索引
例3.2删除基本表SC上的Rep_SCno索引。
drop index turing.index_name;
3 建立视图
例3.4建立数学系学生的视图C_Student,并要求进行修改和插入操作时仍需保证该视图只有数学系的学生,视图的属性名为Sno,Sname,Sage,Sdept。
Create view turing.c_student
As
Select sno,sname,sage,sdept
From turing.student
Where sdept=’计科系’;
例3.5建立学生的学号(Sno)、姓名(Sname)、选修课程名(Cname)及成绩(Grade)的视图Student_CR。
create view turing.student_cr
as
select student.sno,sname,cname,grade
from turing.student,turing.course,turing.sc
where sc.sno=student.sno and o=o;
定义一个反映学生出生年份的视图
student_birth(sno,sname,s_birth,ssex,sdept)。
create view turing.student_birth
as
select sno,sname,2013-sage as s_birth,ssex,sdept
from turing.student;