这篇文章学习如何使用Torque,作为一个ORM(a tool that maps relational databases to java classes)

用Torque访问数据库,需要如下步骤

  • 定义描述数据库结构(tables, columns等)的schema文件
  • 通过schema生成classes和数据库
  • 使用生成的类 (and the torque-runtime library classes) 访问数据库

创建database schema

每个schema文件包含一个数据库作为根元素。

运行Generator

Torque uses the information from the database schema to generate classes by which the database can be accessed. Also, Torque can generate SQL scripts and documentation in HTML and xdoc format from the schema. The Torque generator must be invoked in order to generate these artifacts. This can be done in three different ways: via Maven 2/3, via ant or via plain Java.

数据库独立性

产生的java代码具有数据库独立性。这意味着不必为每种数据库重新生成代码。但是有几点需要注意的:

  • 不是所有data types are available on all databases.
  • Available data types也可能不同数据库表现不同。E.g. Oracle's date type contains time information as well, in contrast to all other databases.
  • 表名和column名的最大长度也随数据库变化而变化。目前的了解,表名长度不超过27个字符,column名长度不超过31个字符在所有数据库中都是安全的。

产生的SQL具有数据库依赖性 (of course).

初始化Torque runtime

Torque通过调用Torque.init() 来初始化。Torque在使用前必须初始化,而且只能初始化一次。初始化时必须提供执行configuration文件的路径或者configuration本身。

一旦初始化,数据库的runtime model,比如DatabaseMaps会自动有生成的MapBuilder类创建。每个peer class在Base class被加载时构建runtime model,并且将table model注册到相应的database model中。

Configuration说明

  • database handles: 数据库的名称,如果没有定义,则是default

    torque.database.default=bookstore
  • database adapter: 为handle指定adapter。目前支持: derby, mysql, oracle, mssql等
    torque.database.bookstore.adapter=mysql
  • 连接池: 可以为任何实现接口DataSource的连接池。用户可以配置获取datasource的factory。

读数据库

读数据需要指定读哪个数据库里的哪张表。Torque引入Criteria object表达SQL Query。之后将Criteria对象传给一个Peer类,该类会负责查询数据库并将结果以Data Object返回。

Runtime中有两类Criteria类:org.apache.torque.criteria.Criteria and org.apache.torque.util.Criteria。前者推荐给新项目,后者已过时但可以支持legacy项目。

Criteria crit = new Criteria();
Criterion a1 = new Criterion(ABC.A, 1, Criteria.LESS_THAN);
Criterion b2 = new Criterion(ABC.B, 2, Criteria.GREATER_THAN);
Criterion a5 = new Criterion(ABC.A, 5, Criteria.GREATER_THAN);
Criterion b3 = new Criterion(ABC.B, 3, Criteria.LESS_THAN); crit.where(a1.and(b2).or(a5.and(b3)));

写数据库

往数据库中写数据,调用save()方法。写的方式分为insert和update。另外一种选择方案是调用对用Peer类的静态方式doInsert()或者doUpdate()

Mass Updates: BasePeer的中的doUpdate(Criteria, ColumnValues) 方法,允许一次修改多个数据对象。比如将id大于5的author的name置null

Criteria criteria = new Criteria();
criteria.where(AuthorPeer.AUTHOR_ID, 5, Criteria.GREATER_THAN);
ColumnValues columnValues = new ColumnValues();
columnValues.put(AuthorPeer.NAME,
new JdbcTypedValue(
null,
java.sql.Types.VARCHAR));
BasePeer.doUpdate(criteria, columnValues);

删除对象: 如何数据已经加载到了直接调用对应Peer类的doDelete(xxx);如果没有被加载,则直接使用Criteria

Criteria criteria = new Criteria();
criteria.where(AuthorPeer.AUTHOR_ID, 5, Criteria.GREATER_THAN);
AuthorPeer.doDelete(criteria);

Reference

https://db.apache.org/torque/torque-4.0/documentation/orm-reference/index.html

http://www.iteye.com/topic/151778

