定时任务update锁表问题

今天用Quartz搞一个定时查询并更新表的Job。碰到一个更新总是锁表的问题。直到现在还不明白。最后把执行的操作都放到一个事务中,在执行外用com.commit()为提交,解决了问题,操作不再锁表。

今天只写两行不过瘾,还是多写几行。参照别人的已经写好的这个定时器框架功能,之所以称之为框架,是因为,它是由表加一些共用类加quartz包来构建成:在表中插入执行的Job类名称,执行的expression,还有Job group(不知道有什么用)。它提供配置了Servlet加载表中的数据,实例这些Job类,并加入Schedule。大概是这样,个人觉得这样做还挺好,至少很简单,我之前想再引入Spring,因为这个配置简单,不过这需要引用别的包,觉得还是前者好些。

回到开始主题,不明白,为什么statement的execute()或者executUpdate()会锁表呢,表象就是执行完后,con都已经关闭了,但是我用另个一外界面操作表,却一直等待直到超时。试过把update去掉,则不会出现上述问题。找来找去,无答案,最后试着用事务提交的方式,竟然可以了,真是无语。JDBC的机制有机会还是要好好学习一下。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值