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视图索引的更多相关文章

  1. oracle 序列 视图 索引 同义词

    序列 Oracle 12C 之后,Oracle 之中提供的是一种手工的自动增长列控制,而这样的控制在 Oracle 之中使用序列(对象)完成. 序列的创建: CREATE SEQUENCE 序列名称 ...

  2. Oracle学习2 视图 索引 sql编程 游标 存储过程 存储函数 触发器

    ---视图 ---视图的概念:视图就是提供一个查询的窗口,来操作数据库中的数据,不存储数据,数据在表中. ---一个由查询语句定义的虚拟表. ---查询语句创建表 create table emp a ...

  3. Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  4. Oracle视图分类及各种操作讲解(超级好文)

    目录:一.视图的定义: 二.视图的作用: 三.创建视图: 1.权限 2.语法 3.1  创建简单视图   3.2  创建连接视图  3.2.1 连接视图定义  3.2.2 创建连接视图  3.2.3 ...

  5. oracle视图总结

    视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...

  6. oracle视图总结(转)

    视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...

  7. oracle 创建索引思考(转)

    在Oracle数据库中,创建索引虽然比较简单.但是要合理的创建索引则比较困难了. 笔者认为,在创建索引时要做到三个适当,即在适当的表上.适当的列上创建适当数量的索引.虽然这可以通过一句话来概括优化的索 ...

  8. Oracle 视图 (待更新, 缓存)

    参考: 视图.索引.存储过程优缺点: http://www.cnblogs.com/SanMaoSpace/p/3147059.html oracle视图总结(转):http://tianwei013 ...

  9. oracle唯一索引与普通索引的区别和联系以及using index用法

    oracle唯一索引与普通索引的区别和联系 区别:唯一索引unique index和一般索引normal index最大的差异是在索引列上增加一层唯一约束.添加唯一索引的数据列可以为空,但是只要尊在数 ...

随机推荐

  1. VMM服务模板(虚机、APP)部署排错

    I won't focus this blog on how to create a service template but more on how you can track the change ...

  2. Codeforces Round #331 (Div. 2) D. Wilbur and Trees 记忆化搜索

    D. Wilbur and Trees Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/596/p ...

  3. hdu 5565 Clarke and baton 二分

    Clarke and baton Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php? ...

  4. alternatives命令使用方法

    alternatives命令使用方法 alternatives是Linux下的一个功能强大的命令.仅仅能在root权限下运行.如系统中有几个命令功能十分相似,却又不能任意删除,那么能够用 altern ...

  5. makefile中的patsubst

    函数名称:加前缀函数—addprefix. 函数功能:为“NAMES…”中的每个文件名称加入前缀“PREFIX”.參数“NAMES…”是空格切割的文件名称序列,将“SUFFIX”加入到此序列的每个文件 ...

  6. TV

    https://github.com/Xs4allWebTV/androidhttps://github.com/mode89/video-feedhttp://www.javaapk.com/sou ...

  7. sync_binlog innodb_flush_log_at_trx_commit 浅析 传

    http://blog.itpub.net/22664653/viewspace-1063134/

  8. 关于MIUI悬浮窗权限问题的解决方案

    先扯会....好久没写Blog了....这段时间有点小忙...瞎忙.....忙的自己都感觉都不应该.....严重影响了生活质量......生活的幸福指数!!!.....到现在还特么的单身!!!求介绍啊 ...

  9. Android:Activity之间跳转和参数传递

    一个activity就好比一个网页,此文章讲解怎样创建一个activity并且实现跳转! 一.学习创建Activity 1.新建一个java类,右击src目录,选择new-->class,新的a ...

  10. couldn't set tty to ppp discipline invalid argument

    参考: http://pptpclient.sourceforge.net/howto-diagnosis.phtml#conventions http://blog.chinaunix.net/ui ...