• 黑马oracle_day02:04.oracle对象&05.oracle编程(上)


    01.oracle体系结构

    02.oracle的基本操作

    03.oracle的查询

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

    05.oracle编程(下)

    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编程语言主要用来编写存储过程

    ---声明方法
    ---赋值操作可以使用:=也可以使用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) := ⅈ  ---&i在PLSQL中表示键盘输入值
    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();

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

    部分内容来自于学习编程期间收集于网络的免费分享资源和工作后购买的付费内容。
  • 相关阅读:
    京东白条
    Linux命令(40)rm 命令
    Linux命令(39)rmdir 命令
    Linux命令(38)pstree命令
    Linux命令(37)type命令
    Linux命令(36)help命令
    Linux命令(35)du命令
    CentOS7修改主机名
    Linux命令(34)tac命令
    Linux命令(33)cat命令
  • 原文地址:https://www.cnblogs.com/MarlonKang/p/11533976.html
Copyright © 2020-2023  润新知