Apache Torque的使用的更多相关文章

  1. Apache Torque入门学习

    Introduction Apache Torque is an object-relational mapper for java. In other words, Torque lets you ...

  2. Apache 项目列表功能分类便于技术选型

    big-data (49):  Apache Accumulo  Apache Airavata  Apache Ambari  Apache Apex  Apache Avro  Apache Be ...

  3. 容器配置jndi Tomcat为例

    context.xml 文件 <Resource name=" password="spsj" type="javax.sql.DataSource&qu ...

  4. PHP ORM框架与简单代码实现(转)

    对象关系映射(Object Relational Mapping,简称ORM)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据 ...

  5. ASF (0) - ASF Java 项目总览

    Apache .NET Ant Library This is a library of Ant tasks that help developing .NET software. It includ ...

  6. ORM PHP 学习记录

    ORM:object relation mapping,即对象关系映射,简单的说就是对象模型和关系模型的一种映射.为什么要有这么一个映射?很简单,因为现在的开发语言基本都是oop的,但是传统的数据库却 ...

  7. php有orm吗

    ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中.本质上就是将数据从一种形式转换到另外一种形式. ORM提供了所有SQL语句的生成,代码人员远离了数据库概念.从 ...

  8. Apache DdlUtils入门

    Introduction  DdlUtils is a small, easy-to-use component for working with Database Definition (DDL) ...

  9. apache开源项目-- Turbine

    1.缘起 Jetspeed是Apache Jakarta小组的开放源码门户系统.它使得最终用户可以通过WAP手机.浏览器.PDA等各种设备来使用各种各样的网络资源(比如应用程序.数据以及这之外的任何网 ...

随机推荐

  1. 浏览器js与css文件有缓存未更新致最新版本

    这是由于编码人员频繁更改引入的资源文件,浏览器中存在缓存,当你清空浏览器缓存也无济于事时可以采用在资源文件尾部加?_MM(MM为随机参数)即可强制更新资源文件.

  2. 收集几个不错的最新win10系统64位和32位系统Ghost版下载

    系统来自转载:系统妈 ◆ 版本特点 该版本安装后可利用微软公开的Windows10 KMS密钥激活,且右小角无版本水印. KMS客户端密钥:NPPR9-FWDCX-D2C8J-H872K-2YT43, ...

  3. hbase 权威指南笔记(二)

    这次我们先来讨论hbase的重试机制,为什么呐,因为最近公司最近也在做这方面的优化,所以就今天研究的一些成功记录一下. configuration.setInt("hbase.client. ...

  4. Django基础之安装配置

    安装配置 一 MVC和MTV模式 著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层:他们之间以一种插件似的,松耦合的方式连接在一起. 模型负责业务对象与数据库的 ...

  5. 启用SQLite的Data Provider 运行WECOMPANYSITE时遇到ERROR CREATING CONTEXT 'SPRING.ROOT': ERROR THROWN BY A DEPENDENCY OF OBJECT 'SYSTEM.DATA.SQLITE'

    从网上下载的源码WeCompanySite,运行时报错 Error creating context 'spring.root': Error thrown by a dependency of ob ...

  6. 华为5G空口新技术(2015年)

    2015-03-24 长江后浪推前浪,4G建设方兴未艾,业界关于5G的讨论已如火如荼.对于每一代移动通信,空口技术都相当于王冠上的明珠. 在月初的世界移动通信大会上,华为发布了面向5G的新空口,并展出 ...

  7. C语言学习 第十一次作业总结

    作业总结 两次的作业,都是和指针有关.从第一次的作业开始,我就多次让同学们思考这个问题:为什么要用指针,为什么在函数的形参中要使用指针.如果能够想明白这2个问题,那么同学们应该会指针的了解就差不多足够 ...

  8. C语言结构体对齐

    1.结构体变量中的元素如何访问? (1)数组中元素的访问方式:表面上有2种方式(数组下标方式和指针方式):实质上都是指针方式访问.(2)结构体变量中的元素访问方式:只有一种,用.或者->的方式来 ...

  9. AngularJS的基础元素应用

    <!doctype html> <!-- 标记ng-app告诉AngularJS处理整个HTML页并引导应用 --> <html ng-app> <head& ...

  10. 关于若干php 表单 的重新审视

    对于表单验证来说 应该在任何可能的时候对用户输入进行验证(通过客户端脚本).浏览器验证速度更快,并且可以减轻服务器的负载. 如果用户输入需要插入数据库,您应该考虑使用服务器验证.在服务器验证表单的一种 ...