【Oracle】PL/SQL语法、存储过程,触发器

一、Oracle数据类型

Orcle数据类型说明类比MySQL数据类型
字符型CHAR固定长度的字符类型CHAR
字符型VARCHAR2可变长度的字符类型VARCHAR
字符型LONG大文本类型,最大2G
数值型NUMBER数值类型,整数小数都可以,number(5)表示长度5的整数,number(5,2)表示共5位,含2位小数INT存整数,FLOAT、DOUBLE存小数
日期型DATE日期时间型,精确到秒
日期型TIMESTAMP精确到秒的小数点后9位
二进制型CLOB存储字符,最大4G(比LONG更多)LONGTEXT
二进制型BLOB存储图像、声音、视频等数据,最大 4GLONGBLOB

二、PL/SQL

PL/SQL(Procedure Language/SQL)是Oracle对SQL语言的过程化扩展,指在SQL命令语言中增加了过程处理语句(分支、循环等)。
基本语法结构

[declare-- 声明变量
]
begin--代码逻辑
[exception--异常处理
]
end;

2.1 变量

变量声明语法:
变量名 类型(长度)
变量赋值语法:
变量名:=变量值
select into赋值语法(结果必须是一条记录,多条记录和没有记录都会报错):
select 列名 into 变量名 from 表名 where 条件

2.2 属性类型

引用型语法,某个变量的类型不预先指定,而是与查询结果相同
表名.列名%type
举例:

declare v_price number(10,2);v_usenum2 number(10,2);v_usenum t_account.usenum%type;--变量的类型与t_account.num0相同v_num0 t_account.num1%type;
beginv_price:=2.45;select usenum,num0 into v_usenum,v_num0 from t_account -- 把usenum赋给v_usenum,num0赋给v_num0where year='2012' and month='01' and owneruuid=1;v_usenum2:=round(v_usenum/1000,2);
end;

记录型语法,某个变量表示一行
表名%rowtype
举例:

declare v_price number(10,2);v_usenum2 number(10,2);v_account t_account%rowtype;--表示一行记录
beginv_price:=2.45;select * into v_account from t_account where year='2012' and month='01' and owneruuid=1;--把查出来的一行给v_accountv_usenum2:=round(v_account.usenum/1000,2);--v_account是一行记录,用.列名使用对应列的值
end;

2.3 异常

oracle中有如下两个异常:
NO_DATA_FOUND:执行select into,未返回行
TOO_MANY_ROWS:执行select into,结果集超过一行
举例:

declare v_price number(10,2);v_usenum2 number(10,2);v_account t_account%rowtype;--表示一行记录
beginv_price:=2.45;select * into v_account from t_account where year='2012' and month='01' and owneruuid=1;--把查出来的一行给v_accountv_usenum2:=round(v_account.usenum/1000,2);--v_account是一行记录,用.列名使用对应列的值
exceptionwhen NO_DATA_FOUND then DBMS_OUTPUT.putline('select into 未返回数据'); -- 这句话是打印输出,类似python中print()when TOO_MANY_ROWS thenDBMS_OUTPUT.putline('select into 返回多行数据');
end;

2.4 条件判断

基本语法1:
if 条件 then 业务逻辑 end if;
基本语法2:
if 条件 then 业务逻辑 else 业务逻辑 end if;
基本语法3:
if 条件 then 业务逻辑 elsif 条件 then 业务逻辑 else 业务逻辑 end if;

2.5 循环

无条件循环语法(重点):
loop 循环语句 end loop;
举例:

declarev_num number;
beginv_num:=1;loopv_num:=v_num+1;exit when v_num>100;--loop循环中使用exit退出循环--也可以写成:if v_num>100 then exit;end if;end loop;
end;

有条件循环语法:
while 条件 loop 循环语句 end loop;
举例:

declarev_num number;
beginv_num:=1;while v_num<=100loopv_num:=v_num+1;end loop;
end;

for循环语法(重点):
for 变量 in 起始值..终止值 loop 循环语句 end loop;
举例:

beginfor v_num in 1..100  --for循环v_num自动声明,不用声明,是局部变量,只能在loop和end loop中间使用loopDBMS_OUTPUT.putline(v_num);end loop;
end;

2.6 游标

游标存放SQL语句的执行结果,可以理解成结果集,可以对其进行逐行处理。

声明游标语法:
cursor 游标名称 is SQL语句;
使用游标语法:

open 游标名称
loopfetch 游标名称 into 变量exit when 游标名称%notfound
end loop;
close 游标名称

普通游标使用举例:

declarecursor cur_pricetable is select * from t_pricetable where owertypeid = 100;--声明游标v_pricetable t_pricetable%rowtype;
beginopen cur_pricetable;--打开游标loopfetch cur_pricetable into v_pricetable;--提取游标exit when cur_pricetable%notfound;--退出循环游标DBMS_OUTPUT.putline(v_pricetable.price);--打印每一条记录的priceend loop;close cur_pricetable;--关闭游标
end;

