[转帖]Struts处方:Hibernate与Struts_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4415 | 回复: 0   主题: [转帖]Struts处方:Hibernate与Struts        下一篇 
white
注册用户
等级:少校
经验:1327
发帖:305
精华:0
注册:2011-7-21
状态:离线
发送短消息息给white 加好友    发送短消息息给white 发消息
发表于: IP:您无权察看 2011-8-26 9:40:21 | [全部帖] [楼主帖] 楼主

持久层是一个应用系统最基本的部份。很显然的,如果没有持久层,所有的工作都将丢失。但是,对不同的人来说持久层意味着不同的东西。持久化时间的长短是选择持久层储存媒介的基本衡量标准之一。例如,对于生命周期为一个用户会话的数据来说,Http session是非常合适的。与之对应的,跨越多个session,或者多个用户的持久化则需要一个数据库来保持。数据的数量是另一个非常重要的衡量标准。例如,最佳实践表明大量的数据最好不要被 存储在一个Http会话中。在这些情况下,你都应该考虑使用数据库。在这篇文章中,我们的目标就是数据库持久层。

    

    你选择的数据库类型对你有架构与设计都有重要的影响。作为面向对象的开发人员,我们倾向于把数据描绘成描述手上商业问题的一组相互关联的对象—这常被称为域模型。 但是,最常用的存储媒介是基于关系模型的。除非我们的对象模型映射成一个关系结构,否则 内存中我们数据的表示就会与持久化它的方法不一致。这个问题也被称作不对称问题。最流行的解决这种不对称问题的是一组被称为对象关系映射工具。一个ORM工具是被用来把数据从对象视图转换为关系型、提供诸如创建、读、更新、删除(CRUD)等持久性服务的 软件。有许多的关于ORM工具的论文,但是从本质上来说,他们谈论的都是对象映射模式。最流行的ORM工具是开源的Hibernate工程。

    

    在这篇文章中,我们展示了如何在一个Struts项目中应用Hibernate。另外,我们将展示如何建立一个Struts插件来提升你系统的性能。

    

    处方

    

    在这个文摘中,我们使用一个例子来展示你在struts项目中使用hibernate时所需要的所有东西。我们将建立一个应用程序来获取和展示从化学元素周期表里取出的元素。这个应用程

    

    序提供给用户一个查找页来通过元素符号来查找元素。应用程序将查询数据库里匹配这个元素符号名的记录并返回查找到的元素信息来响应用户请求。

    

    首先我们将展示如何启动Hypersonic 服务器。当数据库 服务器启动后,我们建立示例程序所需要的表与数据。一旦数据库准备运行了,我们将建立使用Hypersonic数据库服务器所需的Hibernate的所有东西。接下来的步骤是在action里调用Hibernate来处理数据库读取来响应查询请求。因为建立Hibernate的Factory对象是非常耗资源的,我们建立一个Struts plug-in来建立factory并把它保存在context里。

    

    让我们从建立Hypersonic数据库服务器开始。你需要从http://hsqldb.Sourceforge.net/下载它。放置hsqldb.jar在你的classpath路径里,从Dos窗口中敲入以下命令来启动Hypersonic:

java org.hsqldb.Server

    虽然不同版本的Hypersonic的服务器响应不同。下面的应答是典型的Hypersonic已经准备好响应数据库请求的应答:

Server 1.6 is running

Press [Ctrl]+{c} to abort

    随着数据库服务器的启动,我们可以建表和填充数据,如下列表1所示:

    

    Listing 1. 建立元素表

    

北京联动北方科技有限公司create table elements (id integer(3) IDENTITY, 北京联动北方科技有限公司  name char(30), 北京联动北方科技有限公司  number char(30), 北京联动北方科技有限公司  mass char(30), 北京联动北方科技有限公司  symbol char(2)); 北京联动北方科技有限公司  CREATE UNIQUE INDEX ui_elements_pk ON elements (symbol)insert into elements ( name, number, mass, symbol) values ('Manganese','25','55','Mn');insert into elements ( name, number, mass, symbol) values ('Zinc','30','65','Zn');insert into elements ( name, number, mass, symbol) values ('Thulium','69','169','Tm');insert into elements ( name, number, mass, symbol) values ('Californium','98','251','Cf');insert into elements ( name, number, mass, symbol) values ('Gold','79','197','Au');insert into elements ( name, number, mass, symbol) values ('Ytterbium','70','173','Yb');insert into elements ( name, number, mass, symbol) values ('Molybdenum','42','96','Mo');insert into elements ( name, number, mass, symbol) values ('Palladium','46','106','Pd'); 北京联动北方科技有限公司

  

    列表1是建立表的SQL语句,在symbol列上建立唯一索引,插入上面那些化学周期元素。当然你也可以从你高校的化学书本里面找出更多的一些数据插入。

    

    列表2是用来存储从数据库取出数据的JavaBean对象:

    

    Listing 2. JavaBean元素

    

