我是靠谱客的博主 踏实诺言,最近开发中收集的这篇文章主要介绍使用WebSphere配置连接池,Spring使用JNDI方式获取连接,使用JdbcTemplate报错,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

问题描述:
       使用websphere 配置数据库连接池,在spring 中使用jndi的方式获取连接,程序中使用jdbcTemplate操作数据,添加或删除一条数据时,第一次添加成功,第二次添加报错,连续再添加依然报错,过几分钟,操作删除,有可能成功,有可能不成功。并且可以保证程序无问题,开发时是采用tomcat做服务器的,Spring中连接配置是采用直连的,就无任何问题。
代码:
     applicationContext.xml
    <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean" lazy-init="default" autowire="default" dependency-check="default" >
          <property name="jndiName">
                 <value>java:comp/env/jdbc/hxcc</value>
          </property>
    </bean>

   <bean id="custInfoDAO" class="com.cupdata.cif.dao.CustInfoDAOImpl">
        <property name="dataSource">
             <ref bean="dataSource" />
        </property>
        <property name="searchHelper">
             <ref bean="searchHelper" />
        </property>
  </bean>
 

  CustInfoDAOImpl.java

  JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);


  jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter(){

      public int getBatchSize() {
            return listCustInfo.size(); 
      }

     public void setValues(PreparedStatement ps, int i) throws SQLException {
          ps.setString(1, listCustInfo.get(i).getKeytype());
          ps.setString(2, listCustInfo.get(i).getCustid());
          ps.setString(3, listCustInfo.get(i).getCusttype());
     }

 });

 

 

错误描述:

 

java.lang.NullPointerException
 at oracle.jdbc.dbaccess.DBData.clearItem(DBData.java:431)
 at oracle.jdbc.dbaccess.DBDataSetImpl.clearItem(DBDataSetImpl.java:3528)
  at oracle.jdbc.driver.OraclePreparedStatement.clearParameters(OraclePreparedStatement.java:3401)
 at com.ibm.ws.rsadapter.jdbc.WSJdbcConnection.resetStatement(WSJdbcConnection.java:2417)
 at com.ibm.ws.rsadapter.jdbc.WSJdbcConnection.prepareStatement(WSJdbcConnection.java:2065)
  at com.ibm.ws.rsadapter.jdbc.WSJdbcConnection.prepareStatement(WSJdbcConnection.java:2017)
 at org.springframework.jdbc.core.JdbcTemplate$SimplePreparedStatementCreator.createPreparedStatement(JdbcTemplate.java:1114)
 at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:470)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:505)
 at org.springframework.jdbc.core.JdbcTemplate.batchUpdate(JdbcTemplate.java:769)
 at com.cupdata.cif.dao.CustInfoDAOImpl.addCustMainInfo(CustInfoDAOImpl.java:84)
at com.cupdata.cif.manager.CustInfoManagerImpl.addCustMainInfo(CustInfoManagerImpl.java:41)
 at com.cupdata.cif.manager.CustInfoManagerImpl$$FastClassByCGLIB$$a0ccfc8a.invoke(<generated>)
 at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:149)
at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:698)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:148)
 at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:170)
at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:643)
at com.cupdata.cif.manager.CustInfoManagerImpl$$EnhancerByCGLIB$$172567a9_2.addCustMainInfo(<generated>)
at com.cupdata.cif.action.CustInfoAction.addCustMainInfo(CustInfoAction.java:62)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:79)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:618)
at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:280)
at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:216)
at org.springframework.web.struts.DelegatingActionProxy.execute(DelegatingActionProxy.java:106)
at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:484)
at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:274)
 at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1482)
at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:525)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:763)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:856)
at com.ibm.ws.cache.servlet.ServletWrapper.serviceProxied(ServletWrapper.java:282)
 at com.ibm.ws.cache.servlet.CacheHook.handleFragment(CacheHook.java:459)
 at com.ibm.ws.cache.servlet.CacheHook.handleServlet(CacheHook.java:265)
at com.ibm.ws.cache.servlet.ServletWrapper.service(ServletWrapper.java:262)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1075)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1016)
 at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:145)
at net.ed.cc.common.struts.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:138)
at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:190)
at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:130)
at com.ibm.ws.webcontainer.filter.WebAppFilterChain._doFilter(WebAppFilterChain.java:87)
 at com.ibm.ws.webcontainer.filter.WebAppFilterManager.doFilter(WebAppFilterManager.java:771)
at com.ibm.ws.webcontainer.filter.WebAppFilterManager.doFilter(WebAppFilterManager.java:679)
at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:546)
at com.ibm.ws.wswebcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:478)
 at com.ibm.ws.webcontainer.servlet.CacheServletWrapper.handleRequest(CacheServletWrapper.java:90)
at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:744)
 at com.ibm.ws.wswebcontainer.WebContainer.handleRequest(WebContainer.java:1455)
at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:115)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:458)
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewInformation(HttpInboundLink.java:387)
at com.ibm.ws.http.channel.inbound.impl.HttpICLReadCallback.complete(HttpICLReadCallback.java:102)
 at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:165)
 at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)
at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)
at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:136)
at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:195)
at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:743)
at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:873)
 at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1473)

 

表面上看是空指针错误,但程序中根本就没有空指针

   at com.cupdata.cif.dao.CustInfoDAOImpl.addCustMainInfo(CustInfoDAOImpl.java:84)
84行就是 jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter(){ ....

 

datasource不为空,jdbcTemplate也不为空

 

问题已解决:

               方法一:将Websphere的数据源配置属性中的“sql的最高缓存数”改为0可解决问题

               方法二:升级OJDBC.jar包,低版本中的 DBData.clearItem(int i) 方法存在bug

最后

以上就是踏实诺言为你收集整理的使用WebSphere配置连接池,Spring使用JNDI方式获取连接,使用JdbcTemplate报错的全部内容,希望文章能够帮你解决使用WebSphere配置连接池,Spring使用JNDI方式获取连接,使用JdbcTemplate报错所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部