oracle中的控制语句
一、条件语句
1、流程控制-if else
(1)if
if 判断条件 then
...
end if;
(2)if-else
if 判断条件 then
...
else
...
end if;
(3)if-elsif
if 判断条件1 then
...
elsif 判断条件2 then
...
elsif 判断条件n then
...
end if;
(4)if-elsif-else
if 判断条件1 then
...
elsif 判断条件2 then
...
elsif 判断条件n then
...
else
...
end if;
例:
set serverout on;
declare
employee_number number;
begin
select count(*) into employee_count from employees where employee_age>30;
if employee_count>10 then
dbms_output.put_line('公司有年龄大于30的员工');
else
dbms_output.put_line('公司没有年龄大于30的员工');
end if;
end
统计年龄大于30的员工信息,存在多个条件判断(elsif)时如下:
declare
employee_number number;
begin
select count(*) into employee_count from employees where employee_age>30;
if employee_count=1 then
dbms_output.put_line('公司有1名年龄大于30的员工');
elsif employee_count>1 then
dbms_output.put_line('公司有多年龄大于30的员工');
else
dbms_output.put_line('公司没有年龄大于30的员工');
end if;
end
2、流程控制-case when
case when 与if else 有相同的效果。当需要匹配的情况较多时,可以使流程控制更加清晰
(1)case-when
case expression
when value1 then
...
when value2 then
...
when valuen then
...
end case;
(2)case-when-else
case expression
when value1 then
...
when value2 then
...
when valuen then
...
else
...
end case;
例:
declare employee_number number;
begin
select count(*) into employee_count from employees where employee_age>30;
case employee_count
when 1 then
dbms_output.put_line('公司有1名年龄大于30的员工');
when 0 then
dbms_output.put_line('公司没有年龄大于30的员工');
else
dbms_output.put_line('公司有多名年龄大于30的员工');
end case
end
二、循环语句
1、无条件循环-loop
loop
...
end loop;
例:
declare v_id number :=0;
v_name varchar2(20);
begin
loop
if v_id>=5 then
exit;--退出循环
end if;
v_id:=v_id+1;
select empolyee_name into v_name from employees where employee_id=v_id;
dbms_output.put_line(v_id||'号员工是'||v_name);
end loop;
end;
除了利用if判断退出循环外,还可以exit when的形式跳出循环
2、while循环
while 条件判断 loop
循环操作
end loop;
while指定循环条件,其后仍然跟loop,此处的loop循环与无条件循环中的loop完全相同,只是增加了while条件而已。
例:
declare v_id number :=0;
v_name varchar2(20);
begin
while v_id>=5
loop
v_id:=v_id+1;
select empolyee_name into v_name from employees where employee_id=v_id;
dbms_output.put_line(v_id||'号员工是'||v_name);
end loop;
end;
3、for循环
for .. in .. loop
...
end loop;
例:
declare v_id number :=0;
v_name varchar2(20);
begin
for v_id in 1..5
loop
v_id:=v_id+1;
select empolyee_name into v_name from employees where employee_id=v_id;
dbms_output.put_line(v_id||'号员工是'||v_name);
end loop;
end;
4、循环控制关键字
(1)continue:终止本次循环,进入下一次循环。
(2)exit:终止本层循环,进入下一层循环。oracle中没有break关键字,用exit代替。
(3)return:直接跳出存储过程或函数。
转自:https://blog.csdn.net/qq_17503037/article/details/79261510
oracle中的控制语句的更多相关文章
- Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...
- Oracle中PL/SQL简介、基本语法以及数据类型
Oracle中PL/SQL简介.基本语法以及数据类型 一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控 ...
- Oracle中SQL语句分类
Oracle中SQL语句分类如下:1.DML语句 insert/delete/update/select/merge/explan plan/lock table2.DDL语句 create/atlt ...
- Oracle中varchar,varchar2,nvarchar,nvarchar2的区别及其它数据类型描述
--varchar,varchar2 联系: 1.varchar/varchar2用于存储可变长度的字符串 比如varchar(20),存入字符串'abc',则数据库中该字段只占3个字节,而不是20个 ...
- Oracle中如何实现Mysql的两表关联update操作
在看<MySQL 5.1参考手册>的时候,发现MySQL提供了一种两表关联update操作.原文如下: UPDATE items,month SET items.price=month.p ...
- ORACLE中的LTRIM、RTRIM和TRIM
LTRIM.RTRIM和TRIM在ORACLE中的用法:1.LTRIM(C1,C2)其中C1和C2都可以字符串,例如C1是'Miss Liu',C2'MisL'等等.这是第一个和SQL SERVER不 ...
- oracle中临时表是用来做什么的
oracle中临时表是用来做什么的 某些情况下, 需要 多个非常大的表关联的情况下, 但是需要检索的, 是少量的数据的时候.可以先把 大表的数据, 检索出那一小部分, 然后插入到 临时表中, 最后再关 ...
- Oracle 中 decode 函数用法
Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...
- ORACLE 中ROWNUM用法总结(转)
ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=) ...
随机推荐
- shell 中的判断
一.if的基本语法: if [ command ];then 符合该条件执行的语句 elif [ command ];then 符合该条件执行的语句 else 符合该条件执行的语句 ...
- LeetCode Weekly Contest 266
第一题 题解:模拟题 class Solution { public: int countVowelSubstrings(string w) { int n = w.length(); int i = ...
- Canal 实战 | 第一篇:SpringBoot 整合 Canal + RabbitMQ 实现监听 MySQL 数据库同步更新 Redis 缓存
一. Canal 简介 canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署,存在跨机房同 ...
- 【接口】HttpClient 处理get和post请求(二)(2019-07-14 18:41)
一.环境准备 1.导入httpClient依赖包 <dependency> <groupId>org.apache.httpcomponents</groupId> ...
- TDSQL | 在整个技术解决方案中HTAP对应的混合交易以及分析系统应该如何实现?
从主交易到传输,到插件式解决方案,每个厂商对HTAP的理解和实验方式都有自己的独到解法,在未来整个数据解决方案当中都会往HTAP中去牵引.那么在整个技术解决方案中HTAP对应的混合交易以及分析系统应该 ...
- robot_framewok自动化测试--(1)Robot Framework 环境搭建及常见日志问题解决办法
一.Robot Framework 介绍 Robot Framework 的架构是一个通用的验收测试和验收测试驱动开发的自动化测试框架(ATDD).它具有易于使用的表格来组织测试过程和测试数据. 它使 ...
- 【Python+postman接口自动化测试】(6)Chrome开发者工具
Chrome开发者工具 Elements: HTML元素面板,用于定位查看元素源代码 Console: js控制台面板,js命令行,查看前端日志 Sources: 资源面板,用于断点调试js Netw ...
- 【Python接口自动化测试】Postman使用简介
下载地址: http://www.downza.cn/soft/205171.html 工具栏 New: 新建,可以新建Request请求,Collection请求集,环境等等 Import: 导入, ...
- webpack 打包html文件
webpack 打包html文件 webpack.config.js配置文件内容为: /** * loader: 1. 下载 2. 使用(配置) * plugins:1. 下载 2. 引入 3.使用 ...
- MyBatis Plus中使用and和or
如图:show me the code 参考: https://mp.baomidou.com/guide/wrapper.html#or