oracle视图索引
reate table fleet_header(
day date,name varchar2(20),
route_id number(5),fleet_id number(5)
);
create view fleet (day,route_id)
as select day, route_id from fleet_header;
insert into fleet values('10-10月-05',9);
--修改视图定义
create or replace view fleet as select * from fleet_header;
--删除视图
drop view fleet;
--如何在fleet_header表的name 列上创建名为aud_index的索引
create index aud_index on fleet_header(name);
--创建唯一索引
--如何在fleet_header表的route_id 列上创建名为aud_index的索引
create unique index place_ind on fleet_header(route_id)
--创建组合索引
create index comp_index on fleet_header(route_id,fleet_id)
--创建反向键索引
--fleet_header表的route_id列值是一个顺序增长的序号,
--需要在此列上创建索引以提高查询速度
create index rev_ind on fleet_header(route_no) reverse;
--创建位图索引
create bitmap index bit_ind on fleet_header(cat._code);
--创建位图索引
create index ucase_name_ind on fleet_header (upper(name));
--输入以下语句使用该索引
select * from fleet_header where upper(name)='smith';
--删除索引
drop index emp_ind1;
----------------------------------------
--使用条件控制
----------------------------------------
create table salary_records
(
deptcode varchar2(15),
empcode varchar2(10),
empsal number
)
insert into salary_records
values('DP04','A4',0)
declare
dptcode varchar2(15);
emp_code varchar2(10);
salary number;
begin
select deptcode,empcode,empsal into dptcode,emp_code,salary
from salary_records where empcode='&empid'
for update of empsal;
IF dptcode ='DP01' then
update salary_records set empsal=salary+2000
where empcode=emp_code;
elsif dptcode ='DP01' then
update salary_records set empsal=salary+1700
where empcode=emp_code;
elsif dptcode='DP03' then
update salary_records set empsal=salary+2000
where empcode=emp_code;
end if;
commit;
end;
-----------------------------------------------
--使用循环控制
---------------------------------------------
declare
courserec SALARY%rowtype;
counter number:=0;
begin
courserec.empsal:=&id;
courserec.empcode:='&name';
while counter <12
loop
insert into SALARY
values(courserec.empsal,courserec.empcode);
counter:=counter+1;
courserec.empsal:=courserec.empsal+1;
end loop;
end;
-----------------------------------------------
使用顺序控制
-------------------------------------------
alter table salary_records add (working_days number);
select * from salary_records
declare
workdays number;
salary number;
bonus number;
dept varchar2(10);
begin
select working_days,empsal,deptcode into workdays,
salary,dept from salary_records where empcode='&empid';
IF workdays>=29 then
goto calc_raise;
else
DBMS_OUTPUT.PUT_LINE('工作天数少于29天');
end if;
<<calc_raise>>
if dept='DP01' then
bonus :=salary*0.25;
dbms_output.put_line(bonus);
else
bonus :=salary*0.10;
dbms_output.put_line(bonus);
end if;
end;
set serveroutput on
/
oracle视图索引的更多相关文章
- oracle 序列 视图 索引 同义词
序列 Oracle 12C 之后,Oracle 之中提供的是一种手工的自动增长列控制,而这样的控制在 Oracle 之中使用序列(对象)完成. 序列的创建: CREATE SEQUENCE 序列名称 ...
- Oracle学习2 视图 索引 sql编程 游标 存储过程 存储函数 触发器
---视图 ---视图的概念:视图就是提供一个查询的窗口,来操作数据库中的数据,不存储数据,数据在表中. ---一个由查询语句定义的虚拟表. ---查询语句创建表 create table emp a ...
- Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系
版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...
- Oracle视图分类及各种操作讲解(超级好文)
目录:一.视图的定义: 二.视图的作用: 三.创建视图: 1.权限 2.语法 3.1 创建简单视图 3.2 创建连接视图 3.2.1 连接视图定义 3.2.2 创建连接视图 3.2.3 ...
- oracle视图总结
视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...
- oracle视图总结(转)
视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...
- oracle 创建索引思考(转)
在Oracle数据库中,创建索引虽然比较简单.但是要合理的创建索引则比较困难了. 笔者认为,在创建索引时要做到三个适当,即在适当的表上.适当的列上创建适当数量的索引.虽然这可以通过一句话来概括优化的索 ...
- Oracle 视图 (待更新, 缓存)
参考: 视图.索引.存储过程优缺点: http://www.cnblogs.com/SanMaoSpace/p/3147059.html oracle视图总结(转):http://tianwei013 ...
- oracle唯一索引与普通索引的区别和联系以及using index用法
oracle唯一索引与普通索引的区别和联系 区别:唯一索引unique index和一般索引normal index最大的差异是在索引列上增加一层唯一约束.添加唯一索引的数据列可以为空,但是只要尊在数 ...
随机推荐
- PostgreSQL中,如何查表属于哪个数据库
db1=# \x Expanded display is on. db1=# SELECT * FROM information_schema.tables WHERE table_name='tab ...
- [小技巧]設定Reporting Services 2008 發生報表管理員權限不足
转载 http://www.dotblogs.com.tw/dorlis.tsao/archive/2011/01/17/20860.aspx 在自己Windows 7 professional的電腦 ...
- centosx64位寄存器
[root@monitor ~]# uname -aLinux monitor 2.6.32-431.23.3.el6.x86_64 #1 SMP Thu Jul 31 17:20:51 UTC 20 ...
- c#线程问题(1)
delegate : public delegate void ParameterizedThreadStart(Object obj) public delegate void ThreadStar ...
- 1081. Rational Sum (20)
the problem is from PAT,which website is http://pat.zju.edu.cn/contests/pat-a-practise/1081 the code ...
- HDU 4279 - Number
2012年天津赛区网赛的题目,想了好久,也没能想出来 还是小杰思路敏捷,给我讲解了一番,才让我把这个题做出来 f(x)=x-phi(x)(1——x与x互素个数)-g(x)(x的因子个数)+1 其中g( ...
- Helpers\Number
Helpers\Number This helper has 2 methods for converting a number format and to get a percentage. Num ...
- Linux 引导过程内幕
转载:http://www.ibm.com/developerworks/cn/linux/l-linuxboot/index.html 从主引导记录到第一个用户空间应用程序的指导 引导 Linu ...
- PHP.1-网站开发概述
网站开发概述 网站开发从本质来说,就是软件开发 1.B/S软件体系统结构 BS:浏览器与服务器的结构[降低客户端电脑的负荷,减轻维护成本,对CS的改进,可随时随地进行业务处理] #对美工要求比较高,注 ...
- 快递鸟电子面单API对接方法?
之前说了一下快递公司.菜鸟和快递鸟的电子面单接口,很多人不知道快递鸟要怎么对接,现在为大家讲解一下.快递鸟是全球物流接口服务商,为电商 ERP.电商平台.仓储.清关公司提供物流跟踪.电子面单.智选物流 ...