本实战是博主初次学习Java,分析WCP源码时,学习HibernateTools部分的实战,由于初次接触,难免错误,仅供参考,希望批评指正。
开发环境: Eclipse Version: Photon Milestone 6
WCP:http://www.wcpdoc.com/home/Pubindex.html
目录:
Hibernate自动生成(1)
Hibernate自动生成(2)
在第一部分,已经生成了实体对象,现在我们正式使用。
1.把刚才的test项目重构改名,wcp-tpmember, 建立包 com.farm.member.Dao
博主本次需要链接第二个数据库MSSQL,需要新建一个SessionFactory,以下步骤并没有顺序。
2.这个静态方法手动向bean获取实例。(这步现在不做也没事,我还不知道这个类什么时候用)
参考HibernateSeesionFactory.java 新建HibernateSeesionFactoryForMSSQL.java
3.配置jdbc
4.加一个方言:
hibernate.dialectsql
org.hibernate.dialect.SQLServer2008Dialect
5.XML文件配置
在hibernate配置文件spring-hibernate.xml中增加一个sessionFactorymssql
<!-- MSSQL的sessionFactory 添加:陆慧 --> <bean id="sessionFactorymssql" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSourcemssql" /> <!-- 注意这里的ref名字 --> <property name="packagesToScan"> <list> <!-- 可以加多个包 --> <value>com.farm</value> <value>com.manor</value> <value>org.sdkj</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop> <prop key="hibernate.dialect">${hibernate.dialectsql}</prop> <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> <!-- <prop key="hibernate.current_session_context_class">thread</prop> --> </props> </property> </bean> <!-- MSSQL的数据库映射- 添加:陆慧 --> <bean id="dataSourcemssql" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="${jdbc.mssqldriverClassName}" /> <property name="url" value="${jdbc.mssqlurl}" /> <property name="username" value="${jdbc.mssqlusername}" /> <property name="password" value="${jdbc.mssqlpassword}" /> </bean> <!-- 配置Hibernate事务管理器 添加:陆慧 --> <bean id="transactionManagermssql" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactorymssql" /> </bean>
主配置文件spring-mvc.xml中增加一个 transactionManagermssql
<context:component-scan base-package="com.farm,com.manor,org.sdkj" /> <!-- 基于注释的事务,当注释中发现@Transactional时,使用id为“transactionManager”的事务管理器 --> <!-- 如果没有设置transaction-manager的值,则spring以缺省默认的事务管理器来处理事务,默认事务管理器为第一个加载的事务管理器 --> <tx:annotation-driven transaction-manager="transactionManager" /> <!--这个事务由陆慧添加,当多个事务时,注解可以有value参数,默认不写就是上面叫 transactionManager的管理器,其他的都写一个@Transactional("transactionManagermssql")--> <tx:annotation-driven transaction-manager="transactionManagermssql" />
6.新建DAO层
注意点:
1. 类注解 @Repository ,表示此类被spring 接管
2. @Resource如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。
@Resource(name = "sessionFactorymssql") private SessionFactory sessionFactorymssql;
3. 所有的方法写上: @Transactional(value="transactionManagermssql") 表示方法外面包一层事物。
@Transactional 写在Controller层调用的那个层上。这个层可以是Service层,也可以是Dao层。只是人为规定的而已,没有这个东东反正会报错。
一般情况下,写在Service层。因为Dao层是单个方法。Service层是Dao层方法的组合使用。Service层是需要事务的。
7 wcp-web的pom.xml中加一个依赖:
<dependency> <groupId>com.farm</groupId> <artifactId>wcp-tpmember</artifactId> <version>${wcp.version}</version> <exclusions> <exclusion> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> </exclusion> </exclusions> </dependency>
注意exclusion的东东,因为和tomcat下的lib包有重复,所以必须去除包含