专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > 软件架构设计

Spring自动安装(autowire)导致quartz不能运行

发布时间:2011-06-20 02:08:02 文章来源:www.iduyao.cn 采编人员:星星草
Spring自动装配(autowire)导致quartz不能运行
http://jolestar.iteye.com/blog/296780

在spring中配置了一个简单的quartz任务,结果报错:
Java代码 
Failure obtaining db row lock: 第 1 行: 只有 DECLARE CURSOR 才允许使用 FOR UPDATE 子句。 
 
只有 DECLARE CURSOR 才允许使用 FOR UPDATE 子句 
 
at net.sourceforge.jtds.jdbc.SQLDiagnostic.addDiagnostic(SQLDiagnostic.java:368)  
    at net.sourceforge.jtds.jdbc.TdsCore.tdsErrorToken(TdsCore.java:2816)  
    at net.sourceforge.jtds.jdbc.TdsCore.nextToken(TdsCore.java:2254)  
    at net.sourceforge.jtds.jdbc.TdsCore.getMoreResults(TdsCore.java:631)  
    at net.sourceforge.jtds.jdbc.JtdsStatement.executeSQLQuery(JtdsStatement.java:477)  
    at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.executeQuery(JtdsPreparedStatement.java:777)  
    at org.apache.commons.dbcp.DelegatingPreparedStatement.executeQuery(DelegatingPreparedStatement.java:91)  
    at org.quartz.impl.jdbcjobstore.StdRowLockSemaphore.executeSQL(StdRowLockSemaphore.java:92)  


很郁闷,以为是事务控制的问题。
结果最后发现是自动配置(quartz)的问题。

spring的SchedulerFactoryBean中有个dataSource属性。如果这个属性不为空,则用数据库来持久化储存quartz的任务。结果正好我的spring中的DataSource的名字就叫dataSource,结果就导致了上面的错误。

这个哥们也遇到了同样的问题:
http://www.iteye.com/topic/38871

所以spring的autowire还是尽量少用为好。

--------------------------------------------
去掉beans的default-autowire="byName"属性就可以了。
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: