快速业务通道

在JAVA端使Oracle存储过程串行地执行 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-15
去申请,释放锁,在java端也可以使用模板模式,假设子类实现execute方法来完成需要串行化执行的存储过程,这时要注意我们可能会将connection传入到子类的execute方法中,但是子类却不能将connection关闭掉,因为我们还需要在execute方法执行完后会用它来释放锁。当然如果子类真的把物理的connection关闭掉也没有问题,但是现在我们大都使用connection pool,把connection返回给pool的时候,session的锁资源并没有清除。这样还需要将传入到子类execute方法的connection封装一下,或者叫装饰一下,我们有两种解决方法:

·oonnection wrapper的close并不关闭连接或者返回给pool。

·connection wrapper的close方法关闭连接,但是需要在关闭连接之前释放锁,然后在抽象父类的方法中只需判断connection是否close掉,connection.isClosed()方法,如果没有close就调用wrapeer的close方法,既释放锁又关闭连接。

总结一下:lock放在java端会出现意外的情况,锁就必须放在db端,为了避免对已有存储过程代码的侵入性,可以使用wrapper存储过程,由于动态执行存储过程传递参数是个难题,所以还是把锁的申请,释放放在了java端,也避免了对已有存储过程代码的侵入性,同时又懒得每次都去申请锁,释放锁,可以在java端使用模板模式,但是使用模板模式时又怕子类不小心关了connection,而没释放锁,就将connection封装了一下,将这个被封装后的connection传到了子类的execute方法中。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号