在应用程序中将OJB作为一个存储层使用(六)

原创 2003年09月23日 01:33:00

Product映射:

现在我们要开始讲解从Product类到数据库表PRODUCT的映射。通常这种映射都不是通过

编程实现,而是通过定义一个xml文件。DescriptorRepository类提供了一些方法来读取

xml文件并进行初始化。结果就能在以后的编程中被使用(也可以通过纯编程来实现)。

 

我们已经写好了我们的映射关系,文件放置在src/test/ojb/repository.xml,中,xml

文件如下所示:

<?xml version="1.0" encoding="UTF-8"?>

<!-- This is a sample metadata repository for the ObJectBridge System.

     Use this file as a template for building your own mappings-->

<!-- defining entities for include-files -->

<!DOCTYPE descriptor-repository SYSTEM "repository.dtd" [

<!ENTITY user SYSTEM "repository_user.xml">

<!ENTITY junit SYSTEM "repository_junit.xml">

<!ENTITY internal SYSTEM "repository_internal.xml">

]>

<descriptor-repository version="0.9.1"

        isolation-level="read-uncommitted">

<!-- The Default JDBC Connection. If a class-descriptor does not

     specify its own JDBC Connection,

     the Connection specified here will be used. -->

   <jdbc-connection-descriptor

        platform="Hsqldb"

        jdbc-level="2.0"

        driver="org.hsqldb.jdbcDriver"

        protocol="jdbc"

        subprotocol="hsqldb"

        dbalias="/samples/hsql/OJB"

        username="sa"

        password=""

   />

    <!-- include user defined mappings here -->

    &user;

    <!-- include mappings for JUnit tests and sample apps here -->

    &junit;

    <!-- include ojb internal mappings here -->

    &internal;

</descriptor-repository>

文件含有很多的信息:

1. Xml文件通过repository.dtd来验证其有效性。这就保证的xml文件语法的正确性。

确保将dtd文件放在和xml文件一样的目录,否则xml解析器将会报出找不到DTD的错误

2. 映射包含一个缺省的JDBCConnectDescriptor。该描述包含了在存储操作中所用到的

JDBC连接。对于那些没有定义特殊的JDBCConnectionDescriptor的类来说,都使用该描

述中的缺省JDBC连接。

在我们的例子中,描述申明了所有的操作都是靠JsqlDb JDBC驱动的,相应的数据库放在

相应的目录下面。

3. OJB映射回归测试。通过包含repository_junit.xml中的XML entity&junit。该ent

ity被定义在一个包含的文件中:

<!ENTITY junit SYSTEM "repository_junit.xml">

4. OJB内部的映射。OJB需要一些内部表来进行一次阿操作,如维持数据库锁,自动增

长,ODMG的collections和Maps。相应的映射也在这里实现。他们都正确的操作起重要作

用,应该不能被修改。

这些内部映射通过包含repository_internal.xml中的XML entity&internal来定义

5. 用户定义的映射。用户定义的映射包含所有对存储类做的对象/关系映射信息。缺省

的,实例程序的映射在这里定义。这些映射通过包含repository_user.xml的XML entit

y&user来定义。

现在让我们来看一下Product类,我把相应的映射放在repository_user.xml中,这样我们很

易找到。从文件的开头我们可以看到有一个对Product类的类描述:

<!-- Definitions for org.apache.ojb.broker.Product -->

   <class-descriptor

      class="org.apache.ojb.broker.Product"

      table="PRODUCT"

   >

      <field-descriptor

         name="id"

         column="ID"

         jdbc-type="INTEGER"

         primarykey="true"

         autoincrement="true"

      />

      <field-descriptor

         name="name"

         column="NAME"

         jdbc-type="VARCHAR"

      />

      <field-descriptor

         name="price"

         column="PRICE"

         jdbc-type="DOUBLE"

      />

      <field-descriptor

         name="stock"

         column="STOCK"

         jdbc-type="INTEGER"

      />

   </class-descriptor>

类描述给出了和RDBMS表相映射的类名称。

对于每个存储类的属性,我们定义一个field-descriptor,对应存储在数据库中的每一

列.对于主键,我们有一个特别的标记:primarykey="true".主键也相应地被设为autoi

ncrement="true",这就告诉了OJB给这个属性分配一个唯一的ID。这些都是通过一个Se

quenceManager工具类实现的。

Field-descriptor既可以声明primitive data型,也可以声明相应的封装类。

如果你的存储类中含有其他存储类的实例,你可以通过reference-descriptor来定义它

们之间的关系。如果存储类中有array-或是collection-属性,你可以使用collection-

descriptor属性。你可以在org.apache.ojb.broker包中找到一些例子,相应的描述在r

