在桌面上创建了一个倒计时60秒关机的bat处理文件,脚本为:shutdown -s -t 60
又创建了一个取消关机的批处理文件:shutdown -a
两个文件起初都是随便命名的,某天,使用Foobar的scheduler来调用关机批处理,觉得批处理的名字不好,
重命名了一下,遂改为shutdown.bat,取消关机改为Cancle.bat
神秘现象出现了,运行这两个批处理时均出现刷屏现象,百思不的其解,
后看了一篇文章明白了怎么回事:
原来是重命名为保留关键字惹的祸,看来以后重命名任何东西都要小心,最好用汉语,哈哈。
bat文件执行数据导出(exp)的刷屏现象
2010-03-28 14:45:26| 分类: oracle | 标签: |字号大中小 订阅
今天批量导出指定表的数据时,写成了一个bat文件,文件名为exp.bat。双击bat文件后,屏幕出现刷屏现象,数据无法导出。
bat文件如下:
exp user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000
exp user/password@db tables=LOST file=d:\LOST.dmp buffer=1024000
exp user/password@db tables=TRANS file=d:\TRANS.dmp buffer=1024000
。。。。。。。。。。。
双击后bat文件出现刷屏现象,屏幕一直输出第一句导出语句,数据无法导出。
E:\>exp user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000
E:\>exp user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000
。。。。。。。。。。。
单独copy一条语句,放到cmd下运行。导出成功。到底是什么问题,确实让人疑惑。。。。
修改bat文件,在文件中指定exp 路径。
E:\oracle\product\10.2.0\client_1\BIN\exp.exe user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000
E:\oracle\product\10.2.0\client_1\BIN\exp.exe user/password@db tables=LOST file=d:\LOST.dmp buffer=1024000
E:\oracle\product\10.2.0\client_1\BIN\exp.exe user/password@db tables=TRANS file=d:\TRANS.dmp buffer=1024000
。。。。。。。。。。。
双击文件导出成功。
到这问题似乎已解决,但这究竟是什么原因呢?况且以前导出也没出现过这种情况啊。。。
好,下面来测试一下,修改exp.bat文件,增加一个暂停操作。在第一行添加pause,让文件一运行就先暂停。如下
pause
exp user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000
exp user/password@db tables=LOST file=d:\LOST.dmp buffer=1024000
exp user/password@db tables=TRANS file=d:\TRANS.dmp buffer=1024000
。。。。。。。。。。。
双击bat文件,屏幕输出红色部分。按键后输出蓝色部分,继续按输出黑色部分。
d:\我的文档\桌面>pause
请按任意键继续. . .
d:\我的文档\桌面>exp user/password@db tables=STAT file=d:\STAT.dmp buffer=102400
0
d:\我的文档\桌面>pause
请按任意键继续. . .
d:\我的文档\桌面>exp user/password@db tables=STAT file=d:\STAT.dmp buffer=102400
0
d:\我的文档\桌面>pause
请按任意键继续. . .
好,终于发现了,只写了一个暂停,可这bat文件在不停的暂停。暂停被循环调用了。
原来执行到pause后,我们按任意键,会执行下一个语句“exp user/password@db tables=STAT file=d:\STAT.dmp buffer=1024000”,但是调用exp命令时,不是调用oracle目录下的exp.exe。而是调用我的exp.bat,所以再次进入了暂停,形成了死循环。
这就是为啥出现了刷屏的现象。。。(这也好,以后想刷屏的话。把这脚本拿出来就行了。哈)
谨记规范命名,不能再写成exp.bat