ORACLE的基础SQL(三)

—视图
—视图的概念:视图就是提供一个查询的窗口,所有数据来自于原表。

—查询语句创建表
create table emp as select * from scott.emp;
select * from emp;
—创建视图【必须有dba权限】
create view v_emp as select ename, job from emp;
—查询视图
select * from v_emp;
—修改视图[不推荐]
update v_emp set job=’CLERK’ where ename=’ALLEN’;
commit;
—创建只读视图
create view v_emp1 as select ename, job from emp with read only;
—视图的作用?
—第一:视图可以屏蔽掉一些敏感字段。
—第二:保证总部和分部数据及时统一。

—索引
–索引的概念:索引就是在表的列上构建一个二叉树
—-达到大幅度提高查询效率的目的,但是索引会影响增删改的效率。
—单列索引
—创建单列索引
create index idx_ename on emp(ename);
—单列索引触发规则,条件必须是索引列中的原始值。
—单行函数,模糊查询,都会影响索引的触发。
select * from emp where ename=’SCOTT’
—复合索引
—创建复合索引
create index idx_enamejob on emp(ename, job);
—复合索引中第一列为优先检索列
—如果要触发复合索引,必须包含有优先检索列中的原始值。
select * from emp where ename=’SCOTT’ and job =’xx’;—触发复合索引
select * from emp where ename=’SCOTT’ or job =’xx’;—不触发索引
select * from emp where ename=’SCOTT’;—触发单列索引。

—pl/sql编程语言
—pl/sql编程语言是对sql语言的扩展,使得sql语言具有过程化编程的特性。
—pl/sql编程语言比一般的过程化编程语言,更加灵活高效。
—pl/sql编程语言主要用来编写存储过程和存储函数等。

—声明方法
—赋值操作可以使用:=也可以使用into查询语句赋值
declare
i number(2) := 10;
s varchar2(10) := ‘小明’;
ena emp.ename%type;—引用型变量
emprow emp%rowtype;—记录型变量
begin
dbms_output.put_line(i);
dbms_output.put_line(s);
select ename into ena from emp where empno = 7788;
dbms_output.put_line(ena);
select * into emprow from emp where empno = 7788;
dbms_output.put_line(emprow.ename || ‘的工作为:’ || emprow.job);
end;

—pl/sql中的if判断
—输入小于18的数字,输出未成年
—输入大于18小于40的数字,输出中年人
—输入大于40的数字,输出老年人
declare
i number(3) := ⅈ
begin
if i<18 then
dbms_output.put_line(‘未成年’);
elsif i<40 then
dbms_output.put_line(‘中年人’);
else
dbms_output.put_line(‘老年人’);
end if;
end;

—pl/sql中的loop循环
—用三种方式输出1到10是个数字
—while循环
declare
i number(2) := 1;
begin
while i<11 loop
dbms_output.put_line(i);
i := i+1;
end loop;
end;
—exit循环
declare
i number(2) := 1;
begin
loop
exit when i>10;
dbms_output.put_line(i);
i := i+1;
end loop;
end;
—for循环
declare

begin
for i in 1..10 loop
dbms_output.put_line(i);
end loop;
end;

—游标:可以存放多个对象,多行记录。
—输出emp表中所有员工的姓名
declare
cursor c1 is select * from emp;
emprow emp%rowtype;
begin
open c1;
loop
fetch c1 into emprow;
exit when c1%notfound;
dbms_output.put_line(emprow.ename);
end loop;
close c1;
end;

—–给指定部门员工涨工资
declare
cursor c2(eno emp.deptno%type)
is select empno from emp where deptno = eno;
en emp.empno%type;
begin
open c2(10);
loop
fetch c2 into en;
exit when c2%notfound;
update emp set sal=sal+100 where empno=en;
commit;
end loop;
close c2;
end;
—-查询10号部门员工信息
select * from emp where deptno = 10;

猜你喜欢

转载自blog.csdn.net/jimbo_chou/article/details/82557356