带参数游标使用举例:

declarecursor cur_pricetable(v_ownertype number) is select * from t_pricetable where owertypeid = v_ownertype;--声明带参数的游标v_pricetable t_pricetable%rowtype;
beginopen cur_pricetable(100);--打开游标,传入参数100loopfetch cur_pricetable into v_pricetable;--提取游标exit when cur_pricetable%notfound;--退出循环游标DBMS_OUTPUT.putline(v_pricetable.price);--打印每一条记录的priceend loop;close cur_pricetable;--关闭游标
end;

for循环使用游标举例:
自动打开、关闭游标,不用声明变量,也不用fetch,可以直接使用

declarecursor cur_pricetable(v_ownertype number) is select * from t_pricetable where owertypeid = v_ownertype;--声明带参数的游标
beginfor v_pricetable in cur_pricetable(100) --for循环使用游标,变量不需要声明loopDBMS_OUTPUT.putline(v_pricetable.price);--打印每一条记录的priceend loop;
end;

三、存储函数

存储函数也称为自定义函数,接受一个或多个参数,返回一个结果。
函数中使用PL/SQL进行逻辑处理

存储函数创建语法:
语法is的后面与PL/SQL语法的declare后面是一样的

create [or replace] function 函数名称
(参数名称 参数类型,参数名称 参数类型, ...)  -- 这里只写参数类型,不写长度
return 结果变量数据类型  -- 指定返回值的参数类型,不写长度
is -- 声明变量
begin-- 代码逻辑return 结果变量;
[exception-- 异常处理
]
end;

举例:

create or replace function fn_getaddress
(v_id number)    -- 函数的参数是number类型
return varchar2  -- 函数的返回值是varchar2类型
is v_name varchar2(30);
begin--根据传入的v_id查询name,并返回nameselect name into v_name from t_address where id=v_id;return v_name;
end;-- 调用函数查询id=3的地址
select fn_getaddress(3) from dual;
-- 调用函数查询addressid对应的地址,不用再进行表关联
select id,name,fn_getaddress(addressid) from t_owners;

四、存储过程

存储函数和存储过程的区别:

  1. 存储函数只能返回一个值,存储过程可以传出多个值(返回多个值)
  2. 存储函数可以直接在select语句中使用,而存储过程不能
  3. 存储函数一般封装一个查询结果,存储过程一般封装一段事务代码

存储过程创建语法:
相比存储函数,把function换成了procedure,且没有了返回值

create [or replace] procedure 存储过程名称
(参数名称 参数类型,参数名称 参数类型, ...)  -- 这里只写参数类型,不写长度,参数可以传入,也可以传出
is-- 声明变量
begin-- 代码逻辑
[exception-- 异常处理
]
end;

过程参数的三种模式:
IN 传入参数(默认)
OUT 传出参数,主要用于返回程序运行结果
IN OUT 传入传出参数

不带传出参数的存储过程举例:

create or replace procedure pro_students_add
(
v_id number,
v_name varchar2
)
is 
begin insert into t_students values(v_id,v_name);commit;
end;-- 调用存储过程
call pro_students_add(10,"啦啦啦");

带传出参数的存储过程举例:

create or replace procedure pro_students_add
(
v_id number,
v_name varchar2,
v_stuid out number --声明一个传出参数
)
is 
begin insert into t_students values(v_id,v_name);commit;-- 对传出参数赋值select id into v_stuid from t_students where id = v_id;
end;-- 调用传出参数的存储过程
declarev_stuid number; -- 声明一个变量,用来接收存储过程的传出参数
beginpro_students_add(10,"啦啦啦",v_stuid); -- 执行完该语句后,v_stuid就有值了,后面可以直接用DBMS_OUTPUT.putline(v_stuid);
end;

五、触发器

触发器是基于某一张表的增删改操作的,在对应的增删改操作执行之前/之后,执行一段PL/SQL代码
触发器分类:
前置触发器,在对应语句之前执行
后置触发器,在对应语句之后执行
行级触发器,每操作一条记录就执行一次触发器(一般都是行级触发器)
语句级触发器,不管操作多少条记录,一个SQL语句只对应执行一次触发器
创建触发器语法:

create [or replace] trigger 触发器名before|after[delete][[or] insert][[or] update [of 列名]]on 表名[for each row][when(条件)] -- for each row表名该触发器是行级触发器
declare
beginPL/SQLend;

触发器中:old和:new所代表的值:

触发语句:old:new
Insert所有字段都是空(null)将要插入的数据
update更新前该行的值更新后该行的值
delete删除以前该行的值所有字段都是空(null)

