ANT 操控 ORACLE数据库实践
Ant
执行系统命令没有任何问题,这次实际系统命令中可以说遇到了两个问题,一个是启动服务的命令是含有空格的,第二个如何备份数据库可以自动加上日期。
首先,我们启动oracle数据库,操作有两个:
1.启动监听:
<exec
executable="lsnrctl" >
<arg line=" start
"/>
</exec>
2.打开数据库实例:
<exec
executable='cmd' >
<arg line="/c net start
oracleservice${ORA_SID}
"/>
</exec>
第一个操作在这里没有什么区别,就是ant调用系统命令的标准用法,我们来看一下第二个命令,
net start
oracleservice${ORA_SID},如果你直接放入到executable属性中,执行结果一定会是:
BUILD FAILED:
E:\java\TestAnt\build.xml:44: Execute failed: java.io.IOException:
CreateProcess: "net start oracleservicemy_oracle"
error=2
痛苦吧,带有空格的命令应该使用以下方法:
<exec executable='cmd'
>
<arg line="/c net start oracleservice${ORA_SID}
"/>
</exec>
如果在备份数据库的时候加上时间标记,我在linux下面使用教本备份oracle数据库,可以使用data
命令很方便的在备份的文件上面加上日期后缀,ant可以么?
我查了很多资料,终于搞定:
<tstamp>
<format
property="DB_BACKUP_TIME"
pattern="yyyy-MM-dd"/>
</tstamp>
使用 tstamp
target可以非常方便的定义日期属性,这样再生成需要备份文件的名字,方便的解决你的问题。
Ok,你可以参考完成的ant脚本:
附录:参考脚本
<!--
2005 by guipei. -->
<project
name="TestAntOracle" default="demo" basedir="./">
<!-- set
global properties for this build -->
<property
name="DB_BACKUP_DIR" value="." />
<property name="ORA_SID"
value="my_oracle"/>
<property name="ORA_USER"
value="scott"/>
<property name="ORA_PWD"
value="tiger"/>
<property name="ORA_RESTORE_FILE"
value="db_back.dmp"/>
<target name="demo"
>
<echo> ant db_backup to backup db
</echo>
<echo> ant db_restore to restore db
</echo>
<echo> ant db_start to start db
</echo>
<echo> ant db_stop to stop db
</echo>
</target>
<target
name="db_backup">
<tstamp>
<format
property="DB_BACKUP_TIME"
pattern="yyyy-MM-dd"/>
</tstamp>
<property
name="DB_BACKUP_FILE" value="MYDB_${DB_BACKUP_TIME}.DMP"
/>
<echo>will backup db at
${DB_BACKUP_FILE}</echo>
<exec dir="${DB_BACKUP_DIR}"
executable="exp" >
<arg line="
${ORA_USER}/${ORA_PWD}@${ORA_SID}
file=MYDB_${DB_BACKUP_TIME}.DMP "/>
</exec>
</target>
<target
name="db_restore">
<exec dir="${DB_BACKUP_DIR}"
executable="imp" >
<arg line="
${ORA_USER}/${ORA_PWD}@${ORA_SID} file=${ORA_RESTORE_FILE}
full=y"/>
</exec>
</target>
<target
name="db_start">
<exec executable="lsnrctl"
>
<arg line=" start
"/>
</exec>
<exec executable='cmd'
>
<arg line="/c net start
oracleservice${ORA_SID} "/>
</exec>
</target>
<target
name="db_stop">
<exec executable="lsnrctl"
>
<arg line=" stop
"/>
</exec>
<exec executable='cmd'
>
<arg line="/c net stop
oracleservice${ORA_SID} "/>
</exec>
</target>
</project>
http://blog.csdn.net/wgw335363240/article/details/6941435
利用Ant向数据库插入数据
ANT 操控 ORACLE数据库实践的更多相关文章
- Oracle数据库测试和优化最佳实践: OTest介绍 (转)
当前Oracle数据库最佳测试工具OTest * Otest是用于Oracle数据库测试.优化.监控软件. * Otest是免费提供给Oracle客户和广大DBA工程师使用的软件.由原厂技术专家王 ...
- Oracle数据库基础知识
oracle数据库plsql developer 目录(?)[-] 一 SQL基础知识 创建删除数据库 创建删除修改表 添加修改删除列 oracle cascade用法 添加删除约束主键外 ...
- Java连接oracle数据库的OCI和THIN
使用jdbc连接上oracle有两种方法: 1. 使用thin连接 由于thin驱动都是纯Java代码,并且使用TCP/IP技术通过java的Socket连接上Oracle数据库,所以thin驱动是与 ...
- 细说Oracle数据库与操作系统存储管理二三事
在上大学的时候,学习操作系统感觉特别枯燥,都是些条条框框的知识点,感觉和实际应用的关联不大.发现越是工作以后,在工作中越想深入了解,发现操作系统知识越发重要.在实践中结合理论还是不错的一种学习方法.自 ...
- Windows server2008 搭建ASP接口访问连接oracle数据库全过程记录--备用
真的是太不容易了,以前的时候在window server 2003上面搭建了一套asp+oracle的接口系统,就费了好大的劲儿,其实那会迷迷瞪瞪的也不知道怎么的就弄好了,也懒得管了.OK,从昨天到今 ...
- 浅谈Oracle数据库性能优化的目标
Oracle性能优化保证了Oracle数据库的健壮性,为了保证Oracle数据库运行在最佳的性能状态下,在信息系统开发之前就应该考虑数据库的优化策略.从数据库性能优化的场景来区分,可以将性能优化分为如 ...
- [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了
[译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了 本文首发自:博客园 文章地址: https://www.cnblogs.com/yilezhu/p/ ...
- Java连接oracle数据库的两种常用方法
1. 使用thin连接 由于thin驱动都是纯Java代码,并且使用TCP/IP技术通过java的Socket连接上Oracle数据库,所以thin驱动是与平台无关的,你无需安装Oracle客户端,只 ...
- Oracle 数据库备份和恢复配置
可能的失败及其解决方法 失败类型 我们坑你遇到的失败或错误分为两大类:物理和逻辑.物理错误一般是硬件错误或使用数据库的应用程序中的软件错误,而逻辑错误一般在终端用户级别(数据库用户和管理员). 按从轻 ...
随机推荐
- js--性能优化(转)
前言 一直在学习javascript,也有看过<犀利开发Jquery内核详解与实践>,对这本书的评价只有两个字犀利,可能是对javascript理解的还不够透彻异或是自己太笨,更多的是自己 ...
- c语言正则表达式
标准的C和C++都不支持正则表达式,但有一些函数库可以辅助C/C++程序员完成这一功能,其中最著名的当数Philip Hazel的Perl-Compatible Regular Expression库 ...
- Linux入门(二)Linux基本命令及基本操作
1 常用Linux命令 图形界面进入到字符界面: ctrl+alt+F2~F6 字符界面进入到图形界面:ctrl +alt+F7 查看本机ip: ifconfig (windows是:ipconf ...
- 浏览器差异性hack
1 js函数 很多人误以为数组 push 方法拼接字符串会比 += 快,要知道这仅仅是 IE6-8 的浏览器下. 实测表明现代浏览器使用 += 会比数组 push 方法快,而在 v8 引擎中,使用 + ...
- 字符串匹配—KMP 扩展KMP Manacher
kuangbin字符串专题传送门--http://acm.hust.edu.cn/vjudge/contest/view.action?cid=70325#overview 算法模板: KMP: ; ...
- 如何提升 CSS 选择器性能
CSS 选择器性能损耗来自? CSS选择器对性能的影响源于浏览器匹配选择器和文档元素时所消耗的时间,所以优化选择器的原则是应尽量避免使用消耗更多匹配时间的选择器.而在这之前我们需要了解CSS选择器匹配 ...
- 关于逆波兰式的c++实现
正常的表达式 逆波兰表达式 a+b ---> a,b,+ a+(b-c) ---> a,b,c,-,+ a+(b-c)*d ---> a,b,c,-,d,*,+ a+d*(b-c)- ...
- jQuery 事件 - bind() 方法
定义和用法 bind() 方法为被选元素添加一个或多个事件处理程序,并规定事件发生时运行的函数. 实例1(一个事件) 记得把js引用地址换掉 当点击鼠标时,隐藏或显示 p 元素: <html&g ...
- 如何在Eclipse和MyEclipse中安装SVN
在安装目录下,找到dropins文件夹将svn文件复制进去.
- 浅谈 zookeeper 原理,安装和配置
当前云计算流行, 单一机器额的处理能力已经不能满足我们的需求,不得不采用大量的服务集群.服务集群对外提供服务的过程中,有很多的配置需要随时更新,服务间需要协调工作,那么这些信息如何推送到各个节点?并且 ...