zoukankan      html  css  js  c++  java
  • Orecle基本概述(2)

    1.视图
    1.1 视图介绍
    *一种虚拟的表,不是真实存在的表,以多种方式展示数据给用户看,
    1.2 视图使用
    *创建视图语法一(非只读): create or replace view 视图名字 as sql查询语句
    *创建视图语法二(只读): create or replace view 视图名字 as sql查询语句 with read only;
    2.索引
    2.1 索引介绍
    *索引是用于提高查询数据性能的数据库对象
    2.2 索引查询数据库的方式
    *需要建立索引数据,数据库对数据建立B树数据结构,以后用户通过B树查找数据
    2.3 索引的数据结构Btree(B树)
    *B树: 即二叉树
    特点:
    *所有非叶子节点至多拥有两个儿子(左和右)
    *所有节点储存一个关键字;
    *大于关键字的指针指向左边,小于关键字的指向右边,如果左右为空则报告找不到相应的关键字
    2.4 索引类型和语法
    (1).单列索引:基于单个列所建立的索引
    语法: create index 索引名字 on 表名(列名字)
    (2).复合索引:基于两个列或者多个列的索引,在同一个表上可以有多个索引
    语法:create index 索引名字 on 表名(列名1,列名2)
    *索引的使用原则:在数据量大的表上建立索引才有意义,表中修改频率高时不建议使用索引
    3.pl/sql 基本语法
    *程序语法结构:
    declare
    声明部分 (用于定义变量,常量,引用变量,记录型变量,游标)
    begin
    逻辑处理
    end
    *变量:就是oracle中建表时字段的变量
    *常量:使用constant关键字声明的常量
    *引用型变量:
    语法:B列名 表名.A列名%type;
    即B列名的类型与某表中A列名的类型一样
    *记录型变量声明:v_row emp%rowtype;--用于接收emp一条记录到记录型变量v_row中,rowtype表示接收一条记录数据
    3.2 游标
    *介绍:是一个数据集,可以储存多条数据
    *声明游标的语法:
    cursor 游标名字 is sql查询语句;
    *使用游标语法:
    open 游标名称 ;
    loop ---通过遍历将游标里面的数据一条一条打印出来
    fetch 游标名称 into 记录型变量; ----获取游标里面一条数据
    exit when 游标名称%notfound; -----游标里面没有数据退出循环
    逻辑处理获取记录型变量里面的数据
    end loop
    close 游标名称; -----关闭游标

    3.3 if 分支
    *语法 1:
    IF 条件 THEN
    逻辑处理;
    END IF;

    *语法 2:
    IF 条件 THEN
    逻辑处理
    ELSE
    逻辑处理
    END IF;

    *语法 3:
    IF 条件 THEN
    逻辑处理
    ELSIF 条件 THEN
    逻辑处理
    ELSE
    逻辑处理
    END IF;
    3.4 loop 循环语句

    *语法 1:
    WHILE total <= 25000 LOOP
    ..
    total : = total + salary;
    END LOOP;

    *语法 2:
    Loop
    EXIT [when 条件];
    ……
    End loop

    *语法 3:
    FOR I IN 1 . . 3 LOOP
    语句序列 ;
    END LOOP ;

    4.储存过程
    *介绍: 就是给一堆pl/sql代码封装起来起一个名字,之后调用就是储存过程(类似于java中的方法)
    *好处:提高重用性
    *语法:
    create or replace procedure 储存过程的名字(变量名字N [in] / out 数据类型)
    is| as
    begin
    逻辑处理
    end;
    * in代表输入参数,传递数据给存储过程,存储过程里面使用,如果不写in或out,默认in输入参数
    * out代表输出参数,用于接收存储过程执行最后的结果,存储过程返回的值
    5.储存函数
    *单行函数或多行函数是数据库已有的,存储函数我们要自定义函数
    create or replace function 函数名字(变量名字N [in]/out 数据类型)
    return 数据类型
    is|as --用于声明,类似declare,is|as不能省略

    begin
    逻辑处理
    end
    6.触发器
    *介绍:当执行insert/update/delete等数据表改变的sql语句时就会自动触发触发器的执行

    *触发器作用:
    数据确认
    实施复杂的安全性检查
    做审计,跟踪表上所做的数据操作等
    数据的备份和同步

    *触发器的类型
    语句级触发器 :在指定的操作语句操作之前或之后执行一次,不管这条语句影响
    了多少行 。
    行级触发器(FOR EACH ROW) :触发语句作用的每一条记录都被触发。在行级触
    发器中使用 old 和 new伪记录变量, 识别值的状态。

    *语法格式:
    create or replace trigger 触发器名字
    before|after ---设置触发器在改变数据之前或之后执行
    insert | update | delete [of 列名] --设置具体改变数据的命令,可以写一个,也可写多个,多个使用or连接
    on 表名 --改变那个表的时候触发
    [for each row] --触发器的级别
    [declare]

    begin
    逻辑处理
    end;

    7.java程序调用储存过程
    *可以在虚拟机中 xp系统里面 的 oracle 安装目录下找到 jar 包 :ojdbc14.jar
    *创建项目导入jar包
    *实现sql语句的调用

  • 相关阅读:
    buildroot编译文件系统,出现mount: you must be root. can't open /dev/console: Permission denied这种错误。
    Ubuntu 18.04实现实时显示网速
    git 第一次push 出现fatal: 无法读取远程仓库。
    Sql2012 AlwaysOn
    SCVMM 安装
    POJ 3537 Crosses and Crosses
    HDOJ 1524 A Chess Game
    HDOJ 1907 John
    HDOJ 1848 Fibonacci again and again
    HDOJ 1536 S-Nim
  • 原文地址:https://www.cnblogs.com/flzidea/p/10183394.html
Copyright © 2011-2022 走看看