SSH自動生成表結構

Hibernate與Spring配合生成表結構。


首先,要將Spring的信息配置的web.xml,配置Spring用於初始化容器對象的監聽器。

web.xml

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">  
  3.   <display-name>oa_01</display-name>  
  4.     
  5.   <!-- 配置Spring用於初始化容器對象的監聽器 -->  
  6.   <listener>  
  7.     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  8.   </listener>  
  9.   <context-param>  
  10.     <param-name>contextConfigLocation</param-name>  
  11.     <param-value>classpath:applicationContext*.xml</param-value>  
  12.   </context-param>  
  13.     
  14.   <welcome-file-list>  
  15.     <welcome-file>index.jsp</welcome-file>  
  16.   </welcome-file-list>  
  17. </web-app>  


然後,將Hibernate的信息配置到Spring的配置文件中,將Hibernate交由Spring來管理。

applicationContext.xml

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"  
  4.     xmlns:tx="http://www.springframework.org/schema/tx"  
  5.     xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  6.                 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd  
  7.                 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  
  8.   
  9.     <!-- 自動掃描與裝配bean -->  
  10.     <context:component-scan base-package="com.tgb.oa"></context:component-scan>  
  11.       
  12.     <!-- 導入外部的properties文件 -->  
  13.     <context:property-placeholder location="classpath:jdbc.properties"/>  
  14.       
  15.     <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
  16.         <!-- 指定hibernate配置文件的位置 -->  
  17.         <property name="configLocation" value="classpath:hibernate.cfg.xml"></property>  
  18.         <!-- 配置c3p0數據庫連接池 -->  
  19.         <property name="dataSource">  
  20.             <bean class="com.mchange.v2.c3p0.ComboPooledDataSource">  
  21.                 <!-- 數據連接信息 -->  
  22.                 <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3307/myoa"></property>  
  23.                 <property name="driverClass" value="com.mysql.jdbc.Driver"></property>  
  24.                 <property name="user" value="root"></property>  
  25.                 <property name="password" value="123456"></property>  
  26.                   
  27.                 <!-- 初始化時獲取三個連接(取值應在minPoolSize與maxPoolSize之間。默認值: 3) -->  
  28.                 <property name="initialPoolSize" value="3"></property>  
  29.                 <!-- 連接池中保留的最小連接數,默認值:3 -->  
  30.                 <property name="minPoolSize" value="3"></property>  
  31.                 <!-- 連接池中保留的最大連接數,默認值:15 -->  
  32.                 <property name="maxPoolSize" value="5"></property>  
  33.                 <!-- 當連接池中的連接數耗盡的時候,c3p0一次同時獲取的連接數,默認值:3 -->  
  34.                 <property name="acquireIncrement" value="3"></property>  
  35.                 <!-- 控制數據源內加載的PreparedStatements數量。如果maxStatements與maxStatementsPerConnection均爲0,則緩存被關閉。Default: 0 -->  
  36.                 <property name="maxStatements" value="8"></property>  
  37.                 <!--maxStatementsPerConnection定義了連接池內單個連接所擁有的最大緩存statements數。Default: 0 -->  
  38.                 <property name="maxStatementsPerConnection" value="5"></property>  
  39.                 <!--最大空閒時間,1800秒內未使用則連接被丟棄。若爲0則永不丟棄。Default: 0 -->  
  40.                 <property name="maxIdleTime" value="1800"></property>  
  41.             </bean>  
  42.         </property>         
  43.     </bean>  
  44.       
  45.       
  46. </beans>  


這裏我將數據庫連接信息以及連接池都配置到了Spring中,當然你也可以將數據庫連接信息寫到Hibernate的配置文件裏,Hibernate會有自己默認的連接池配置,但是它沒有Spring的好用。具體寫到哪看你需要吧。


接下來就是Hibernate的配置了,裏面包括數據庫方言、是否顯示sql語句、更新方式以及實體映射文件。當然也可按上面說的將數據庫連接信息寫到裏面。

hibernate.cfg.xml

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE hibernate-configuration PUBLIC  
  3.     "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  4.     "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">  
  5.   
  6. <hibernate-configuration>  
  7.     <session-factory>  
  8.           
  9.         <property name="dialect">  
  10.             org.hibernate.dialect.MySQL5InnoDBDialect  
  11.         </property>  
  12.           
  13.         <property name="show_sql">true</property>  
  14.         <property name="hbm2ddl.auto">update</property>  
  15.           
  16.         <mapping resource="com/tgb/oa/domain/User.hbm.xml"/>  
  17.           
  18.     </session-factory>  
  19. </hibernate-configuration>  


實體映射文件,不做過多解釋。

User.hbm.xml

[html] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. <?xml version="1.0" <span style="font-family: Arial, Helvetica, sans-serif;">encoding="UTF-8"?</span>>  
  2. <!DOCTYPE hibernate-mapping PUBLIC  
  3.         "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  4.         "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  5.   
  6. <hibernate-mapping package="com.tgb.oa.domain">  
  7.   
  8.     <class name="User" table="T_User">  
  9.         <id name="id">  
  10.             <generator class="native"/>  
  11.         </id>  
  12.         <property name="name" />  
  13.     </class>  
  14.       
  15. </hibernate-mapping>  


實體類

User.java
[java] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. package com.tgb.oa.domain;  
  2.   
  3. public class User {  
  4.   
  5.     private String name;  
  6.     private  Long id;  
  7.       
  8.     public String getName() {  
  9.         return name;  
  10.     }  
  11.     public void setName(String name) {  
  12.         this.name = name;  
  13.     }  
  14.     public Long getId() {  
  15.         return id;  
  16.     }  
  17.     public void setId(Long id) {  
  18.         this.id = id;  
  19.     }  
  20.       
  21.       
  22. }  


當tomcat啓動的時候,會先找到web.xml,然後根據web.xml的配置,會找到spring中的applicationContext.xml的配置文件,在applicationContext.xml中有相應的SessionFactory的配置,裏面有Hibernate的相關信息,接着就會找到Hibernate-cfg.xml,讀取該文件,並找到實體映射文件User.hbm.xml,最後根據User.hbm.xml的配置映射成相應的表結構。


Tomcat啓動以後,表結構也跟着生成了,生成表結構後的效果:



兩種生成表結構的方式其實也沒有哪種好,哪種不好之說。用工具類生成的方式不需要Spring的參與,但是需要一個工具類來支持;與Spring配合的方式不需要多餘的東西,但是需要與Spring配合才能用。如果你只需要Hibernate那就用第一種,如果正好是配合Spring來使用那毫無疑問就用第二種。具體看情況吧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章