1. 程式人生 > >Spring-mybatis整合 獲取properties 建立SQLSessionFactory失敗

Spring-mybatis整合 獲取properties 建立SQLSessionFactory失敗

程式碼:

<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/test" />
<property name="username" value="root" />
<property name="password" value="root" />
</bean>

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation" value="/mybatis.xml" />
</bean>

測試類:

輸出結果:


如果想載入properties 配置檔案的方式讀取 dataSource Bean:


這時,你會發現沒有問題;會得到資料庫連線,但是加上SQLSessionFactory的話就會報錯:


報錯資訊:


提示很明顯:建立初始化的SQLSessionFactory失敗,因為dataSource載入失敗!!什麼原因呢?

找了好久終於發現:

MapperScannerConigurer實際是在解析載入bean定義階段的,這個時候要是設定sqlSessionFactory的話,會導致提前初始化一些類,這個時候,PropertyPlaceholderConfigurer還沒來得及替換定義中的變數,導致把表示式當作字串複製了,解決的辦法如下:

方法一:

修改<property name="sqlSessionFactory" ref="sqlSessionFactory"/>為

<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>

原理:使用sqlSessionFactoryBeanName注入,不會立即初始化sqlSessionFactory, 所以不會引發提前初始化問題。

方法二:

直接刪掉<property name="sqlSessionFactory" ref="sqlSessionFactory"/>

注意:在沒有配置這一行時,必須配置一個以sqlSessionFactory命名的org.mybatis.spring.SqlSessionFactoryBean。

自己試試吧,希望能幫到你們!