- 浏览: 202076 次
- 性别:
- 来自: 芜湖
文章分类
- 全部博客 (139)
- 软件 (0)
- Pattern (6)
- CSDN导入 (19)
- Struts (3)
- [网站分类]1.网站首页原创 (27)
- [网站分类]6.转载区 (4)
- Hibernate (10)
- Error (8)
- [网站分类]2.Java新手区 (20)
- Java (8)
- [网站分类]4.其他技术区 (10)
- Web (1)
- C++ (2)
- Algorithm (4)
- Linux (2)
- Skill (1)
- Tech (2)
- Note (2)
- [网站分类]3.非技术区 (1)
- Database (1)
- Winty (7)
- [网站分类]1.网站首页原创Java技术区(对首页文章的要求: 原创、高质量、经过认真思考并精心写作。BlogJava管理团队会对首页的文章进行管理。) (0)
最新评论
-
haohao-xuexi02:
很不错哦。
O'Reilly cos上传组件的使用(1/3) - 上传文件 -
yoin528:
useUnicode=true&charact ...
[原]向MySQL数据库插入Blob数据的问题 -
xiaoqing20:
下载来看看!呵呵
[原]Struts2类型转换 -
xiaoqing20:
[原]Struts2类型转换
ORACLE实验2007
实验一
练习1、请查询表DEPT中所有部门的情况。
select * from dept;
练习2、查询表DEPT中的部门号、部门名称两个字段的所有信息。
select deptno,dname from dept;
练习3、请从表EMP中查询10号部门工作的雇员姓名和工资。
select ename,sal from emp where deptno=10;
练习4、请从表EMP中查找工种是职员CLERK或经理MANAGER的雇员姓名、工资。
select ename,sal from emp where job='CLERK' or job='MANAGER';
练习5、请在EMP表中查找部门号在10-30之间的雇员的姓名、部门号、工资、工作。
select ename,deptno,sal,job from emp where deptno between 10 and 30;
练习6、请从表EMP中查找姓名以J开头所有雇员的姓名、工资、职位。
select ename,sal,job from emp where ename like 'J%';
练习7、请从表EMP中查找工资低于2000的雇员的姓名、工作、工资,并按工资降序排列。
select ename,job,sal from emp where sal<=2000 order by sal desc;
练习8、请从表中查询工作是CLERK的所有人的姓名、工资、部门号、部门名称以及部门地址的信息。
select ename,sal,emp.deptno,dname,loc from emp,dept where emp.deptno=dept.deptno and job='CLERK';
练习9、查询表EMP中所有的工资大于等于2000的雇员姓名和他的经理的名字。
select a.ename,b.ename from emp a,emp b where a.mgr=b.empno(+) and a.sal>=2000;
练习10、在表EMP中查询所有工资高于JONES的所有雇员姓名、工作和工资。
select ename,job,sal from emp where sal>(select sal from emp where ename=’JONES’);
练习11、列出没有对应部门表信息的所有雇员的姓名、工作以及部门号。
select ename,job,deptno from emp where deptno not in (select deptno from dept);
练习12、查找工资在1000~3000之间的雇员所在部门的所有人员信息
select * from emp where deptno in (select distinct deptno from emp where sal between 1000 and 3000);
练习13、雇员中谁的工资最高。
select ename from emp where sal=(select max(sal) from emp);
select ename from (select * from emp order by sal desc) where rownum<=1;
*练习14、雇员中谁的工资第二高(考虑并列第一的情况,如何处理)。
select ename from (select ename ,sal from (select * from emp order by sal desc) where rownum<=2 order by sal) where rownum<=1;
实验二
1. 查询所有雇员的姓名、SAL与COMM之和。
select ename,sal+nvl(comm,0) “sal-and-comm” from emp;
2. 查询所有81年7月1日以前来的员工姓名、工资、所属部门的名字
select ename,sal,dname from emp,dept where emp.deptno=dept.deptno and hiredate<=to_date('1981-07-01','yyyy-mm-dd');
3. 查询各部门中81年1月1日以后来的员工数
select deptno,count(*) from emp where hiredate>=to_date('1981-01-01','yyyy-mm-dd') group by deptno;
4. 查询所有在CHICAGO工作的经理MANAGER和销售员SALESMAN的姓名、工资
select ename,sal from emp where (job='MANAGER' or job='SALES') and deptno in (select deptno from dept where loc='CHICAGO');
5. 查询列出来公司就职时间超过24年的员工名单
select ename from emp where hiredate<=add_months(sysdate,-288);
6. 查询于81年来公司所有员工的总收入(SAL和COMM)
select sum(sal+nvl(comm,0)) from emp where to_char(hiredate,'yyyy')='1981';
7. 查询显示每个雇员加入公司的准确时间,按××××年××月××日 时分秒显示。
select ename,to_char(hiredate,'yyyy-mm-dd hh24:mi:ss') from emp;
8. 查询公司中按年份月份统计各地的录用职工数量
select to_char(hiredate,'yyyy-mm'),loc,count(*) from emp,dept
where emp.deptno=dept.deptno group by to_char(hiredate,'yyyy-mm'),loc;
9. 查询列出各部门的部门名和部门经理名字
select dname,ename from emp,dept where emp.deptno=dept.deptno and job='MANAGER';
10. 查询部门平均工资最高的部门名称和最低的部门名称
select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) ) where rownum<=1)
union all select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) desc ) where rownum<=1);
11. *查询与雇员号为7521员工的最接近的在其后进入公司的员工姓名及其所在部门名
select ename,dname
from (select ename,deptno from
(select ename,deptno from emp where hiredate>(select hiredate from emp where empno=7521) order by hiredate ) where rownum<=1) e,dept
where e.deptno=dept.deptno
实验三、
1. 建立一个表(表名自定),表结构与EMP相同,没有任何记录。
create table my_emp as select * from emp;
Delete From my_emp;--WintyAdd
2. 用INSERT语句输入5条记录,并提交。
insert into my_emp values(200,'Winty','CLERK',300,to_date('8-25-2006','mm-dd-yyyy'),1500,500,40);--WintyAdd
Commit;
3. 扩大该表的记录数到约40条,并使雇员号不重复;每个雇员都有所属部门,雇员在同一部门的经理是同一人。
insert ….
update …
commit
4. 建立一个与DEPT表结构和记录完全相同的新表,并与前项新表建立参照完整性约束。
create table my_dept as select * from dept;--WintyAdd
alter table my_dept add( constraint s1 primary key(deptno));--*
alter table my_emp add(constraint s2 foreign key(deptno) references dept(deptno));
5. 对在'NEW YORK'工作的雇员加工资,每人加200。
update my_emp set sal=sal+200 where my_emp.deptno in
(select deptno from my_dept where my_dept.loc='NEW YORK');--WintyAdd
6. *如果雇员姓名与部门名称中有一个或一个以上相同的字母,则该雇员的COMM增加500。
translate(c1,c2,c3)将c1中与c2相同的字符以c3代替;
chr(27)为ESC
update my_emp a
set comm=NVL(comm,0)+500
where a.ename<>(
select translate(a.ename,b.dname,CHR(27))
from my_dept b where b.deptno=a.deptno
);
--a.deptno与b.deptno必须有主外键连接,否则可能出错,为什么?
否则会有错误:单行子查询返回多个行--WintyAdd
commit;
7. 删除部门号为30的记录,并删除该部门的所有成员。
delete from emp where deptno=30;
delete from dept where deptno=30;
commit
8. 新增列性别SEX,字符型。
alter table emp add(sex char(2));
9. 修改新雇员表中的MGR列,为字符型。
该列数据必须为空
alter table emp modify(mgr varchar2(20));
10. 试着去删除新表中的一个列。
alter table my_emp drop (comm);
实验四、
1. 查询部门号为30的所有人员的管理层次图。
select level,ename from emp
start with deptno=30 and job='MANAGER'
connect by mgr=prior empno;
2. 查询员工SMITH的各个层次领导。
select level,ename from emp
start with ENAME='SMITH'
connect by prior mgr= empno;
3. 查询显示EMP表各雇员的工作类型,并翻译为中文显示
用decode函数
select ename,decode(job,'CLERK','雇员','MANAGER','经理','Default') a from emp;--WintyAdd
4. *查询显示雇员进入公司当年是什么属相年(不考虑农历的年份算法)
用decode函数
select decode(mod(to_number(to_char(hiredate,'mmddyy')),12),0,'猴',1,'鸡',2,'狗','None') from e;--WintyAdd
5. 建立一个视图myV_emp,视图包括myEMP表的empno、ename、sal,并按sal从大到小排列。
create view myV_EMP as select empno,ename,sal from emp;
6. 定义一个mySeq,对select mySeq.nextval,my_emp.* from my_emp的执行结果进行说明。
create sequence mySeq
increment by 10
start with 100
nocache
nocycle;
select mySeq.nextval,my_emp.* from my_emp;
--WintyAdd
7. 定义序列mySeq、myEMP、myV_emp的同义词,能否用同义词对上述对象进行访问。
create synonym syn_myEMP for my_EMP;--WintyAdd
8. 在myEMP表中建立ename的唯一性索引。
alter table my_emp add(constraint sfds unique(ename));--WintyAdd
9. 如何在sql*plus中,运行sql的脚本(即后缀为.sql的文件)
@C:"sql1.sql--WintyAdd
start C:"sql1.sql--WintyAdd
实验五、
1. 观察下列PL/SQL的执行结果
declare
s emp%rowtype;
begin
select * into s
from emp where ename='KING';
DBMS_OUTPUT.PUT_LINE(s.empno||s.ename||s.job||s.sal);
END;
2. 编写一个PL/SQL,显示ASC码值从32至120的字符。
begin
for i in 32..120
loop
dbms_output.put_line(chr(i));
end loop;
end;
i未定义并不提示出错--WintyAdd
3. 计算myEMP表中COMM最高与最低的差值,COMM值为空时按0计算。
declare
var1 number;
var2 number;
val_comm number;
begin
select max(nvl(comm,0)) into var1 from myemp;
select min(nvl(comm,0)) into var2 from myemp;
val_comm:=var1-var2;
dbms_output.put_line(val_comm);
end;
4. 根据表myEMP中deptno字段的值,为姓名为'JONES'的雇员修改工资;若部门号为10,则工资加100;部门号为20,加200;其他部门加400。
declare
c1 number;
c2 number;
begin
select deptno into c1 from emp where ename='JONES';
if c1=10 then
c2:=100;
elsif c1=20 then
c2:=200;
else c2:=400;
end if;
update emp set sal=sal+c2 where ename='JONES';
commit;
end;
5. 计算显示部门人数最多的部门号、人数、工资总和,以及部门人数最少的部门号、人数、工资总和。
--WintyAdd
最多时:
select deptno,PersonNum,TotalSal from
(select deptno,count(*) PersonNum,sum(nvl(sal,0)+nvl(comm,0)) TotalSal
from emp group by deptno order by PersonNum desc)
where rownum< =1;
最少时:
Asc
6. 计算myEMP中所有雇员的所得税总和。假设所得税为累进税率,所得税算法为:工资收入为0-1000为免税;收入1000-2000者,超过1000的部分税率10%;2000-3000者超过2000部分按20%税率计算;3000-4000者超过3000部分按30%税率计算;4000以上收入,超过4000部分按40%税率计算。(请查阅累进税率的概念)
declare
sum_xx number:=0;
xx number :=0;
begin
--计算收入为1000-2000的所得税总额
select sum((sal-1000)*0.1) into xx from emp where sal >1000 and sal<=2000;
sum_xx:=sum_xx+xx;
--计算收入为2000-3000的所得税总额
select sum((sal-2000)*0.2+100) into xx from emp where sal >2000 and sal<=3000;
sum_xx:=sum_xx+xx;
--计算收入为3000-4000的所得税总额
select sum((sal-3000)*0.3+300) into xx from emp where sal >3000 and sal<=4000;
sum_xx:=sum_xx+xx;
--计算收入为4000以上的所得税总额
select sum((sal-4000)*0.4+600) into xx from emp where sal >4000;
sum_xx:=sum_xx+xx;
dbms_output.put_line(sum_xx);
end;
7. *(可选做,难题)假设有个表如myEMP,未建立主键,含有多条记录重复(列值完全相同),试编制一个PL/SQL,将多余的重复记录删除。
实验六、
1. 用外部变量,实现两个PL/SQL程序间的数据交换。
SQL> variable a1 number;
SQL> begin
2 :a1:=1000;
3 end;
4 /
PL/SQL 过程已成功完成。
SQL> begin
2 dbms_output.put_line(:a1);
3 end;
4 /
1000
PL/SQL 过程已成功完成。
2. 插入myEMP表中的数据记录,考虑可能出现的例外,并提示。
主要的例外提示:唯一性索引值重复DUP_VAL_ON_INDEX
begin
insert into myEMP values(7369,'winty','CLERK',7902,to_date('17-12-80','dd-mm-yy'),800,NULL,20);
exception
when DUP_VAL_ON_INDEX then
dbms_output.put_line('记录重复');
when others then
null;
end;
3. 删除myDEPT表中的数据记录一条,考虑例外情况,并提示。
主要的例外提示:违反完整约束条件
4. 将下列PL/SQL改为FOR游标
declare
cursor cur_myemp is select * from emp;
r emp%rowtype;
begin
open cur_myemp;
fetch cur_myemp into r;
while cur_myemp%found
loop
dbms_output.put_line(r.ename);
fetch cur_myemp into r;
end loop;
close cur_myemp;
end;
用For 实现.
Declare
Cursor cur_myemp Is Select * From emp;
Begin
For cur_myemp_cur In cur_myemp Loop
dbms_output.put_line(cur_myemp_cur.ename);
End Loop;
End;
/
5. 工资级别的表salgrade,列出各工资级别的人数。(用游标来完成)
declare
v1 number;
cursor cur1 is select * from salgrade;
begin
for c1 in cur1
loop
select count(*) into v1 from emp where sal between c1.losal and c1.hisal;
dbms_output.put_line('grade'||c1.grade||' '||v1);
end loop;
end;
实验七、
1. 在myEMP表中增加一个字段,字段名为EMPPASS,类型为可变长字符。
alter table myemp add(emppass varchar2(50));
2. 建立一个存储过程,用于操作用户登录的校验,登录需要使用EMPNO和EMPPASS,并需要提示登录中的错误,如是EMPNO不存在,还是EMPNO存在而是EMPPASS错误等。
create or replace procedure p_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
x1 emp.ename%type;
x2 number;
begin
select ename into x1 from emp where empno=in_empno;
select count(*) into x2 from emp where empno=in_empno and emppass=in_emppass;
if x2=1 then
out_code:=0;
out_desc:=x1;
else
out_code:=2;
out_desc:='用户登陆密码错误!';
end if;
exception
when NO_DATA_FOUND then
out_code:=1;
out_desc:='该用户号存在!';
when TOO_MANY_ROWS then
out_code:=3;
out_desc:='该用户号有重复值!';
when others then
out_code:=100;
out_desc:='其他错误!';
end;
3. 建立一个存储过程,实现myEMP表中指定雇员的EMPPASS字段的修改,修改前必须进行EMPPASS旧值的核对。
create or replace procedure p_changepass(
in_empno in emp.empno%type,
in_oldpass in emp.emppass%type,
in_newpass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
x1 number;
begin
select count(*) into x1 from emp where empno=in_empno and emppass=in_oldpass;
if x1=1 then
update emp set emppass=in_newpass where empno=in_empno;
commit;
out_code:=0;
out_desc:='修改口令成功';
else
out_code:=1;
out_desc:='修改口令不成功';
end if;
exception
when others then
out_code:=100;
out_desc:='其他错误';
end;
//Now Here:winty
4. 建立一个函数,输入一个雇员号,返回该雇员的所在同一部门的最高级别上司姓名。
create or replace function f_leader(
in_empno in emp.empno%type) return varchar2
is
v1 number;
v2 number;
v3 emp.ename%type;
v4 emp.deptno%type;
begin
v1:=in_empno;
v3:='未找到';
select deptno into v4 from emp where empno=v1;
loop
select mgr into v2 from emp where empno=v1;
select ename into v3 from emp where empno=v2 and deptno=v4;
v1:=v2;
end loop;
exception
when others then
return v3;
end;
5. 试用上题函数,实现各雇员的同一部门最高级别上司的SELECT查询。
select f_leader(7521) from dual;
6. *编写实验五中第六题,关于各雇员工资的所得税计算函数
实验八、
1. 建立一个触发器,当myEMP表中部门号存在时,该部门不允许删除。
create or replace trigger dept_line_delete
before delete on dept for each row
declare
v1 number;
begin
select count(*) into v1 from emp where deptno=:old.deptno;
if v1>=1 then RAISE_APPLICATION_ERROR(-20000,'错误');
end if;
end;
实验九、
1. 建立一个示例包emp_mgmt中,新增一个修改雇员所在部门的过程。
create or replace package emp_mgmt as
procedure change_dept(
in_newdept in emp.deptno%type,
out_code out number,
out_desc out varchar2);
mgmt_empno emp.empno%type;
procedure mgmt_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2);
end;
create or replace package body emp_mgmt as
procedure change_dept(
in_newdept in emp.deptno%type,
out_code out number,
out_desc out varchar2)
is
begin
update emp set deptno=in_newdept where empno=mgmt_empno;
commit;
out_code:=0;
out_desc:='ok';
end;
procedure mgmt_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
begin
--登陆过程见实验七第2题
mgmt_empno:=in_empno;
out_code:=0;
out_desc:='ok';
end;
end;
2. 假设myEMP表中有口令字段password,试在包emp_mgmt中建立一个登录的过程,并将登录成功的雇员号存入包变量。
见前一题
3. 示例包emp_mgmt中,将remove_emp操作设限,只有本部门经理操作才能删除本部门雇员记录,只有公司头头PRESIDENT才能删除部门经理的雇员记录。
--
procedure remove_emp(
remove_empno emp.empno%type,
out_code number,
out_desc varchar2)
is
x emp.job%type;
y number;
begin
select job,deptno into x,y from emp where empno=mgmt_empno;
if x='PRESIDENT' then
delete from emp where empno=remove_empno and job='MANAGER';
else
delete from emp where empno=remove_empno and deptno=y and x='MANAGER';
end if
if sql%found then
out_code:=0;
out_desc:='ok';
else
out_code:=1;
out_desc:='未删除记录';
end if;
commit;
end;
4. *用DELPHI+ORACLE实现上题的软件功能。
实验十
1. 编写一段PL/SQL,利用系统工具包,实现对SERVER端数据文件D:"DATA"A.TXT的读取输出至缓冲区。
2. 编写一个存储过程,就myEMP表,输入参数为字段名和匹配值(字符型),对符合匹配条件的工资加100。
3. 编写一个存储过程,输入参数为一个表名,通过存储过程处理将该表删除DROP,并返回是否成功的信息。
实验十一
1. 以雇员作为对象类型,试根据myEMP表结构设计其属性,方法主要有雇员更换部门、更换工种、MAP排序的定义。
2. 编制一个雇员类型的对象表myOBJ_EMP。
3. 添加对象表myOBJ_EMP的数据10条。
4. 试对对象表排序输出。
5. 给对象表中部门号为20的记录的工资增加10%。
6. 显示每个雇员所在的雇员名、部门名称。
实验一
练习1、请查询表DEPT中所有部门的情况。
select * from dept;
练习2、查询表DEPT中的部门号、部门名称两个字段的所有信息。
select deptno,dname from dept;
练习3、请从表EMP中查询10号部门工作的雇员姓名和工资。
select ename,sal from emp where deptno=10;
练习4、请从表EMP中查找工种是职员CLERK或经理MANAGER的雇员姓名、工资。
select ename,sal from emp where job='CLERK' or job='MANAGER';
练习5、请在EMP表中查找部门号在10-30之间的雇员的姓名、部门号、工资、工作。
select ename,deptno,sal,job from emp where deptno between 10 and 30;
练习6、请从表EMP中查找姓名以J开头所有雇员的姓名、工资、职位。
select ename,sal,job from emp where ename like 'J%';
练习7、请从表EMP中查找工资低于2000的雇员的姓名、工作、工资,并按工资降序排列。
select ename,job,sal from emp where sal<=2000 order by sal desc;
练习8、请从表中查询工作是CLERK的所有人的姓名、工资、部门号、部门名称以及部门地址的信息。
select ename,sal,emp.deptno,dname,loc from emp,dept where emp.deptno=dept.deptno and job='CLERK';
练习9、查询表EMP中所有的工资大于等于2000的雇员姓名和他的经理的名字。
select a.ename,b.ename from emp a,emp b where a.mgr=b.empno(+) and a.sal>=2000;
练习10、在表EMP中查询所有工资高于JONES的所有雇员姓名、工作和工资。
select ename,job,sal from emp where sal>(select sal from emp where ename=’JONES’);
练习11、列出没有对应部门表信息的所有雇员的姓名、工作以及部门号。
select ename,job,deptno from emp where deptno not in (select deptno from dept);
练习12、查找工资在1000~3000之间的雇员所在部门的所有人员信息
select * from emp where deptno in (select distinct deptno from emp where sal between 1000 and 3000);
练习13、雇员中谁的工资最高。
select ename from emp where sal=(select max(sal) from emp);
select ename from (select * from emp order by sal desc) where rownum<=1;
*练习14、雇员中谁的工资第二高(考虑并列第一的情况,如何处理)。
select ename from (select ename ,sal from (select * from emp order by sal desc) where rownum<=2 order by sal) where rownum<=1;
实验二
1. 查询所有雇员的姓名、SAL与COMM之和。
select ename,sal+nvl(comm,0) “sal-and-comm” from emp;
2. 查询所有81年7月1日以前来的员工姓名、工资、所属部门的名字
select ename,sal,dname from emp,dept where emp.deptno=dept.deptno and hiredate<=to_date('1981-07-01','yyyy-mm-dd');
3. 查询各部门中81年1月1日以后来的员工数
select deptno,count(*) from emp where hiredate>=to_date('1981-01-01','yyyy-mm-dd') group by deptno;
4. 查询所有在CHICAGO工作的经理MANAGER和销售员SALESMAN的姓名、工资
select ename,sal from emp where (job='MANAGER' or job='SALES') and deptno in (select deptno from dept where loc='CHICAGO');
5. 查询列出来公司就职时间超过24年的员工名单
select ename from emp where hiredate<=add_months(sysdate,-288);
6. 查询于81年来公司所有员工的总收入(SAL和COMM)
select sum(sal+nvl(comm,0)) from emp where to_char(hiredate,'yyyy')='1981';
7. 查询显示每个雇员加入公司的准确时间,按××××年××月××日 时分秒显示。
select ename,to_char(hiredate,'yyyy-mm-dd hh24:mi:ss') from emp;
8. 查询公司中按年份月份统计各地的录用职工数量
select to_char(hiredate,'yyyy-mm'),loc,count(*) from emp,dept
where emp.deptno=dept.deptno group by to_char(hiredate,'yyyy-mm'),loc;
9. 查询列出各部门的部门名和部门经理名字
select dname,ename from emp,dept where emp.deptno=dept.deptno and job='MANAGER';
10. 查询部门平均工资最高的部门名称和最低的部门名称
select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) ) where rownum<=1)
union all select dname from dept where deptno=(select deptno from (select deptno from emp group by deptno order by avg(sal) desc ) where rownum<=1);
11. *查询与雇员号为7521员工的最接近的在其后进入公司的员工姓名及其所在部门名
select ename,dname
from (select ename,deptno from
(select ename,deptno from emp where hiredate>(select hiredate from emp where empno=7521) order by hiredate ) where rownum<=1) e,dept
where e.deptno=dept.deptno
实验三、
1. 建立一个表(表名自定),表结构与EMP相同,没有任何记录。
create table my_emp as select * from emp;
Delete From my_emp;--WintyAdd
2. 用INSERT语句输入5条记录,并提交。
insert into my_emp values(200,'Winty','CLERK',300,to_date('8-25-2006','mm-dd-yyyy'),1500,500,40);--WintyAdd
Commit;
3. 扩大该表的记录数到约40条,并使雇员号不重复;每个雇员都有所属部门,雇员在同一部门的经理是同一人。
insert ….
update …
commit
4. 建立一个与DEPT表结构和记录完全相同的新表,并与前项新表建立参照完整性约束。
create table my_dept as select * from dept;--WintyAdd
alter table my_dept add( constraint s1 primary key(deptno));--*
alter table my_emp add(constraint s2 foreign key(deptno) references dept(deptno));
5. 对在'NEW YORK'工作的雇员加工资,每人加200。
update my_emp set sal=sal+200 where my_emp.deptno in
(select deptno from my_dept where my_dept.loc='NEW YORK');--WintyAdd
6. *如果雇员姓名与部门名称中有一个或一个以上相同的字母,则该雇员的COMM增加500。
translate(c1,c2,c3)将c1中与c2相同的字符以c3代替;
chr(27)为ESC
update my_emp a
set comm=NVL(comm,0)+500
where a.ename<>(
select translate(a.ename,b.dname,CHR(27))
from my_dept b where b.deptno=a.deptno
);
--a.deptno与b.deptno必须有主外键连接,否则可能出错,为什么?
否则会有错误:单行子查询返回多个行--WintyAdd
commit;
7. 删除部门号为30的记录,并删除该部门的所有成员。
delete from emp where deptno=30;
delete from dept where deptno=30;
commit
8. 新增列性别SEX,字符型。
alter table emp add(sex char(2));
9. 修改新雇员表中的MGR列,为字符型。
该列数据必须为空
alter table emp modify(mgr varchar2(20));
10. 试着去删除新表中的一个列。
alter table my_emp drop (comm);
实验四、
1. 查询部门号为30的所有人员的管理层次图。
select level,ename from emp
start with deptno=30 and job='MANAGER'
connect by mgr=prior empno;
2. 查询员工SMITH的各个层次领导。
select level,ename from emp
start with ENAME='SMITH'
connect by prior mgr= empno;
3. 查询显示EMP表各雇员的工作类型,并翻译为中文显示
用decode函数
select ename,decode(job,'CLERK','雇员','MANAGER','经理','Default') a from emp;--WintyAdd
4. *查询显示雇员进入公司当年是什么属相年(不考虑农历的年份算法)
用decode函数
select decode(mod(to_number(to_char(hiredate,'mmddyy')),12),0,'猴',1,'鸡',2,'狗','None') from e;--WintyAdd
5. 建立一个视图myV_emp,视图包括myEMP表的empno、ename、sal,并按sal从大到小排列。
create view myV_EMP as select empno,ename,sal from emp;
6. 定义一个mySeq,对select mySeq.nextval,my_emp.* from my_emp的执行结果进行说明。
create sequence mySeq
increment by 10
start with 100
nocache
nocycle;
select mySeq.nextval,my_emp.* from my_emp;
--WintyAdd
7. 定义序列mySeq、myEMP、myV_emp的同义词,能否用同义词对上述对象进行访问。
create synonym syn_myEMP for my_EMP;--WintyAdd
8. 在myEMP表中建立ename的唯一性索引。
alter table my_emp add(constraint sfds unique(ename));--WintyAdd
9. 如何在sql*plus中,运行sql的脚本(即后缀为.sql的文件)
@C:"sql1.sql--WintyAdd
start C:"sql1.sql--WintyAdd
实验五、
1. 观察下列PL/SQL的执行结果
declare
s emp%rowtype;
begin
select * into s
from emp where ename='KING';
DBMS_OUTPUT.PUT_LINE(s.empno||s.ename||s.job||s.sal);
END;
2. 编写一个PL/SQL,显示ASC码值从32至120的字符。
begin
for i in 32..120
loop
dbms_output.put_line(chr(i));
end loop;
end;
i未定义并不提示出错--WintyAdd
3. 计算myEMP表中COMM最高与最低的差值,COMM值为空时按0计算。
declare
var1 number;
var2 number;
val_comm number;
begin
select max(nvl(comm,0)) into var1 from myemp;
select min(nvl(comm,0)) into var2 from myemp;
val_comm:=var1-var2;
dbms_output.put_line(val_comm);
end;
4. 根据表myEMP中deptno字段的值,为姓名为'JONES'的雇员修改工资;若部门号为10,则工资加100;部门号为20,加200;其他部门加400。
declare
c1 number;
c2 number;
begin
select deptno into c1 from emp where ename='JONES';
if c1=10 then
c2:=100;
elsif c1=20 then
c2:=200;
else c2:=400;
end if;
update emp set sal=sal+c2 where ename='JONES';
commit;
end;
5. 计算显示部门人数最多的部门号、人数、工资总和,以及部门人数最少的部门号、人数、工资总和。
--WintyAdd
最多时:
select deptno,PersonNum,TotalSal from
(select deptno,count(*) PersonNum,sum(nvl(sal,0)+nvl(comm,0)) TotalSal
from emp group by deptno order by PersonNum desc)
where rownum< =1;
最少时:
Asc
6. 计算myEMP中所有雇员的所得税总和。假设所得税为累进税率,所得税算法为:工资收入为0-1000为免税;收入1000-2000者,超过1000的部分税率10%;2000-3000者超过2000部分按20%税率计算;3000-4000者超过3000部分按30%税率计算;4000以上收入,超过4000部分按40%税率计算。(请查阅累进税率的概念)
declare
sum_xx number:=0;
xx number :=0;
begin
--计算收入为1000-2000的所得税总额
select sum((sal-1000)*0.1) into xx from emp where sal >1000 and sal<=2000;
sum_xx:=sum_xx+xx;
--计算收入为2000-3000的所得税总额
select sum((sal-2000)*0.2+100) into xx from emp where sal >2000 and sal<=3000;
sum_xx:=sum_xx+xx;
--计算收入为3000-4000的所得税总额
select sum((sal-3000)*0.3+300) into xx from emp where sal >3000 and sal<=4000;
sum_xx:=sum_xx+xx;
--计算收入为4000以上的所得税总额
select sum((sal-4000)*0.4+600) into xx from emp where sal >4000;
sum_xx:=sum_xx+xx;
dbms_output.put_line(sum_xx);
end;
7. *(可选做,难题)假设有个表如myEMP,未建立主键,含有多条记录重复(列值完全相同),试编制一个PL/SQL,将多余的重复记录删除。
实验六、
1. 用外部变量,实现两个PL/SQL程序间的数据交换。
SQL> variable a1 number;
SQL> begin
2 :a1:=1000;
3 end;
4 /
PL/SQL 过程已成功完成。
SQL> begin
2 dbms_output.put_line(:a1);
3 end;
4 /
1000
PL/SQL 过程已成功完成。
2. 插入myEMP表中的数据记录,考虑可能出现的例外,并提示。
主要的例外提示:唯一性索引值重复DUP_VAL_ON_INDEX
begin
insert into myEMP values(7369,'winty','CLERK',7902,to_date('17-12-80','dd-mm-yy'),800,NULL,20);
exception
when DUP_VAL_ON_INDEX then
dbms_output.put_line('记录重复');
when others then
null;
end;
3. 删除myDEPT表中的数据记录一条,考虑例外情况,并提示。
主要的例外提示:违反完整约束条件
4. 将下列PL/SQL改为FOR游标
declare
cursor cur_myemp is select * from emp;
r emp%rowtype;
begin
open cur_myemp;
fetch cur_myemp into r;
while cur_myemp%found
loop
dbms_output.put_line(r.ename);
fetch cur_myemp into r;
end loop;
close cur_myemp;
end;
用For 实现.
Declare
Cursor cur_myemp Is Select * From emp;
Begin
For cur_myemp_cur In cur_myemp Loop
dbms_output.put_line(cur_myemp_cur.ename);
End Loop;
End;
/
5. 工资级别的表salgrade,列出各工资级别的人数。(用游标来完成)
declare
v1 number;
cursor cur1 is select * from salgrade;
begin
for c1 in cur1
loop
select count(*) into v1 from emp where sal between c1.losal and c1.hisal;
dbms_output.put_line('grade'||c1.grade||' '||v1);
end loop;
end;
实验七、
1. 在myEMP表中增加一个字段,字段名为EMPPASS,类型为可变长字符。
alter table myemp add(emppass varchar2(50));
2. 建立一个存储过程,用于操作用户登录的校验,登录需要使用EMPNO和EMPPASS,并需要提示登录中的错误,如是EMPNO不存在,还是EMPNO存在而是EMPPASS错误等。
create or replace procedure p_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
x1 emp.ename%type;
x2 number;
begin
select ename into x1 from emp where empno=in_empno;
select count(*) into x2 from emp where empno=in_empno and emppass=in_emppass;
if x2=1 then
out_code:=0;
out_desc:=x1;
else
out_code:=2;
out_desc:='用户登陆密码错误!';
end if;
exception
when NO_DATA_FOUND then
out_code:=1;
out_desc:='该用户号存在!';
when TOO_MANY_ROWS then
out_code:=3;
out_desc:='该用户号有重复值!';
when others then
out_code:=100;
out_desc:='其他错误!';
end;
3. 建立一个存储过程,实现myEMP表中指定雇员的EMPPASS字段的修改,修改前必须进行EMPPASS旧值的核对。
create or replace procedure p_changepass(
in_empno in emp.empno%type,
in_oldpass in emp.emppass%type,
in_newpass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
x1 number;
begin
select count(*) into x1 from emp where empno=in_empno and emppass=in_oldpass;
if x1=1 then
update emp set emppass=in_newpass where empno=in_empno;
commit;
out_code:=0;
out_desc:='修改口令成功';
else
out_code:=1;
out_desc:='修改口令不成功';
end if;
exception
when others then
out_code:=100;
out_desc:='其他错误';
end;
//Now Here:winty
4. 建立一个函数,输入一个雇员号,返回该雇员的所在同一部门的最高级别上司姓名。
create or replace function f_leader(
in_empno in emp.empno%type) return varchar2
is
v1 number;
v2 number;
v3 emp.ename%type;
v4 emp.deptno%type;
begin
v1:=in_empno;
v3:='未找到';
select deptno into v4 from emp where empno=v1;
loop
select mgr into v2 from emp where empno=v1;
select ename into v3 from emp where empno=v2 and deptno=v4;
v1:=v2;
end loop;
exception
when others then
return v3;
end;
5. 试用上题函数,实现各雇员的同一部门最高级别上司的SELECT查询。
select f_leader(7521) from dual;
6. *编写实验五中第六题,关于各雇员工资的所得税计算函数
实验八、
1. 建立一个触发器,当myEMP表中部门号存在时,该部门不允许删除。
create or replace trigger dept_line_delete
before delete on dept for each row
declare
v1 number;
begin
select count(*) into v1 from emp where deptno=:old.deptno;
if v1>=1 then RAISE_APPLICATION_ERROR(-20000,'错误');
end if;
end;
实验九、
1. 建立一个示例包emp_mgmt中,新增一个修改雇员所在部门的过程。
create or replace package emp_mgmt as
procedure change_dept(
in_newdept in emp.deptno%type,
out_code out number,
out_desc out varchar2);
mgmt_empno emp.empno%type;
procedure mgmt_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2);
end;
create or replace package body emp_mgmt as
procedure change_dept(
in_newdept in emp.deptno%type,
out_code out number,
out_desc out varchar2)
is
begin
update emp set deptno=in_newdept where empno=mgmt_empno;
commit;
out_code:=0;
out_desc:='ok';
end;
procedure mgmt_login(
in_empno in emp.empno%type,
in_emppass in emp.emppass%type,
out_code out number,
out_desc out varchar2)
is
begin
--登陆过程见实验七第2题
mgmt_empno:=in_empno;
out_code:=0;
out_desc:='ok';
end;
end;
2. 假设myEMP表中有口令字段password,试在包emp_mgmt中建立一个登录的过程,并将登录成功的雇员号存入包变量。
见前一题
3. 示例包emp_mgmt中,将remove_emp操作设限,只有本部门经理操作才能删除本部门雇员记录,只有公司头头PRESIDENT才能删除部门经理的雇员记录。
--
procedure remove_emp(
remove_empno emp.empno%type,
out_code number,
out_desc varchar2)
is
x emp.job%type;
y number;
begin
select job,deptno into x,y from emp where empno=mgmt_empno;
if x='PRESIDENT' then
delete from emp where empno=remove_empno and job='MANAGER';
else
delete from emp where empno=remove_empno and deptno=y and x='MANAGER';
end if
if sql%found then
out_code:=0;
out_desc:='ok';
else
out_code:=1;
out_desc:='未删除记录';
end if;
commit;
end;
4. *用DELPHI+ORACLE实现上题的软件功能。
实验十
1. 编写一段PL/SQL,利用系统工具包,实现对SERVER端数据文件D:"DATA"A.TXT的读取输出至缓冲区。
2. 编写一个存储过程,就myEMP表,输入参数为字段名和匹配值(字符型),对符合匹配条件的工资加100。
3. 编写一个存储过程,输入参数为一个表名,通过存储过程处理将该表删除DROP,并返回是否成功的信息。
实验十一
1. 以雇员作为对象类型,试根据myEMP表结构设计其属性,方法主要有雇员更换部门、更换工种、MAP排序的定义。
2. 编制一个雇员类型的对象表myOBJ_EMP。
3. 添加对象表myOBJ_EMP的数据10条。
4. 试对对象表排序输出。
5. 给对象表中部门号为20的记录的工资增加10%。
6. 显示每个雇员所在的雇员名、部门名称。
发表评论
-
[原]简易Windows密码查看器
2009-10-10 00:08 1764[标题]:简易Windows密码查看器 [时间]:2009- ... -
[原]手机姓名秀 - NameShow
2010-01-30 21:48 1083手机姓名秀 - NameShow 在手机上展示你的姓 ... -
我的Stylish CSS
2010-03-23 14:10 1212■去除126邮箱广告的Stylish CSS: @-moz- ... -
Greasemonkey猴子脚本
2010-03-23 14:18 1042// ==UserScript== // @name ... -
[原]开发自己的Windows Live Writer插件
2009-10-05 19:26 1908[标题]: 开发自己的Windows Live Writer插 ... -
[原]将Puppy Linux安装到U盘
2009-09-21 00:12 5712[标题]:将Puppy Linux安装到U盘 [时间]:2 ... -
[原]在全局鼠标钩子中模拟鼠标右键单击
2009-03-28 15:55 4290[标题]:在全局鼠标钩子中模拟鼠标右键单击 [时间]:2009 ... -
[原]使用"异或"简单加密的实现
2009-04-19 19:30 2087[标题]:使用"异或"简单加密的实现 [时 ... -
[转]在Word中让目录不显示页码
2009-05-07 23:26 1796[问题]: 文章由目录和正文两部分组成,我想让目录部分不显示页 ...
相关推荐
《oracle数据库应用与开发 石彦芳 李丹》实验6.5,原创练习-------------------------------------------------------------------------------------------------不喜勿下
- **OCM (Oracle Certified Master)**: 最高级别的Oracle认证,要求持有者不仅具备深厚的技术知识,还需要通过严格的实验室考试,展示其解决复杂问题的能力。 #### 二、Oracle培训及课程安排 - **培训机构**: ...
oracle原厂培训时作的备份恢复实验,oracle原厂培训时作的备份恢复实验,oracle原厂培训时作的备份恢复实验.
最全、最详细的Oracle10实验指导书。每一部分实验都包括实验内容的讲解和实验联系题。 实践1 Oracle10g的安装及常用工具的使用 3 实践2 Oracle数据库基本命令 23 实践3 数据库的操作 44 实践4 数据库的安全管理 50 ...
本实验旨在让学生掌握Oracle数据库的备份与恢复技术,这对于数据库管理至关重要,尤其是在应对意外数据丢失或系统故障时。 实验内容主要分为两个部分:逻辑备份与恢复以及物理备份与恢复。 逻辑备份与恢复是通过...
- 在图形界面下通过DBCA安装Oracle 9.2.0.8介质,保持与原Oracle安装路径一致(/home/db/oracle)。 - 安装后,通过SQL*Plus检查能否正常启动Oracle数据库。 3. **升级数据库字典与编译程序**: - 运行`catpatch....
本实验主要涉及Oracle数据库中SQL(Structured Query Language)的使用,旨在帮助用户熟悉并掌握SQL的基本查询技巧。 实验内容涵盖以下几个方面: 1. **查询语句**: - `SELECT * FROM emp`:查询emp表中的所有...
而如果是进行技术创新或实验性质的工作,非LTS版本可能更适合,因为它包含了更多前沿的特性和改进。 对于Java开发者来说,持续关注Oracle Technology Network上的更新非常重要,因为这不仅可以确保使用的是最新、最...
- **获取路径**:先通过OCP考试,再学习两门高级技术课程并通过预考,在Oracle实验室环境中成功通过实习考试。 - **实习考试目的**:培养动手能力,学员必须完成真实的职业任务。 #### Oracle认证政策变动 - **...
- **实验环境**:Windows 2000 Server + SP4 + Oracle 9.2.0.1 for Windows - **预备步骤**: 1. **复制与修改参数文件**:首先,需从源数据库的文件目录中复制初始参数文件`init<sid>.ora`至目标目录,并修改实例...
这份“WebLogic原厂培训教材实验”PDF,显然是Oracle官方提供的培训资料,旨在帮助用户深入理解和掌握WebLogic Server的各类功能和最佳实践。 一、WebLogic基础 WebLogic Server作为Java EE(现在称为Jakarta EE)...
ORACLE database 10g: administration workshop i and ii (英文3.1原版)目前是最新的版本 包含了实验部分和附录部分 完全版本 与2008版的书籍完全一致 看时请打开查看备注页面 包含内容:D17090GC31 D17092GC31
### Factor Oracle:弱因子识别与在线字符串匹配的高效实验算法 #### 引言与背景 在计算机科学领域,特别是信息检索、数据压缩以及生物信息学等应用中,字符串匹配问题是一个核心研究课题。其基本任务是在一个较大...
这个资料包涵盖了原版书籍、实验手册和补充材料,确保您对19c的新特性和最佳实践有深入的理解。 首先,"Oracle Database 12c OCM Exam Preparation Workshop Ed 1 (Student Guide - Volumes 1-5)" 是一系列的学习...
- 更多编辑命令,如`l`列出当前脚本,`del n`删除第n行,`c\原内容\新内容`替换内容,`a`追加内容,`i`在行后插入内容。 4. **文件操作**: - `save [file] filename [create|replace|append]`:保存当前会话到...
在本实验指南中,我们将详细探讨如何在Vmware Sphere ESXI 5.0环境下使用虚拟文件共享安装RHEL 5_x64操作系统,并在此基础上构建Oracle 11gR2_x64 RAC集群。Oracle Real Application Clusters (RAC)是一种高可用性和...
WebLogic Server是由Oracle公司(原BEA Systems)开发的一款高性能、高可用性且可扩展的企业级应用服务器,主要应用于Java EE应用程序的部署和运行环境。它提供了全面的中间件功能,包括但不限于集群、负载均衡、...