/ / Що не так з моєю конфігурацією Spring та Hibernate? - xml, hibernate, spring, hibernate3

Що трапилось з конфігурацією моєї весни та глибокого сну? - xml, hibernate, spring, hibernate3

Що сталося з цією конфігурацією? Я використовую Spring 3 і Hibernate 3.6 і намагаюся налаштувати використання DAO. Я бачу дві помилки в hibernate.cfg.xml.

Перший на тезі сеансу-фабрики

 The content of element type "session-factory" must match
"(property*,mapping*,(class-cache|collection-cache)*,event*,listener*)".

Другий - на імені властивості = "dataSource" - тег-

The content of element type "property" must match "null".

application-context.xml

    <?xml version="1.0" encoding="utf-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<bean id="dataSource"
class="org.apache.tomcat.dbcp.dbcp.BasicDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost/projectName</value>
</property>
<property name="username">
<value>uname</value>
</property>
<property name="password">
<value>pass</value>
</property>
<!-- Disable the second-level cache  -->
<!-- Echo all executed SQL to stdout -->
</bean>
</beans>

hibernate.cfg.xml

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- Database connection settings -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
</bean>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- Disable the second-level cache  -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property>
<property name="transaction.factory_class">
org.hibernate.transaction.JDBCTransactionFactory
</property>
<property name="current_session_context_class">
thread
</property>
<mapping class="com.projectname.model.name"/>
<mapping class="com.projectname.model.stuff"/>
</session-factory>
</hibernate-configuration>

Відповіді:

2 для відповіді № 1

Ви змішували конфігурації Hibernate і Spring. Вони цілком відокремлені. Ви не можете використовувати Spring beans в конфігурації Hibernate.

Для цього потрібно перейти до налаштувань Spring:

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource"/>
</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- Disable the second-level cache  -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property>
<property name="transaction.factory_class">
org.hibernate.transaction.JDBCTransactionFactory
</property>
<property name="current_session_context_class">
thread
</property>
</bean>

Можливо, я помиляюся над дрібницями, оскільки зазвичай використовую конфігурацію анотацій, але ви повинні повернутися до документації.