北京联动北方科技有限公司package com.strutsrecipes.hibernate.beans;public class Element { 北京联动北方科技有限公司 private String name; 北京联动北方科技有限公司 private String symbol; 北京联动北方科技有限公司 private String number; 北京联动北方科技有限公司 private String mass; 北京联动北方科技有限公司 private int id; 北京联动北方科技有限公司 public Element() { super(); 北京联动北方科技有限公司 }  public Element(String name, String symbol, String number, String mass) { 北京联动北方科技有限公司 this.name = name; 北京联动北方科技有限公司 this.symbol = symbol; 北京联动北方科技有限公司 this.number = number; 北京联动北方科技有限公司 this.mass = mass; 北京联动北方科技有限公司 }  public int getId() { return id; 北京联动北方科技有限公司 }  public void setId(int id) { this.id = id; 北京联动北方科技有限公司 }  public String getMass() { return mass; 北京联动北方科技有限公司 }  public String getName() { return name; 北京联动北方科技有限公司 }  public String getNumber() { return number; 北京联动北方科技有限公司 }  public String getSymbol() { return symbol; 北京联动北方科技有限公司 }  public void setMass(String mass) { this.mass = mass; 北京联动北方科技有限公司 }  public void setName(String name) { this.name = name; 北京联动北方科技有限公司 }  public void setNumber(String number) { this.number = number; 北京联动北方科技有限公司 }  public void setSymbol(String symbol) { this.symbol = symbol; 北京联动北方科技有限公司 }} 北京联动北方科技有限公司

  

    Hibernate是一个对象-关系映射工具。它的任务是映射对象到关系型表,反之亦然。所以,我们必须告诉Hibernate如何映射列到JavaBean的属性上。这个是通过Element.hbm.xml文件来完成的。这份文件里面包含的信息用来授予Hibernate从表里面拷贝数据到Elements JavaBean的权利。如果我们使用Hibernate来更新数据,Element.hbm.xml文件里的信息将被用来解析从Elements JavaBean来的数据来生成更新的SQL语句。列表3显示了Element.hbm.xml。

Listing 3. Element.hbm.xml

北京联动北方科技有限公司<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"  "http://hibernate.sf.net/hibernate-mapping-2.0.dtd"><hibernate-mapping> 北京联动北方科技有限公司  <class name="com.strutsrecipes.hibernate.beans.Element" table="elements"> 北京联动北方科技有限公司  <id name="id" column="id"> 北京联动北方科技有限公司  <generator class="native"/> 北京联动北方科技有限公司  </id> 北京联动北方科技有限公司  <property name="name" column="name"/> 北京联动北方科技有限公司  <property name="number" column="number"/> 北京联动北方科技有限公司  <property name="mass" column="mass"/> 北京联动北方科技有限公司  <property name="symbol" column="symbol"/> 北京联动北方科技有限公司  </class></hibernate-mapping> 北京联动北方科技有限公司

  

    让我们跳到列表3

    

    我们声明了与elements表相联系的类文件的完整的包名。然后我们声明了表的名字与这个类相关联。接下来我们声明从JavaBean的id属性到表的id列的映射。因为property和column属性都有相同的值,我们本来可以忽略column属性,但是为了清晰起见,我们还是把column列出来。 <id>是个特殊的标签。它被用来声明表的主键。闭合的标签<generator>表示Hibernate以最适合数据库实现的方式生成该主键。你可以参考Hibernate文档有关标签<id>的更多信息。最后我们为其它的JavaBean属性做声明。为了清晰起见,column属性再次被声明。

    

    一旦映射文件被详细的分析,那一切都非常的明晰了。它简单地声明了表与类的映射和JavaBean属性与表的列名的映射。接下来我将告诉你在哪里放置这个文件。

    

    接下来,我们通过声明环境信息来配置Hibernate。在列表4我们展示Hibernate.cfg.xml文件。

Listing 4. hibernate.cfg.xml

北京联动北方科技有限公司 <?xml version='1.0' encoding='utf-8'?><!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"  "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd"><hibernate-configuration> 北京联动北方科技有限公司  <session-factory> 北京联动北方科技有限公司  <property name="dialect">net.sf.hibernate.dialect.HSQLDialect</property> 北京联动北方科技有限公司  <property name="connection.driver_class">org.hsqldb.jdbcDriver</property> 北京联动北方科技有限公司  <property name="connection.username">sa</property>  <property name="connection.password"></property>  <property name="connection.url">jdbc:hsqldb:hsql://127.0.0.1</property> 北京联动北方科技有限公司  <property name="show_sql"> </property>  <property name="">true</property> 北京联动北方科技有限公司  <mapping resource="/com/strutscookbook/hibernate/beans/Element.hbm.xml"/></session-factory></hibernate-configuration> 北京联动北方科技有限公司

  

    让我们跳到列表4

    

    我们以指定数据库实现方言开始,允许Hibernate充分利用实现特殊化的属性。我们声明Hypersonic方言。我们可以参考Hibernate文档以选择数据库相应的方言。然后我们声明数据库 驱动。必须保证这个驱动在应用程序的classpath上。然后我们声明数据库的用户名,数据库密码,连接数据库的URL。接下来我们通知Hibernate在日志里显示运行时生成的SQL语句。

    

    Hibernate.cfg.xml文件必须被放在你的classpath里。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论