plsql判断和循环
if语句
语法1
如果条件成立,执行if和end if 之间的语句。
if 条件表达式 then
plsql语句;
end if;
语法2
if 条件表达式 then
条件成立时执行的语句;
else
条件不成立时执行的语句;
end if;
语法3
if 条件表达式1 then
条件1成立时执行的语句;
elsif 条件表达式2 then
条件2成立时执行的语句;
...
elsif 条件表达式n then
条件n成立时执行的语句;
else
所有条件都不成立时执行的语句;
end if;
例1
```
declare
test_scores number(4,1):=&请输入您的成绩;
begin
if test_scores>=90 and test_scores=80 and test_scores=70 and test_scores=60 and test_scores
例2
declare
test_scores1 number(4,1):=&请输入您的成绩;
begin
if test_scores1=60 then
dbms_output.put_line('您输入的成绩为'||test_scores1||' 经评测等级为'||'D');
elsif test_scores1=70 then
dbms_output.put_line('您输入的成绩为'||test_scores1||' 经评测等级为'||'C');
elsif test_scores1=80 then
dbms_output.put_line('您输入的成绩为'||test_scores1||' 经评测等级为'||'B');
elsif test_scores1=90 then
dbms_output.put_line('您输入的成绩为'||test_scores1||' 经评测等级为'||'A');
else
dbms_output.put_line('请您确认成绩后再试');
end if;
end;
case when语句
语法1(这种语法一般只用在sql语句中,它功能和decode函数一样)
case
when 条件表达式1 then
值1;
when 条件表达式2 then
值2;
...
when 条件表达式3 then
值2;
else
默认值
end case;
语法2
case 表达式
when 值1 then
plsql语句;
when 值2 then
plsql语句;
..
when 值3 then
plsql语句;
else
默认执行的语句;
end case;
例1
```
declare
v_scores number(4,1):=&请输入您的成绩;
v_output varchar2(50);
begin
v_output:=case
when v_scores=60 then 'D'
when v_scores=70 then 'C'
when v_scores=80 then 'B'
when v_scores=90 then 'A'
else '请您确认成绩后再试' end;
dbms_output.put_line('您输入的成绩为'||v_scores||'评测等级为'||v_output);
end;
```
例2
```
declare
v_grade varchar2(20):='A';
v_score varchar2(50);
begin
v_score:=case v_grade
when '不及格' then '成绩
loop
语法
loop
循环体(plsql语句);
退出循环条件;
循环变量控制语句;
end loop
循环打印1-10
```
declare
--声明一个变量作为循环变量
n number(6):=1;
begin
--循环打印
loop
--循环体语句,打印n的值
dbms_output.put_line(n);
--退出循环条件
exit when n=10;
--循环控制语句,修改循环变量n的值
n:=n+1;
end loop;
end;
```
循环打印1-10
declare
control_var number(2):=0;
begin
loop
if control_var>9 then
exit;
end if;
control_var:=control_var+1;
dbms_output.put_line(control_var);
end loop;
end;
while
如果循环条件成立,执行循环体和循环控制语句
直到循环条件不成立退出循环
while 循环条件 loop
循环体语句;
循环控制语句;
end loop;
循环打印1-10
```
declare
--声明一个变量作为循环变量
n number(10):=1;
begin
--while循环打印条件
while n
循环打印1-10
```
declare
n number(10):=0;
begin
while n
for循环
语法1
for 循环变量 in 数字集合 loop
循环体语句;
end loop;
数字集合的表示
1..10 表示1到10的自然数集合
循环打印1-10
```
begin
for i in 1..10 loop
dbms_output.put_line(i);
end loop;
end;
```
循环打印10-1
```
begin
for i in reverse 1..10 loop
dbms_output.put_line(i);
end loop;
end;
```
reverse表示集合顺序反转
语法2
for 循环变量 in select语句或者游标变量 loop
循环体语句;
end loop;
获取emp表中员工编号
```
begin
for v_empno in(select empno from emp) loop
dbms_output.put_line(v_empno.empno);
end loop;
end;
```
获取emp表中员工编号和工作
```
begin
for v_emp in(select * from emp) loop
dbms_output.put_line(v_emp.empno||','||v_emp.job);
end loop;
end;
```
获取emp表中全部数据
```
begin
for v_emp in(select * from emp) loop
dbms_output.put_line(rpad(v_emp.empno, 4,' ')||' , '||
nvl(rpad(v_emp.ename,10,' '),' ')||' , '||
nvl(rpad(v_emp.job,9,' '),' ')||' , '||
nvl(rpad(v_emp.mgr,4,' '),' ')||' , '||
nvl(to_char(v_emp.hiredate,'YYYYMMDD'),' ')||' , '||
nvl(rpad(v_emp.sal,4,' '),' ')||' , '||
nvl(rpad(v_emp.comm,7,' '),' ')||' , '||
nvl(rpad(v_emp.deptno,2,' '),' ')
);
end loop;
end;
```
退出循环
- exit退出整个循环
- continue退出本次循环
- return直接退出程序
for
for1
```
begin
for i in 1..9 loop
if i=5 then
dbms_output.put_line('我要退出了');
exit;
end if;
dbms_output.put_line(i);
end loop;
dbms_output.put_line('小**,我在循环体外');
end;
```
执行结果
```
1
2
3
4
我要退出了
小**,我在循环体外
```
for2
```
begin
for i in 1..9 loop
if i=5 then
dbms_output.put_line('我要退出了');
continue;
end if;
dbms_output.put_line(i);
end loop;
dbms_output.put_line('小**,我在循环体外');
end;
```
执行结果
1
2
3
4
我要退出了
6
7
8
9
小**,我在循环体外
for3
```
begin
for i in 1..9 loop
if i=5 then
dbms_output.put_line('我要退出了');
return;
end if;
dbms_output.put_line(i);
end loop;
dbms_output.put_line('小**,我在循环体外');
end;
```
执行结果
1
2
3
4
我要退出了
loop
loop
```
declare
v_control number(2) := 0;
begin
loop
v_control := v_control + 1;
if v_control = 5 then
continue;
end if;
if v_control = 10 then
exit;
end if;
dbms_output.put_line(v_control);
end loop;
dbms_output.put_line('小**,我在循环体外');
end;
```
执行结果
1
2
3
4
6
7
8
9
小**,我在循环体外
while
while
```
declare
v_control number(2):=0;
begin
while v_control
执行结果
1
2
3
4
6
7
8
9
goto(不常用)
执行到goto语句时,代码会回到标签所在位置,重新往下执行
标签
```
declare
--声明一个变量作为循环变量
n number:=1;
begin
>
dbms_output.put_line(n);
n:=n+1;
if n
plsql判断和循环的更多相关文章
- python之--条件判断和循环
Python之判断 和其他语言一样,python同样具有条件判断和循环的操作,比如我们可以编写一个简单的判断操作:使用if关键字可以达到判断的效果,如下例: >>> test_if ...
- python学习第六天 条件判断和循环
总归来讲,学过C语言的同学,对条件判断和循环并不陌生.这次随笔只是普及一下python的条件判断和循环对应的语法而已. 条件判断: 不多说,直接贴代码: age = 23 if age >= 6 ...
- 初学Java scirpt(判断、循环语句)
在编写代码时,我们经常需要为不同的判断结果来执行不同的动作以及需要反复执行同一段代码,这时我们就需要使用判断和循环语句来实现. 1.判断语句(if) 判断语句经常用的有(if......else).( ...
- python入门(11)条件判断和循环
python入门(11)条件判断和循环 条件判断 计算机之所以能做很多自动化的任务,因为它可以自己做条件判断. 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,用if语句实现: ag ...
- Python学习之条件判断和循环
#coding= utf-8 # 条件判断和循环 # 如果if语句判断是True,就把缩进的两行print语句执行了,否则,什么也不做 age1 = 20 if age1 >= 18: prin ...
- Python第四天 流程控制 if else条件判断 for循环 while循环
Python第四天 流程控制 if else条件判断 for循环 while循环 目录 Pycharm使用技巧(转载) Python第一天 安装 shell 文件 Python第二天 ...
- 【转】shell编程下 特殊变量、test / [ ]判断、循环、脚本排错
[转]shell编程下 特殊变量.test / [ ]判断.循环.脚本排错 第1章 shell中的特殊变量 1.1 $# $# 表示参数的个数 1.1.1 [示例]脚本内容 [root@znix ~] ...
- javascript中的分支判断与循环
分支判断与循环 分支结构 单一选择结构(if) 二路选择结构(if/else) 内联三元运算符 ?: 多路选择结构(switch) var condition = true; if (conditio ...
- python基础(二)条件判断、循环、格式化输出
继续上一篇,今天主要总结一下条件判断.循环.格式化输出 一.条件判断 python中条件判断使用if else来判断,多分支的话使用if elif ... else,也就是如果怎么怎么样就怎么怎么样, ...
随机推荐
- FastJson稍微使用不当就会导致StackOverflow
GitHub 9.4k Star 的Java工程师成神之路 ,不来了解一下吗? GitHub 9.4k Star 的Java工程师成神之路 ,真的不来了解一下吗? GitHub 9.4k Star 的 ...
- 史上最全 Java 中各种锁的介绍
更多精彩原创内容请关注:JavaInterview,欢迎 star,支持鼓励以下作者,万分感谢. 锁的分类介绍 乐观锁与悲观锁 锁的一种宏观分类是乐观锁与悲观锁.乐观锁与悲观锁并不是特定的指哪个锁(J ...
- PHP、 Ruby、Python、Java、C++、C、Objective C——编程语言之禅
PHP是你豆蔻年华时的心上人,她是情窦初开的你今年夏天傻乎乎追求的目标.玩一玩可以,但千万不要投入过深,因为这个“女孩”有严重的问题. Ruby是脚本家族中一个非常漂亮的孩子.第一眼看她,你的心魄就会 ...
- 获取Centos的Docker CE
Docker文档 Docker提供了一种在容器中运行安全隔离的应用程序的方法,它与所有依赖项和库打包在一起. 获取Centos的Docker CE 一.OS要求 要安装Docker Engine-Co ...
- Xshell6配置ssh免密码登录虚拟机
首先先说明一下有密码的,涉及到root登陆权限的问题: 1.用超级管理员身份登录,修改 vi /etc/ssh/sshd_config, 找到 把其中的permitRootLogin 修改成: # ...
- mjpg-stream 视频服务 (1)| 简介与配置树莓派使用
源码地址为:https://github.com/jacksonliam/mjpg-streamer Mjpg简介: (1)mjpg-streamer是一个命令行应用程序,它将JPEG帧从一个或多个输 ...
- PHP 从另一个角度来分析 Laravel 框架的依赖注入功能
从根本上说,依赖注入不是让对象创建一个依赖关系,也不是让工厂对象去创建对象,而是将所需的依赖变成一个外部对象,使之成为一个"某些人的问题” 你为"某些人的问题”注入了类的依赖关系. ...
- 如何对 React 函数式组件进行优化
文章首发个人博客 前言 目的 本文只介绍函数式组件特有的性能优化方式,类组件和函数式组件都有的不介绍,比如 key 的使用.另外本文不详细的介绍 API 的使用,后面也许会写,其实想用好 hooks ...
- JenKins结合cppcheck及cpplint进行代码风格及静态代码检测
JenKins结合cppcheck及cpplint 最近公司需要在Jenkins上安装cppcheck及cpplint进行代码风格及静态代码检测,这里记录下过程. 前提条件 安装了Jenkins 步骤 ...
- deepin MySQL 安装以及编码格式的修改utf-8
deepin MySQL 安装以及编码格式的修改utf-8: 1.sudo apt-get install mysql-server mysql-client 2.sudo mysql -u root ...