epository.xml中。

工具支持:

一般说来,有三种建立O/R映射的方式:

1. Forward engineering。通过给出Java类(或是UML模型),生成SQL DDL和映射关系

。我们可以使用一个工具从repository.xml生成一个数据库。执行build[.sh] forword

-db可以看到forward engineering的工作过程。

2. Reverse engineering。给出SQL DDL或者数据库,产生Java类和映射。执行build[

.sh] reverse-db可以看到reverse engineering的工作过程。

3. Mapping proper。给出Java类和SQL DDL,产生映射。我们现在还没有进行果测试,

但是已经列入下一步的计划中。

 

结论:

在本文中,我们学习了怎样给一个简单的类建立OJB对象/关系映射,在类的实例上通过

OJB PersistenceBroker API进行存储操作。

接着还有三篇文档,介绍了如何使用OJB ODMG API,OJB JDO API和高级O/R映射(包括

1-1,1-n映射,代理机制,支持多态性和映射继承)

我们希望该文档会对你有帮助,欢迎提出意见建议。

在应用程序中将OJB作为一个存储层使用(五)

定义对象/关系映射: 在看了实例程序的源代码和数据库(运行bin/build browse -db将会启动InstantDB数据 库的浏览窗口)后,你可能会问:在程序中我们并没用看到任何关于数据存储的...
  • Emolasa
  • Emolasa
  • 2003年09月23日 01:36
  • 916

在应用程序中将OJB作为一个存储层使用(一)

介绍: 本文通过一个简单的例子说明了怎样使用对象关系映射桥(OJB)。例子程序含有义产品 目录数据库和一些用户功能。程序的源代码随OJB源代码一起发布,包含在org.apache. ojb.tutor...
  • Emolasa
  • Emolasa
  • 2003年09月23日 01:35
  • 912

在应用程序中将OJB作为一个存储层使用(二)

用OJB PersistenceBroker API实现各种功能: 上面的一段代码很简单,因为没有涉及到存储操作,仅仅是程序的退出。下面让我们来 看一个更具体的例子:UCListAllProducts...
  • Emolasa
  • Emolasa
  • 2003年09月23日 01:32
  • 735

在应用程序中将OJB作为一个存储层使用(四)

删除对象: UCDeleteProduct类允许用于从products中选择一条记录并将它从存储库中删除。用户输 入产品的productId,broker试着查找指定的product。我们不需要拥有真...
  • Emolasa
  • Emolasa
  • 2003年09月23日 01:33
  • 770

在应用程序中将OJB作为一个存储层使用(三)

如果在product表中有10000条记录,那么从存储库中获得所有得记录是一个很费时的操 作,每个记录都必须新建一个对象,整个表都要读入内存。在示例程序中,没有考虑性 能问题,但是在一个实际的应用OJ...
  • Emolasa
  • Emolasa
  • 2003年09月23日 01:33
  • 768

搭建存储层

    首先抛开程序意义上的存储工具,从现实的角度考虑存储层所需要的几个条件.    我想大概有以下几点:    一、存储微粒          一个存储微粒可以比做计算机所认识的0/1;      ...
  • hanyuhen1
  • hanyuhen1
  • 2010年03月23日 13:56
  • 134

2.存储层

commitlog 存储路径默认为$HOME/store/commitlog,可以在broker启动时通过storePathCommitLog设置,存储的文件如下图所示,默认大小为1G: 数据过...
  • a417930422
  • a417930422
  • 2016年09月19日 13:57
  • 1029

在IIS 中没有将虚拟目录作为应用程序进行配置

在应用程序级别以外使用注册为 allowDefinition=MachineToApplication 的节是错误的。导致该错误的原因可能是在 IIS 中没有将虚拟目录作为应用程序进行配置解决办法:在...
  • ltlqltlq
  • ltlqltlq
  • 2006年11月15日 14:47
  • 926

Java: 第一次尝试Java,Thread类

A thread is a thread of execution in a program. The Java Virtual Machine allows an application to ha...
  • olojiang
  • olojiang
  • 2007年04月04日 18:50
  • 2019

只有在配置文件或 Page 指令中将 enableSessionState 设置为 true 时,才能使用会话状态。还请确保在应用程序配置的 // 节中包括 System.Web.SessionStateMod 或自定义会话状态模块 -

      使用VS2010设计Asp.net时出现: 只有在配置文件或 Page 指令中将 enableSessionState 设置为 true 时,才能使用会话状态。还请确保在应用程序配置的 ...
  • zorsbutape
  • zorsbutape
  • 2011年05月08日 20:52
  • 4187
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在应用程序中将OJB作为一个存储层使用(六)
举报原因:
原因补充:

(最多只允许输入30个字)