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

Orecle基本概述(2)的更多相关文章

  1. Orecle基本概述(1)

    Orecle1.什么是orecle及体系结构?* 全局数据库,指物理磁盘数据库,一个真实存在的磁盘目录.*用户: 用户在oracle里面是用来隔离数据的*表空间: 逻辑结构,不可视的,虚拟的,用户的数 ...

  2. 【AR实验室】ARToolKit之概述篇

    0x00 - 前言 我从去年就开始对AR(Augmented Reality)技术比较关注,但是去年AR行业一直处于偶尔发声的状态,丝毫没有其"异姓同名"的兄弟VR(Virtual ...

  3. Recurrent Neural Network系列1--RNN(循环神经网络)概述

    作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 本文翻译自 RECURRENT NEURAL NETWORKS T ...

  4. Swift3.0服务端开发(一) 完整示例概述及Perfect环境搭建与配置(服务端+iOS端)

    本篇博客算是一个开头,接下来会持续更新使用Swift3.0开发服务端相关的博客.当然,我们使用目前使用Swift开发服务端较为成熟的框架Perfect来实现.Perfect框架是加拿大一个创业团队开发 ...

  5. .Net 大型分布式基础服务架构横向演变概述

    一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...

  6. [C#] 进阶 - LINQ 标准查询操作概述

    LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ...

  7. 【基于WinForm+Access局域网共享数据库的项目总结】之篇一:WinForm开发总体概述与技术实现

    篇一:WinForm开发总体概述与技术实现 篇二:WinForm开发扇形图统计和Excel数据导出 篇三:Access远程连接数据库和窗体打包部署 [小记]:最近基于WinForm+Access数据库 ...

  8. Java消息队列--JMS概述

    1.什么是JMS JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送 ...

  9. [AlwaysOn Availability Groups]健康模型 Part 1——概述

    健康模型概述 在成功部署AG之后,跟踪和维护健康状况是很重要的. 1.AG健康模型概述 AG的健康模型是基于策略管理(Policy Based Management PBM)的.如果不熟悉这个特性,可 ...

随机推荐

  1. 关于Java网络编程

    一,网络编程中两个主要的问题 一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输. 在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可 ...

  2. mysql设置updatetime字段每次修改时自动更新

    我们在数据库表设计阶段中都会加上CreateTime, UpdateTime字段, 在重要业务字段更新的时候,都会重新赋值UpdateTime字段,这个对后期查找分析业务数据变更时非常有用. 但是现在 ...

  3. 人工智能-智能创意平台架构成长之路(四)-丰富多彩的banner图生成解密第一部分(对标阿里鹿班的设计)

    我们之前讲了很多都是平台架构的主体设计,应用架构设计以及技术架构的设计,那么现在我们就来分享一下丰富多彩的banner图是怎么生成出来的. banner图的生成我们也是不断的进行迭代和优化,这块是最核 ...

  4. Spring Security Oauth2 自定义 OAuth2 Exception

    付出就要得到回报,这种想法是错的. 前言 在使用Spring Security Oauth2登录和鉴权失败时,默认返回的异常信息如下 { "error": "unauth ...

  5. golang中Array与Slice

    在golang中有数组和Slice两种数据结构,Slice是基于数组的实现,是长度动态不固定的数据结构,本质上是一个对数组字序列的引用,提供了对数组的轻量级访问.那么在go的函数中以数组或Slice为 ...

  6. Flask学习之旅--还是数据库(sqlacodegen + SQL Alchemy)

    一.写在前面 其实之前已经写过一篇关于 Flask 中使用数据库的博客了,不过那一篇博客主要是记录我在使用 Flask + MySQL8.0 时所遇到的一些问题(如果用的不是 MySQL8.0估计就没 ...

  7. 记录工作中linux相关操作

    在项目部署之后,查看日志能查看部署结果是否正确部署. 最开始查看日志我会使用cat service.log tail -f service.log vim service.log 打开日志之后 /+查 ...

  8. Rsync 服务部署与参数详解

    Rsync 简介 rsync 是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份的优秀工具.Rsync软件适用于unix/linux/windows等多种操作系统平台. 传统的 ...

  9. github认证登陆

    使用github OAuth实现用户登录 做登录功能时,允许使用第三方网站的身份,这称为"第三方登录". 原理 github内的认证方法 在github上申请OAuth App,进 ...

  10. 品Spring:SpringBoot和Spring到底有没有本质的不同?

    现在的Spring相关开发都是基于SpringBoot的. 最后在打包时可以把所有依赖的jar包都打进去,构成一个独立的可执行的jar包.如下图13: 使用java -jar命令就可以运行这个独立的j ...