后置触发器举例:

-- 创建日志表,记录业务名称修改前和修改后的值
create table t_owners_log(
updatetime date,
ownerid number,
oldname varchar2(30),
newname varchar2(30)
);create or replace trigger tri_owners_log
after
update of name  
on t_owners     -- 当t_owners.name被update之后触发该触发器
for each row    -- 行级触发器
declarebegininsert into t_owners_log values(sysdate,:new.id,:old.name,:new.name);\-- 注意触发器里不用commit,会自动commit,如果是存储过程则需要commit
end;

六、视图、物化视图、序列、同义词

视图: 一段查询的SQL语句,创建成一张视图,可以把这个视图当表来用,视图不存储数据,修改视图的内容会修改视图对应的基表
物化视图: 一段查询的SQL语句,创建成一张物化视图,会存储数据,修改物化视图不影响基表
序列: Oracle中没有自增主键,所以要用序列实现获取一个自增/自减的数据,序列.nextval获取下一个值,序列.currval返回序列的当前值
同义词: 可以理解为别名,公有同义词所有用户都能使用,私有同义词只能这个用户使用

Oracle结构:
一个Oracle只有一个数据库,一个数据库下有多个表空间
一个表空间下有多个用户,每个用户创建的表都自动在对应的表空间下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/224189.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#科学绘图之scottPlot绘制多个图像

文章目录 示例移除图像图例信号图 scott系列&#xff1a;绘图初步 示例 从名字就能看出&#xff0c;ScottPlot的绘图函数AddScatter的作用是为图窗添加数据点&#xff0c;换言之&#xff0c;每调用一次AddScatter&#xff0c;就可以在图窗中添加一组图像。下面添加两个按钮&a…

excel在扩展屏幕中显示有时候显示黑屏,这种怎么处理?

在使用Excel时&#xff0c;如果在扩展屏幕中出现黑屏或其他显示问题&#xff0c;可以尝试以下方法来解决&#xff1a; 1. 更新显卡驱动程序&#xff1a; 确保你的计算机的显卡驱动程序是最新版本。过时的或不兼容的显卡驱动可能导致显示问题。 2. 调整分辨率和屏幕比例&#…

CS5565设计资料|CS5565规格书|typec转HDMI 8k60Hz方案

CS556x是一款高性能的Type-C/DisplayPort1.4到HDMI2.1协议转换器&#xff0c;可通过Type-C/ DisplayPort链路接收视频和音频流&#xff0c;并转换为支持TMDS或FRL输出信令的HDMI。DP接收器在4个通道上支持高达8.1Gbps的链路速率。HDMI输出端口可用作TMDS或FRL发射器。FRL发射器…

天猫数据分析(天猫数据查询平台):11月天猫啤酒市场销售数据分析报告

在酒类市场中&#xff0c;被视作“气氛担当”的啤酒&#xff0c;是派对聚会或者自饮场景中的常客&#xff0c;消费人群广泛&#xff0c;如今&#xff0c;啤酒市场已进入存量时代&#xff0c;市场中啤酒的销售也在稳步增长。 鲸参谋数据显示&#xff0c;今年11月份&#xff0c;天…

技术分享 | app测试中常用的Android模拟器

Emulator Emualor 是 Android Studio 自带的模拟器&#xff0c;是官方提供的工具&#xff0c;Android 开发最常使用的就是这一款。 它功能非常齐全&#xff0c;电话本、通话等功能都可正常使用。用户可以使用键盘输入&#xff0c;鼠标点击模拟器按键输入&#xff0c;甚至还可以…

MySql数据库的初步认识(数据库学习—— 一)

什么是数据库 数据库&#xff08;Database&#xff09; 是按照数据结构来组织、存储和管理数据的仓库。它是数据管理的有效技术&#xff0c; 是由一批数据构成的有序集合&#xff0c;这些数据被存放在结构化的数据表里。数据表之间相互关联&#xff0c;反映客 观事物间的本质联…

物联网网关

物联网网关是连接物联网设备和互联网的重要桥梁。 它负责将物联网设备采集到的数据进行处理、存储和转发&#xff0c;使其能够与云端或其它设备进行通信。 物联网网关的作用是实现物联网设备与云端的无缝连接和数据交互。 物联网网关功能 数据采集&#xff1a;物联网网关可以从…

十四、YARN核心架构

1、目标 &#xff08;1&#xff09;掌握YARN的运行角色和角色之间的关系 &#xff08;2&#xff09;理解使用容器做资源分配和隔离 2、核心架构 &#xff08;1&#xff09;和HDFS架构的对比 HDFS架构&#xff1a; YARN架构&#xff1a;&#xff08;主从模式&#xff09; &…

一个简单的cmake模板(C++)

