Bash中执行存储过程或普通的SQL命令

演示: 在bash中执行一个存储过程和一个普通的SQL语句


0. 前提条件:

数据库:Oracle10g

表:oracle自带的emp表,默认有数据如下:


1. 在bash中执行oracle存储过程

首先,在oracle中建立一个存储过程Proc_SelEName

CREATE OR REPLACE Procedure Proc_SelEName
(inempno number,outname out varchar2
)
as
beginselect ename into outname from emp where empno=inempno;
end;
接着,建立bash脚本:mysh.sh

#!/bin/bashsql_str=`
sqlplus -S scott/scott@ORCLtxk <<EOF--set linesize 800;--set long 2048576;--set serveroutput on;var oi_return varchar2(20);call  Proc_SelEName($1,:oi_return);select :oi_return from dual;
exit
EOF`echo "$sql_str"
最后,执行脚本,检测结果:

[zcm@bash #23]$./mysh.sh 7369Call completed.:OI_RETURN
--------------------------------------------------------------------------------
SMITH
[zcm@bash #24]$

2. 在bash中执行普通的SQL查询语句

只需要修改下上面的bash脚本就可以了,修改如下:

#!/bin/bashsql_str=`
sqlplus -S scott/scott@ORCLtxk <<EOFselect empno,ename from emp t where rownum<3;
exit
EOF`echo "$sql_str"

最后运行bash脚本:

[zcm@bash #24]$./mysh.shEMPNO ENAME
---------- ----------7369 SMITH7499 ALLEN
[zcm@bash #25]$

结论:在bash中执行oracle存储过程及sql语句非常方便,返回的结果就像是在终端下执行的结果--普通的文本。再对返回的结果进行适当的处理就可以得到比较实用的数据了!

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

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

相关文章

“AS3.0高级动画编程”学习:第二章转向行为(下)

在上一篇里&#xff0c;我们学习了“自主角色”的一些基本行为&#xff1a;寻找(seek)、避开(flee)、到达(arrive)、追捕(pursue)、躲避(evade)、漫游(wander)。这一篇将继续学习其它更复杂&#xff0c;更高级的行为。 一、对象回避(object avoidance) 对象回避的正式解释为&am…

solor mysql_solr 同步 mysql

一、首先创建一个数据库和表这里创建了一个表&#xff0c;加上了测试数据&#xff0c;注意这里有一个字段来记录更新时间 update_date二、修改配置文件我们首先介绍全量同步&#xff0c;再介绍增量同步我的 solr 版本是 7.5 的&#xff0c;new_core是我创建的 core&#xff0c…

java canvas 缩放图片_详解如何用HTML5 Canvas API控制图片的缩放变换

摘要&#xff1a;这篇HTML5栏目下的“详解如何用HTML5 Canvas API控制图片的缩放变换”&#xff0c;介绍的技术点是“html5_canvas、canvas、Html5、控制图片、api、图片”&#xff0c;希望对大家开发技术学习和问题解决有帮助。缩放变换scale(sx,sy)传入两个参数&#xff0c;分…

向周鸿祎的360安全浏览器学互联网产品运营和推广

做互联网产品运营就要像周鸿祎一样&#xff0c;老周一直是运营流的大力倡导者&#xff0c;而360安全浏览器则是老周给我们上的产品运营又一课&#xff0c;醍醐灌顶&#xff0c;如梦初醒。 下图是截止到今年6月中国网民的浏览器使用情况图&#xff1a; 根据CNZZ的数据&#xff0…

java中的locksupport_java中线程的停止以及LockSupport工具类

看jstack输出的时候&#xff0c;可以发现很多状态都是TIMED_WAITING(parking)&#xff0c;如下所示&#xff1a;"http-bio-8080-exec-16" #70 daemon prio5 os_prio0 tid0x00007f6088027800 nid0x3a1f waiting on condition [0x00007f60fcd03000]java.lang.Thread.St…

深入react技术栈(8):事件系统

我是歌谣 放弃很容易 但是坚持一定很酷 微信公众号搜索前端小歌谣获取前端知识 1合成事件的绑定方式 2合成事件的实现机制 3在React中使用原生事件 4合成事件和原生事件混用 5对比react与原生事件 文章参考深入React技术栈

java mac jconsole_解决java maven项目找不到jconsole-1.8.0.jar和tools-1.8.0.jar包问题

今天遇到了这样一种情况&#xff0c;自己的maven项目中并没有引用的jar包出现在了Maven Dependencies的依赖包中。而我在pom.xml自己没有没有引入啊.图示怀疑是自己的alibaba 的druid所依赖的包&#xff1a;com.alibabadruid1.0.14然后查看了它的相关依赖&#xff0c;果然找到了…

PyRun_SimpleString的无穷怨念

From: http://blog.csdn.net/ccat/article/details/544491 好吧&#xff0c;我承认我是个菜鸟&#xff0c;所以今天我勇敢的站出来接受大家的鄙视…… 话说早上同事喊我帮他改段程序&#xff0c;很简单&#xff0c;就是用PyRun_SimpleString函数执行一段Python脚本。错误也很直…

cisco 交换机vlan-trunk的配置详解及应用实例:

虚拟局域网&#xff08;vlan&#xff09;&#xff1a;主要是为了分割广播域注&#xff1a;不同vlan之间不能相互通信。trunk&#xff1a;主要是为了不同交换机的相同vlan相互通信配置静态VLAN的步骤:************************************1.创建VLAN1)VLAN数据库配置模式:Switc…

java 登录拦截器_springMVC 拦截器-用户登录拦截实战

各位小伙伴咱们继续学习新知识今天要分享的就是拦截器不知道小伙伴们平时上网的时候有没有注意到,尤其是上网购物的时候,不登录账号,就无法访问一些功能页面,比如你不登录账号,就没法查看购物车里面有什么物品.这就是拦截器起到的作用.那么今天我们就来给之前的项目添加一个拦截…

java和node.js 2018_node.js在2018年能继续火起来吗?我们来看看node.js的待遇情况

你知道node.js是怎么火起来的吗&#xff1f;你知道node.js现在的平均工资是多少吗&#xff1f;你知道node.js在2018年还能继续火吗&#xff1f;都不知道&#xff1f;那就来看文章吧&#xff0c;多学点node.js&#xff0c;说不定以后的你工资就会高于nodejs的平均工资了&#xf…