2014-03-31 100 views
1

我正在使用spring jdbc進行數據庫連接。每次運行我的測試java類spring時,上下文也會每次加載。任何建議?爲什麼每次都加載spring應用上下文

我的代碼片斷低於,

appContext.xml:

<?xml version="1.0" encoding="utf-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 
    xsi:schemaLocation=" 
      http://www.springframework.org/schema/beans 
      http://www.springframework.org/schema/beans/spring-beans-2.0.xsd 
      http://www.springframework.org/schema/context 
      http://www.springframework.org/schema/beans/spring-context-2.0.xsd "> 

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> 
     <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
     <property name="url" value="jdbc:mysql://localhost:3306/3i" /> 
     <property name="username" value="xxx" /> 
     <property name="password" value="xxx" /> 
    </bean> 

    <bean id="jdbcTemp" class="org.springframework.jdbc.core.JdbcTemplate"> 
     <property name="dataSource" ref="dataSource"> 
     </property> 
    </bean> 
</beans> 

Java類:

package com.pinovus.dbconnection; 

import org.springframework.context.ApplicationContext; 
import org.springframework.context.support.ClassPathXmlApplicationContext; 
import org.springframework.jdbc.core.JdbcTemplate; 

public class DbDao { 

    private static JdbcTemplate jdbctemplate; 
    private static ApplicationContext appcontext; 

    public JdbcTemplate getJdbctemplate() { 

     ApplicationContext cx = new ClassPathXmlApplicationContext(
       "appContext.xml"); 
     jdbctemplate = (JdbcTemplate) cx.getBean("jdbcTemp"); 
     return jdbctemplate; 
    } 

    public void setJdbctemplate(JdbcTemplate jdbctemplate) { 
     this.jdbctemplate = jdbctemplate; 
    } 

    /** 
    * @param args 
    */ 
    public static void main(String[] args) { 
     // TODO Auto-generated method stub 

    } 

} 

和測試Java類:

package com.pinovus.dbconnection; 

import org.springframework.jdbc.core.JdbcTemplate; 
import org.springframework.jdbc.support.rowset.SqlRowSet; 

public class test { 

    public static void main(String[] args) { 
     // TODO Auto-generated method stub 
     JdbcTemplate jt = new DbDao().getJdbctemplate(); 
     String qry = "select role from accounts"; 
     SqlRowSet rs = jt.queryForRowSet(qry); 
     while (rs.next()) { 
      System.out.println(rs.getString(1)); 
     } 
    } 
} 
+0

您正在調用每次加載spring上下文的'getJdbctemplate()'。你想要它做什麼? – jervine10

+0

現在我明白了它的代碼問題,每次我調用getJdbctemplate()方法 – jasim

回答

1

你的DAO不應該知道的應用程序上下文,不應該明確它仰視的東西。你可以把它改寫使用the Spring documentation爲例:

public class DbDaoImpl implements DbDao { 

    private JdbcTemplate jdbcTemplate; 

    public void setDataSource(DataSource dataSource) { 
     this.jdbcTemplate = new JdbcTemplate(dataSource); 
    }  
    ... 
} 

,你可以刪除應用程序上下文XML的jdbcTemp條目。取而代之的是使DAO Spring管理,爲它創建一個條目,如下所示:

<bean id="dbDao" class="DbDaoImpl"> 
    <property name="dataSource" ref="dataSource"/> 
</bean> 
+0

感謝您的答案,但我必須這樣做用DriverManager – jasim

+0

@jasim:??我沒有說不使用DriverManager。讓你的Dao成爲一個春季管理的豆子。 –

0

這是因爲你創造新的我nstance每次:

new DbDao().getJdbctemplate(); 

,並進一步:

new ClassPathXmlApplicationContext("appContext.xml"); 

這不是春天的一個問題。這取決於你的設計。

我不知道該如何幫助你,因爲它只是正確的Java代碼:無論如何,在public static void main(String[] args)的情況下,你必須實例化對象來處理它們。

請提供更多信息哪裏都是你的疑惑

+0

好了,現在我明白了問題,如何在每次運行程序時加載彈簧上下文 – jasim

+0

對不起:您對Java有多少了解?當運行程序('java com.pinovus.dbconnection.test')每次它不僅創建上下文,但甚至啓動JVM –

+0

對不起我的愚蠢問題,我必須學習更多 – jasim

相關問題