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语句的调用

转载于:https://www.cnblogs.com/flzidea/p/10183394.html

Orecle基本概述(2)相关推荐

  1. Java 多线程概述

    多线程技术概述 1.线程与进程 进程:内存中运行的应用程序,每个进程都拥有一个独立的内存空间. 线程:是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换.并发执行,一个进程最少有一个线程, ...

  2. 【SpringMVC】概述

    概述: SpringMVC:是基于spring的一个框架, 实际上就是spring的一个模块, 专门是做web开发的.                       理解是servlet的一个升级 Sp ...

  3. 梯度下降优化算法概述

    本文原文是 An overview of gradient descent optimization algorithms,同时作者也在 arXiv 上发了一篇同样内容的 论文. 本文结合了两者来翻译 ...

  4. Redis概述和基础

    Redis 1.NoSQL NoSQL = Not Only SQL(不仅仅是SQL) 泛指非关系型数据库的,随着web2.0互联网的诞生!传统的关系型数据库很难对付web2.0时代!尤其是超大规模的 ...

  5. OpenCL™(开放计算语言)概述

    OpenCL™(开放计算语言)概述 异构系统并行编程的开准 OpenCL™(开放计算语言)是一种开放的.免版税的标准,用于对超级计算机.云服务器.个人计算机.移动设备和嵌入式平台中的,各种加速器进行跨 ...

  6. 自动驾驶QNX,Linux,Autosar概述

    自动驾驶QNX,Linux,Autosar概述 QNX是一个分布式.嵌入式.可规模扩展的实时操作系统.遵循POSIX.1 (程序接口)和POSIX.2 (Shell和工具).部分遵循POSIX.1b( ...

  7. Tengine MLOps概述

    Tengine MLOps概述 大幅提高产业应用从云向边缘迁移的效率 MLOps Cloud Native 聚焦于提升云端的运营过程效率 MLOps Edge Native 聚焦于解决边缘应用开发及异 ...

  8. Tengine Web服务器概述

    Tengine Web服务器概述 Tengine是由淘宝网发起的Web服务器项目.在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性.目的是打造一个高效.安全的Web平台. 发展 ...

  9. Docker基本原理概述

    Docker基本原理概述 Docker是一个用于开发,交付和运行应用程序的开放平台.Docker能够将应用程序与基础架构分开,从而可以快速交付软件.借助Docker,可以以与管理应用程序相同的方式来管 ...

最新文章

  1. DOM+XPath提取规则注记!
  2. 【秋招必备】LeetCode神器,算法刷题宝典.pdf
  3. php7.2 mysql 教程_如何在PHP7中扩展mysql,先安装php7.2。后安装mysql
  4. 智能计算机科学的奠基人,【编注】神经网络算法奠基人之一沃尔特·皮茨的传奇故事...
  5. kafka 报错:kafka server:Message was too large ,server rejected it to avoid allocation
  6. easyui一行显示多行_easyui datagrid以及oracle中的多行合并一行
  7. arduino tft 方向_ESP32在Arduino环境下玩转 LVGL,ESP32移植LVGL详细教程
  8. mysql交叉连接后生成的记录总数_4.mysql数据库创建,表创建模等模板脚本,mysql_SQL99标准的连接查询(内连接,外连接,满外连接,交叉连接)_MySQL...
  9. linux listen监听,Linux网络协议栈 -- socket listen监听
  10. python文本进度条代码解释_python动态文本进度条的实例代码
  11. Linux USB设备驱动程序设计 和 USB下载线驱动设计
  12. mybatis-spring-struts2整合
  13. VS code 快捷键常用
  14. Windows 7语言包下载
  15. 解决File “D:\ProgramData\Anaconda3\lib\site-packages\keras\engine\saving.py“,相关问题
  16. Win10系统上设置Microsoft store的默认下载路径
  17. Python 面试题
  18. 【无标题】2022年施工员-设备方向-通用基础(施工员)考试模拟100题及模拟考试
  19. Random中的随机数的产生机制
  20. 中国古代数学家张丘建在他的《算经》中提出了一个著名的 “ 百钱买百鸡问题”鸡翁一, 值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何

热门文章

  1. python从入门到精通怎么样-Python从入门到精通:一个月就够了
  2. 21天学通python第二版-电子工业出版社-网上书店
  3. 怎么自学python自动化测试-学习自动化测试,如何学习Python语言?
  4. python培训中心-【北京Python培训中心】
  5. python字符串写入excel-Python向excel中写入数据的方法
  6. Opengl-光照-基本光照-冯氏(千万好好理解后面所有的延伸基本都是基于这个的)
  7. JSR338(Java Persistence)
  8. LeetCode Course Schedule II(拓扑排序)
  9. nginx启动初始化过程(二)
  10. java设计模式:Singleton模式