01.oracle体系结构

02.oracle的基本操作

03.oracle的查询

04.oracle对象&&05.oracle编程(a)

05.oracle编程(b)

04.oracle对象&&05.oracle编程(a)


01视图

---视图
---视图的概念:视图就是提供一个查询的窗口,所有数据来自于原表。 ---查询语句创建表
create table emp as select * from scott.emp;
select * from emp; ---创建视图【必须有dba权限】
create view v_emp as select ename, job from emp;
---创建只读视图
create view v_emp1 as select ename, job from emp with read only;
---查询视图
select * from v_emp1; ---视图的作用?
---第一:视图可以屏蔽掉一些敏感字段。
---第二:保证总部和分部数据及时统一。

02索引

---索引
--索引的概念:索引就是在表的列上构建一个二叉树
----达到大幅度提高查询效率的目的,但是索引会影响增删改的效率。
---单列索引
---创建单列索引
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';---触发单列索引。

03plsql编程语言定义变量

---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用 || 连接字符串varchar2类型

04plsql中的if判断

---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;

05plsql中的循环

---打印输出语法
dbms_output.put_line(i);

---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;

pl/sql的for循环和MATLAB的for语法规则类似,都是默认递增整数1。

---exit循环
declare
i number(2) := 1;
begin
loop
exit when i>10;
dbms_output.put_line(i);
i := i+1;
end loop;
end;
---exit循环是使用的重点内容

06plsql中的游标

---游标:可以存放多个对象,多行记录。
---输出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;

==================

end

最新文章

  1. jvm内存默认大小,及如何调整大小
  2. Eclipse的快捷键
  3. linux SecureCRT ssh key认证登陆
  4. [安卓]windows下如何安装Android源码
  5. C++模板(基础)
  6. python 的 class
  7. Top Things to Consider When Troubleshooting Complex Application Issues
  8. 转载字典地址:http://blog.csdn.net/aladdinty/article/details/3591789
  9. [AngualrJS] ng-strict-di
  10. c++ primer (5)2
  11. css3绘制中国结
  12. java 简单分页/总结
  13. MSSQL 镜像
  14. 一个有用的shell脚本
  15. Day-8: 面对对象编程
  16. 强化学习(十三) 策略梯度(Policy Gradient)
  17. netcore服务程序暴力退出导致的业务数据不一致的一种解决方案(优雅退出)
  18. Intellij IDEA 中如何查看maven项目中所有jar包的依赖关系图(转载)
  19. VueJs(7)---计算属性和侦听器
  20. hdu 4277 USACO ORZ dfs+hash

热门文章

  1. 019-PHP创建目录函数
  2. 018-PHP判断文件是否存在
  3. JAVA - 创建SpringBoot项目
  4. 08 SSM整合案例(企业权限管理系统):11.AOP日志
  5. 第十七篇 ORM跨表查询和分组查询---二次剖析
  6. c++ auto_ptr笔记
  7. java web实现在线编辑word,并将word导出(三)
  8. HTML元素类型和类型的转换
  9. 吴裕雄--天生自然Django框架开发笔记:Django 创建第一个项目
  10. 了解redis