定时任务update锁表问题

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

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

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

你可能感兴趣的:(数据库)