链接&#xff1a;小黑屋1024 / Python GitCode #对cmake版本的要求&#xff0c;此处不低于3.16 cmake_minimum_required(VERSION 3.16)#项目名称&#xff1a;此处为test project(test)#设置编译生成产物输出路径 ##可执行文件exe SET(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURC…

医学检验系统LIS源码,C# +.Net+Oracle

LIS是HIS的一个组成部分&#xff0c;通过与HIS的无缝连接可以共享HIS中的信息资源&#xff0c;使检验科能与门诊部、住院部、财务科和临床科室等全院各部门之间协同工作。  体系结构&#xff1a;Client/Server架构 客户端&#xff1a;WPFWindows Forms 服务端&#xff1a;C…

escapeshellarg参数绕过和注入的问题

escapeshellcmd escapeshellcmd(string $command): string command--要转义的命令。 escapeshellcmd() 对字符串中可能会欺骗 shell 命令执行任意命令的字符进行转义。 此函数保证用户输入的数据在传送到 exec() 或 system() 函数&#xff0c;或者 执行操作符 之前进行转义。 …

pytest + yaml 框架 -60.git+jenkins+allure+钉钉通知反馈

前言 当我们自动化用例写完后&#xff0c;接下来就是如何运行用例&#xff0c;生成报告以及反馈通知了。 如果你们公司已经有jenkins了&#xff0c;那么直接集成到jenkins上构建你的自动化任务是非常方便的。 用例上传git仓库 第一步&#xff0c;将写好的自动化用例&#xf…

保障线程安全性:构建可靠的多线程应用

目录 引言 为什么线程安全性如此重要&#xff1f; 1. 竞态条件&#xff08;Race Conditions&#xff09; 2. 死锁&#xff08;Deadlocks&#xff09; 3. 数据竞争&#xff08;Data Races&#xff09; 4. 内存可见性&#xff08;Memory Visibility&#xff09; 面临的挑战…

一张图系列 - “leetcode快速复习“

什么是leetcode&#xff1f; LeetCode是一个在线评测平台&#xff0c;提供大量算法题目&#xff0c;可帮助程序员提高编程和算法能力。它主要提供算法和数据结构相关的练习题&#xff0c;包括各种难度级别的编程题&#xff0c;从简单的算法题到复杂的系统设计问题都有。用户可…

【玩转TableAgent数据智能分析】TableAgent全功能详解及多领域数据分析实践(中)不同领域数据分析实践

3 电影点评数据分析实践 利用本身自带的电影点评数据&#xff0c;来具体看一下TableAgent的分析能力&#xff0c;选择电影点评数据&#xff0c;智能体会自动导入该数据DMSC20000.csv&#xff0c;大小为3.3 MB。在数据信息展示区&#xff0c;就会显示出该数据&#xff0c;并提供…

知识付费平台选择指南:如何找到最适合你的学习平台?

在当今的知识付费市场中&#xff0c;用户面临的选择越来越多&#xff0c;如何从众多知识付费平台中正确选择属于自己的平台呢&#xff1f;下面&#xff0c;我们将为您介绍我有才知识付费平台相比同行的优势&#xff0c;帮助您做出明智的选择。 一、创新的技术架构&#xff0c;…

Java研学-MyBatis框架

一 MyBatis框架 1 框架介绍 框架&#xff1a;对基础代码进行封装并提供相应的API&#xff0c;调用API可省去一些代码的编写&#xff0c;从而提高效率。一个好的框架一定是经过测试&#xff0c;自身的功能已经实现&#xff0c;可以完成特定的功能。 2 MyBatis 框架 MyBatis 框…

Spring Mybatis随记

连接池获取连接逻辑 com.zaxxer.hikari.pool.HikariPool#getConnection(long) // 内部循环获取空闲连接&#xff0c;返回前检查数据库连接是否可以用Spring获取连接 如果已经开启了事务&#xff0c;只要没提交事务&#xff0c;调用非事务的DAO执行sql也会被事务统一管理 org.…

基于物理的AlGaN/GaN HEMT器件2DEG电荷密度分析模型(文献阅读)

标题&#xff1a;A Physics-Based Analytical Model for 2DEG Charge Density in AlGaN/GaN HEMT Devices (IEEE TRANSACTIONS ON ELECTRON DEVICES) 重要公式 2DEG电荷密度建模的困难源于量子阱中Ef随ns的复杂变化。此关系由给出 n s D V t h [ l n ( l e E f − E 0 V t …

Seconds_Behind_Master越来越大,主从同步延迟

问题现象 发现从库mysql_slave的参数Seconds_Behind_Master越来越大。已排除主从服务器时间不一致&#xff1b;那么主要就判断两点&#xff1a;是io thread慢还是 sql thread慢&#xff1f;先观察show slave status\G 。 判断3个参数&#xff08;参数后面的值是默认空闲时候的…