Oracle基础基础:通过通过sqlplus执行执行sql语句后的结果进行判断语句后的结果进行判断
今天小编就为大家分享一篇关于Oracle基础:通过sqlplus执行sql语句后的结果进行判断,小编觉得内容挺不错
的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
这篇文章介绍一下如何对sqlplus执行的sql语句结果进行判断。
环境准备环境准备
使用Oracle的精简版创建docker方式的demo环境,详细可参看:
https://www.jb51.net/article/153533.htm
常见问题常见问题
在sqlplus中执行sql语句,如果直接使用命令行的方式调用时会碰到两个问题:
问题1: 需要进行交互性的输入
问题2:结果的判断不能通过返回值来确认
解决方式解决方式
在脚本调用里,解决方式如下
问题1可以通过前文提到的Here Document来解决。
问题2,则可以通过对输出的判断来进行,因为Oracle的错误代码基本以ORA-打头,所以根据输出中是否包含ORA-,基
本可确认是否存在错误。
执行结果判断示例执行结果判断示例
这里使用命令行的方式进行验证,直接拷贝到脚本中即可以使用脚本的方式与sqlplus进行集成。
oracle@e871d42341c0:~$ sqlplus system/liumiao123@XE <<EOF
> desc student
> delete from student;
> select * from student;
> insert into student values (1001, 'liumiaocn');
> insert into student values (1001, 'liumiao');
> insert into student values (1003, 'michael');
> commit;
> select * from student;
> EOF
SQL*Plus: Release 11.2.0.2.0 Production on Mon Oct 22 05:18:51 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> Name Null? Type
----------------------------------------- -------- ----------------------------
STUID NOT NULL NUMBER(4)
STUNAME VARCHAR2(50)
SQL>
3 rows deleted.
SQL>
no rows selected
SQL>
1 row created.
SQL> insert into student values (1001, 'liumiao')
*
ERROR at line 1:
ORA-00001: unique constraint (SYSTEM.SYS_C007024) violated
SQL>
1 row created.
SQL>
Commit complete.
SQL>
STUID STUNAME
---------- --------------------------------------------------
1001 liumiaocn
1003 michael
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$ echo $?
0
oracle@e871d42341c0:~$
从上文可以看到,三行insert的sql语句由于第二行的主键重复,出现错误,但是最终的结果使用命令行的方式无法对结果进行
评论0