您的位置:首页 > 编程语言 > Java开发

JAVA程序在windows计划任务里执行的问题

2014-05-15 08:40 369 查看
写了一个简单的JAVA类,定时从一个ORACLE数据库取数据放到另一个mysql数据库中,写了一个脚本如下:

set classpath=.;%classpath%;./classes12.jar;./mysql-connector-java-5.1.6-bin.jar

set path=%path%;D:\develop\Java\jdk1.6\bin

set JAVA_HOME=D:\develop\Java\jdk1.6

cd E:\workfile\SAP-to-MYSQL

java getsapdata >>getsapdata.log

手动执行的时候完全没有问题,当时加到windows计划任务里就是执行不成功,程序执行的DOS窗口一闪而过,也看不到是什么错误,网上搜了半天,也没找到可行的答案,后来在脚本里加入了延迟语句 ping -n 5 127.1>nul,才看到报的是找不到类的错误:

Exception in thread "main" java.lang.NoClassDefFoundError: getsapdata

Caused by: java.lang.ClassNotFoundException: getsapdata

at java.net.URLClassLoader$1.run(URLClassLoader.java:202)

at java.security.AccessController.doPrivileged(Native Method)

at java.net.URLClassLoader.findClass(URLClassLoader.java:190)

at java.lang.ClassLoader.loadClass(ClassLoader.java:307)

at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301

at java.lang.ClassLoader.loadClass(ClassLoader.java:248)

Could not find the main class: getsapdata. Program will exit.

明明就在这个目录下,怎么就找不到呢,迷惑,又是一阵搜索,还是没答案,想着难道windows定时任务挑分区吗,就把程序挪到C盘,结果计划任务真的执行成功了,那是怎么回事呢,想想找不到类怎么也应该是环境变量路径类的问题吧,后来想到我以前经常用DOS窗口敲命令,打开DOS窗口默认在C盘,而我的应用一般都在其他分区,所以每次敲命令比如:cd e:\work\shell,运行完后当前路径并没有改变,必须再敲一下e:,才进入到e:\work\shell目录,会不会是windows计划任务开启DOS执行窗口也是默认在C盘,我虽然在脚本里加了 cd
E:\workfile\SAP-to-MYSQL命令,但实际上系统的当前路径还是会在默认的C:\Users\Administrator 目录下,我的程序移动到C盘的时候,因为系统默认路径也在C盘,所以 cd 命令是成功进入了c盘的我的应用程序目录,但不是C盘的就不行了,网上查了下,原来cd 的时候加个 /d 参数可以直接改变盘符,哎,以前居然一致没用过,把脚本中的 cd 命令改为 cd
/d E:\workfile\SAP-to-MYSQL 后,再次执行计划任务则执行成功。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: