首页产品库评测行情新闻|手机数码笔记本台式机DIY硬件数字家庭数码相机办公外设|软件下载游戏开发|社区

更多

数码相机
MP4
LCD
机箱
音箱

天极网 > 开发频道>简析J2EE应用程序数据库类设计模式

简析J2EE应用程序数据库类设计模式

2001-05-09 08:36作者:出处:JDeveloper责任编辑:


  二、程序实现

  在具体实现上面的这种模式时,往往根据具体的应用程序来选用不同的技术来实现。看到上面的描述模式后,我们很容易就发现,可以用EJB来实现(EJB分两种,实体EJB和会话EJB)。

  我们知道,EJB提出来的目的是用于提供一种分布式组件系统的开发。如果我们的应用程序是一个分布式的应用系统,那么毫无疑问,使用EJB来实现能大大减轻编程的工作量。同时,通过使用EJB容器的一些高级特性,可以使应用程序更加可靠,扩展性也大大加强。这样一来,开发人员就不必关心一些底层技术,比如事务处理,安全等各个方面,而是把重点放在怎样实现业务逻辑上。但是我们应该注意,如果开发的应用不是分布式的情况下,那么采用EJB有可能大大降低系统的性能。因为,EJB调用的开销很大。

  本文将探讨在不利用EJB技术的情况下如何来实现上面介绍的这个模式。

  下面以开发图书信息查询系统为例。

  1.实体类

  如前面讲到的,实体类的每个实例与表中一个记录对应。这样,实体类的属性应该和表的每个字段一一对应。必须注意的是,实体类的实例是每个记录在内存中的对应,因此,在程序中对实例的操作并不马上反应到数据库的记录中。

  在该类中,只是对数据的包装,因此,该类仅需要一些基本的方法,即setXX()和getXX()方法。

  下面是一个实体类,是对Book表的封装。

  class Book{

   protected int  ID;

   protected String Name;

   protected String ISBN;

   protected String Author;

   protected int  PublisherID;

   protected double Price;

   protected int  Volume;

   public void setID(int iID);

   public int  getID();

   public void setName(String sName);

   public String getName();

   public void setISBN(String sISBN);

   public String getISBN();

   public void setAuthor(String sAuthor);

   public String getAuthor();

   public void setPublisherID(int iID);

   public int  getPublisherID();

   public void setPrice(double dPrice);

   public double getPrice();

   public void setVolume(int iVolume);

   public int  getVolume();

   public Book(int iID, String sName, String sISBN, int iPublisherID, double dPrice, int iVolume);

  };

  同样地可以对表Publisher进行封装。

  2.会话类

  会话类主要是对一个表进行处理。这些操作可以是在表中创建一条记录,删除一条记录,更新一条记录和查找一条记录。这些操作的结果是将表中的记录和内存中的实体类的实例对应起来,或将实例与表中的记录对应起来。

  我们可以看一下对Book表的封装。

  class BookTable{

   void Add(Book book);

   void Delete(Book book);

   void Update(Book book);

   Collection findbyID(int iID);

   Collection findbyXXXX(XX,XX);

   Collection findbyPulisherName(String sPublisherName);

  };

  上面的类的申明中,Add()用于将内存中的一个Book实例映射到数据库中。Delete()用于删除数据库中的某一个记录。Update()用于更新表中的一个记录。而findbyXXXX()则对应于SELECT语句。

  对于涉及到多个表操作时,可以有两种方式。一种是象BookTable一样,专门封装一个类。另一个方法是,直接在BoolTable中写一个findbyPublisherName()。这个方法设计成返回一个Book的集合。

  上面只是简单的介绍了怎样实现实体类和会话类。在具体的应用中,还要考虑到数据库操作的一致性。下面就介绍一下事务处理的相关内容。
共3页。 9 1 2 3 :

关注此文的读者还看过:

返回开发频道首页

软件频道最新更新

热点推荐

天极服务|关于我们|About us|网站律师|RSS订阅|友情合作|加入我们|天极动态|网站地图|意见反馈|MSN/QQ上看天极
Copyright (C) 1999-2012 Yesky.com, All Rights Reserved 版权所有 天极网络