本实战是博主初次学习Java,分析WCP源码时,学习HibernateTools部分的实战,由于初次接触,难免错误,仅供参考,希望批评指正。

开发环境: Eclipse Version: Photon Milestone 6

WCP:http://www.wcpdoc.com/home/Pubindex.html

目录:

Hibernate自动生成(1)

Hibernate自动生成(2)

动软生成的WCP DAO层模板(不使用接口)

在第一部分,已经生成了实体对象,现在我们正式使用。

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包有重复,所以必须去除包含

【原创】Hibernate自动生成(2)的更多相关文章

  1. 【原创】Hibernate自动生成(1)

    本实战是博主初次学习Java,分析WCP源码时,学习HibernateTools部分的实战,由于初次接触,难免错误,仅供参考,希望批评指正. 开发环境: Eclipse Version: Photon ...

  2. hibernate自动生成映射文件

    映射文件是O/R Mapping的关键,相当于控制中心.当数据库表较多时,手动配置该映射文件非常耗时.为了快速开发程序,使开发人员的注意力集中到业务逻辑上来,Hibernate官方提供的MiddleG ...

  3. Hibernate自动生成实体类注解(转)

    常用的hibernate annotation标签如下: @Entity --注释声明该类为持久类.将一个Javabean类声明为一 个实体的数据库表映射类,最好实现序列化.此时,默认情况下,所有的类 ...

  4. intellij配置hibernate自动生成hbm.xml文件

    1.首先创建一个Java web项目,这里因为已经在整个项目中配置好tomcat了,所以我是直接创建module的,其实和创建project的配置方法一样,创建的时候选择Web Application ...

  5. MyEclipse 2015 如何使项目能够使用 Hibernate自动生成文件

    在MyEclipse-Project facets 下 对hibernate这一栏打钩即可

  6. Hibernate 自动生成数据库表

    http://blog.csdn.net/u010096526/article/details/50533428

  7. hibernate自动生成时报错问题

    创建好了实体类和.hbm.xml文件,运行项目报上错: 实体类和xml文件中的字段要一致.(顺序和字段)

  8. hibernate如何配置自动生成表

    hibernate自动生成表有两种方法: 1.直接写代码,通过方法来创建数据库表. 2.通过 hibernate.cfg.xml配置标签来创建数据表. 下面依次实现: 1.直接写代码,通过方法来创建数 ...

  9. python 自动生成C++代码 (代码生成器)

    python 代码自动生成的方法 (代码生成器) 遇到的问题 工作中遇到这么一个事,需要写很多C++的底层数据库类,但这些类大同小异,无非是增删改查,如果人工来写代码,既费力又容易出错:而借用pyth ...

随机推荐

  1. Python中使用XMLRPC(入门)

    一.简介 RPC是Remote Procedure Call的缩写,翻译成中文为:远程方法调用. 它是一种在本地机器上调用远端机器上的一个过程(方法)的技术,这个过程也被大家称为“分布式计算”,是为了 ...

  2. util.string.js

    ylbtech-JavaScript-util: util.string.js 字符串处理工具 1.A,JS-效果图返回顶部   1.B,JS-Source Code(源代码)返回顶部 1.B.1, ...

  3. ylb:事务处理

    ylbtech_sqlserver --1.定义三个变量分别保存你的姓名,年龄和身高,然后赋值并且输出 --DECLARE @name varchar(10) , @age int , @height ...

  4. ylb:事务

    ylbtech_sqlserver create database bank go use bank go create table users ( uid ,), uname ) not null, ...

  5. 论坛中不同类型的贴的排序问题(涉及数据库的:CASE... END)

    在论坛中,会有不同类型的帖子,比如说:普通贴.精华帖.置顶帖: 论坛的这些贴子会根据不同的类型进行排序,当然不仅仅只是看帖子类型,还有贴子的动态情况来进行排序. 在这里演示一下简单的帖子排序,我们只关 ...

  6. Makefile之嵌套执行make

    1.在Makefile中 一般使用一个总控Makefile来指明文件的编译规则 如: subsystem: cd subdir && $(MAKE) 其等价于 subsystem: $ ...

  7. Loadrunner中对中文进行UTF-8转码的探索

    上一篇 / 下一篇  2010-02-22 15:20:28 查看( 2378 ) / 评论( 2 ) / 评分( 5 / 0 ) 这是一个HTTP接口测试中经常会碰到的问题,目前的服务器采用的都是U ...

  8. 【SpringMVC学习03】SpringMVC中注解和非注解方式下的映射器和适配器总结

    从上一篇的springmvc入门中已经看到,springmvc.xml中的配置了映射器和适配器,是使用非注解的方式来配置的,这是非注解方式的一种,这里再复习一下: 1. 非注解方式 1.1 处理器适配 ...

  9. [译] JavaScript 的事件循环

    译者注 本译文基本是按原文的意思来翻译,但对于 JavaScript 的事件循环,个人感觉还是 Philip Roberts 的视频讲解更形象些,思路和本文大致相同,不过他把事件表理解为 Web AP ...

  10. 阿里CI/CD、DevOps、分层自动化技术

    原文地址:http://www.infoq.com/cn/news/2017/01/alibaba-yunxiao-cicd-devops 在互联网时代,产品快速迭代的重要性不言而喻.不管是传统企业还 ...