本实战是博主初次学习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. [置顶] 使用kube-proxy让外部网络访问K8S service的ClusterIP

    配置方式 kubernetes版本大于或者等于1.2时,外部网络(即非K8S集群内的网络)访问cluster IP的办法是: 修改master的/etc/kubernetes/proxy,把KUBE_ ...

  2. npm中package-lock.json的作用:npm install安装时使用

    简单理解: XYZ 的格式 对应为: 主版本号.次版本号.修订号,版本号递增规则如下: 主版本号:当你做了不兼容的 API 修改, 次版本号:当你做了向下兼容的功能性新增, 修订号:当你做了向下兼容的 ...

  3. Swagger简介,轻松构造restful api的文档

    Swagger 是一款RESTFUL接口的文档在线自动生成+功能测试功能软件. Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使 ...

  4. oracle数据库中函数和存储过程中的区别

    一.函数必须有返回值,过程没有返回值: 二.函数可以单独执行,过程必须通过execute执行: 三.函数可以嵌入SQL中执行,过程不能. 可以将比较复杂的查询写成函数,然后在过程中调用.

  5. android 小技巧

    1. 模拟器横坚屏切换 ctrl + F11, ctrl + F12

  6. git学习——查看提交历史

    git log可以查看提交历史: 用-p选项展开显示每次提交的内容差异,用-2则仅显示最近两次的更新:git log -p -2 在-p选项后面使用--word-diff选项进行单词层面的对比.这其中 ...

  7. MYSQL数据插入、更新及删除

    上文讲到创建数据表,本文介绍create table后的数据插入: 一.通过insert into ...values...插入 insert into tablename (column1,colu ...

  8. IIS相关知识和经验的碎皮化记录

    1.IIS(Internet Information Services)网站本机可以访问,局域网其他机器无法访问 导致这个问题之一是防火墙规则,解决办法如下: 1)[开始]打开[控制面板],选择[WI ...

  9. Storm/Cassandra集成错误:NoSuchMethodError: concurrent.Futures.withFallback

    本文原文出处: http://blog.csdn.net/bluishglc/article/details/50443205 严禁不论什么形式的转载.否则将托付CSDN官方维护权益. 2015年的最 ...

  10. ubuntu 14.04 anaconda安装

    Python的准备工作 Python 一个备受欢迎的点是社区支持很多,有非常多优秀的库或者模块.但是某些库之间有时候也存在依赖,所以要安装这些库也是挺繁琐的过程.但总有人忍受不了这种 繁琐,都会开发出 ...