WEB开发网
开发学院WEB开发Jsp JAVA数据对象应用程序接口Castor使用参考 阅读

JAVA数据对象应用程序接口Castor使用参考

 2008-01-05 19:23:54 来源:WEB开发网   
核心提示:exolab旗下的castor是目前流行的、开放源码的JDO实现包, 它主要用来实现O/R Mapping,JAVA数据对象应用程序接口Castor使用参考,运用该软件包可以大大减轻程序员在处理对象-关系数据库的负担,本文介绍了Castor的基本用法, 并用有大量代码实例进行解释,并且提供了J2EE容器能够治理横跨多重

  exolab旗下的castor是目前流行的、开放源码的JDO实现包。 它主要用来实现O/R Mapping。运用该软件包可以大大减轻程序员在处理对象-关系数据库的负担。本文介绍了Castor的基本用法, 并用有大量代码实例进行解释。
  
  
  
  
  
  内容提要:
  
  
  
  · 打开JDO数据库 Client应用
  
  
  
  · J2EE应用
  
  
  
  · 使用JDO数据库对象
  
  
  
  · 区别瞬时JDO对象和持久JDO对象
  
  
  
  · OQLQuery
  
  
  
  · 创建与更新和删除
  
  
  
  · 使用JDO和xml
  
  
  
  
  
  打开JDO数据库
  
  
  
  Castor JDO支持两种类型的环境,Client应用和J2EE服务器。 Client应用被用来负责配置数据库连接和明确地治理事务。 J2EE应用使用JNDI来获得预先设好的数据库连接并利用UserTransaction或容器治理事务(CMT)来处理事务。 假如你曾经在这两种环境中使用过JDBC,那么应该比较熟悉这两种模型和他们之间的区别。
  
  
  
  
  
  Client应用
  
  
  
  Client应用负责定义JDO数据库配置,和明确地治理事务处理。 数据库通过一个单独的XML文件被配置 并连接到一个Mapping文件。 在例子代码中我将数据库文件命名为database.xml,但是你可以使用任何别的名称。 更多信息参见Castor JDO数据库配置。
  
  
  
  
  
  org.exolab.castor.jdo.JDO定义数据库名称和属性并且被用来打开数据库连接。 在上
  
  
  
  
  
  可以通过设置setConfiguration文件的URL来要求JDO层装载哪个数据库配置。 注重:Castor JDO在建立多个用同样的配置的JDO对象的情况下,将会仅仅只执行一次装载数据库配置。
  
  
  
  
  
  org.exolab.castor.jdo.Database对象代表数据库的一个打开的连接。
  
  
  
  
  
  线程 JDO对象定义不是线程安全的,因此不应该在并发多线程中使用JDO对象。还有,建立多个JDO对象仅仅 需要少量额外工作,而JDBC连接在每个事务处理中仅仅打开一次。这样处理的模式能够大大提高性能。
  
  
  
  
  
  下列的代码片断展示了在Client应用中很常用的组合:“打开数据库,执行SQL,关闭数据库。”
  
  
  
  JDO jdo;
  
  
  
  Database db;
  
  
  
  
  
  // 定义JDO对象
  
  
  
  jdo = new JDO();
  
  
  
  jdo.setDatabaseName( "mydb" );
  
  
  
  jdo.setConfiguration( "database.xml" );
  
  
  
  jdo.setClassLoader( getClass().getClassLoader() );
  
  
  
  
  
  // 打开一个新的数据库连接
  
  
  
  db = jdo.getDatabase();
  
  
  
  // 开始处理事务
  
  
  
  db.begin();
  
  
  
  // 以下是一些业务逻辑
  
  
  
  . . .
  
  
  
  // 提交事务处理,并且关闭数据库
  
  
  
  db.commit();
  
  
  
  db.close();
  
  
  
  J2EE应用
  
  
  
  前提: 假设我们的J2EE容器内嵌支持Castor。
  
  
  
  J2EE应用依靠于J2EE容器(Servlet,EJB,等等)构成数据库关连和使用JNDI找到它,使用它。 J2EE应用模型答应应用部署从一个中心的地方构成数据库中心,并且提供了J2EE容器能够治理横跨多重的数据源的分布式的处理能力。
  
  
  
  
  
  在J2EE环境中,应用程序使用JNDI lookup代替org.exolab.castor.jdo.JDO 来构造JDO对象。

Tags:JAVA 数据 对象

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接