1. 什么是Morphia

Morphia是一个开放源代码的对象关系映射框架,它对MongoDB数据库 java版驱动进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵MongoDB数据库,也让Java程序员可以从复杂数据库设计中脱离出来,从而将更多的精力投入到业务逻辑中去。Morphia是一个轻量级的类型安全的Java对象to/from MongoDB库,具有以下特征:

· 它易于使用,而且非常轻巧 ,每种类型使用一次反射。

· 数据存储(DataStore) 和 DAO<T,V> 访问抽象,或自己实现...

· 使用运行时验证的类型安全 (Type-safe)和 Fluent 查询(Query) 支持

· 基于注解的行为映射,无XML文件

· 扩展 : Validation(jsr303) ,以及SLF4J日志

· 生命周期方法/事件(Lifecycle Method/Event) 支持

· 可与Guice、Spring和其它DI框架很好整合或协作

· 很多扩展点(新的注解,转换器,行为映射,日志等)

· 不存储Null/Empty值(默认)

· GWT支持(实体仅为POJO) - (GWT忽略注释)

· 允许原始类型、void toObject(DBObject) 或 DBObject  fromObject(Object) fromObject的高级映射器

2. Morphia开发环境配置

首先,从http://code.google.com/p/morphia/downloads/list下载Morphia开发包,最新版为morphia-0.99.jar,然后从http://www.mongodb.org/downloads 下载MongoDB数据库 java版驱动最新版为mongo-2.7.2.jar,直接将这两个jar包include到项目中即可,当然在程序的运行前应保证MongoDB数据库后台服务进程已经启动。(MongoDB数据库的具体安装使用请参考其它相关资料),要求使用Java SE 5或更高版本。

3. Morphia 中Java 注释使用

Morphia使用Java注释的特性来描述Java对象如何被持久化到MongoDB数据库中去。以下是Morphia比较常用的注释。

@Id

@Id 注释指示 Morphia 哪个字段用作文档 ID。如果试图持久保存对象(其 @Id 注释的字段为 null),则 Morphia 会自动生成 ID 值。

@Entity

@Entity 注释是必需的。其声明了在专用MongoDB集合上该类作为文档将持久保存。在默认情况下,Morphia 使用类名称来命名集合。

@Embedded

@Embedded 注释说明 Morphia将此对象实例嵌入到另一个对象中去。而不单独的放到一个MongoDB 集合。

@Reference

@Reference 注释说明对象是对另外一个集合中的文档的引用。在从 MongoDB 集合中加载对象时,Morphia 遵循着这些引用来建立对象关系。

@Indexed

类属性标记@Indexed注释, 表明为此属性增加索引。

@Property

类属性标记@ Property注释, 表明为此属性在MongoDB数据库取一个别名。

@Transient

类属性标记@Transient注释则表明这个字段将不被持久化到数据库。

4. Morphia编程模型

本节上通过定义一个简单的类以及一些操作代码片段来说明Morphia功能的编程模型,使得我们可以从总体上了解Morphia开发。

1. 定义被持久类

@Entity

class MyEntity {

@Id

ObjectId id;

String name;

}

2. 初始化morphia

Mongo mongo = new Mongo("localhost");//连接到本地mongoDB数据库

Morphia morphia = new Morphia();

morphia.mapPackage("MyEntity");//告诉Morphia映射哪些类

Datastore ds = morphia.createDatastore(mongo ,"myDB");//创建名为“myDB”数据库,mongo最好使用单实例模式

ds.ensureIndexes(); //在标记为@Id的类属性上创建索引

ds.ensureCaps(); //设置默认的mongoDB集合容量

3. 保存被持久化类

MyEntity e = ...;

ds.save(e);//将MyEntity对象持久化到mongoDB数据库中

4. 查询

MyEntity e =ds.find(MyEntity.class).get();//通过类型取的第一个数据项

MyEntity e = ds.find(MyEntity.class).field("name")

.equal("someName").get();

5. Datasotre接口

Datastore接口把Java对象保存到MongoDB或从MongoDB中访问Java对象提供了安全类型的方法。它提供了get/find/save/delete方法为你操作Java对象。

5.1  Get方法

Get方法返回一个实体对象通过@Id。get方法只是find(...)方法的一个精简版,通过ID访问。它会返回一个实体对象,或者null如果没有找到的话。

Datastore ds = ...

Hotel hotel = ds.get(Hotel.class, hotelId);

5.2  Find方法

find方法只是对Query的一个轻量级的封装。 作为封装它将返回一个Query,它实现Iterable<T>和QueryResults接口。

//在循环中使用

for(Hotel hotel : ds.find(Hotel.class, "stars >", 3))

print(hotel);

//作为一个List返回

List<Hotel> hotels = ds.find(Hotel.class, "stars >", 3).asList();

//对结果排序

List<Hotel> hotels = ds.find(Hotel.class, "stars >", 3).sort("-stars").asList();

//返回第一个符合条件的结果

Hotel gsHotel = ds.find(Hotel.class, "name", "Grand Sierra").get();

这里是有效的操作符列表["=", "==", "!=", "<>", ">", "<", ">=", "<=", "in", "nin", "all", "size", "exists"]。如果没有指定操作符默认使用"=",  就像上面的例子,"="和“==”是等价的表示相等,"!="和"<>"是等价的表示不相等。

5.3   Save方法

大部分对MongoDB数据库操作的工作及Morphia映射解析工作已由Morphia完成。本方法直截了当,只要我们在定义持久化类时使用好Morphia 注释即可。

Hotel hotel = new Hotel();

ds.save(hotel);

//@Id 属性如果没有指定的话,将被自动生成,

ObjectId id = hotel.getId();

5.4   Delete方法

它已很好的自我解释,delete方法将从MongoDB数据库删除数据项,基于一个查询如id或其它条件。

Datastore ds = ...

//通过指定主键Id,删除数据项

ds.delete(Hotel.class, "Grand Sierra Resort");

//基于一个查询,删除数据项

ds.delete(ds.createQuery(Hotel.class).filter("pendingDelete", true));

在morphia支持mongoDB以原子方式做一些操作的功能。如删除一个实体,并且同时返回要删除的项。 FindAndDelete方法首先查询要删除的项,并且删除。

5.5  Update方法

Updates应用在服务器上并且允许复杂但非常有效的修改。 假设要跟踪一个用户的最近网站登录信息。在任何成功登录网站的用户都修改时间,但是将不必加载此用户的信息然后在重新保存整个对象信息。而是相反地,你可以局部的修改并且执行一个有效的修改。

@Entity

class User

{

@Id private ObjectId id;

private long lastLogin;

//... 其它属性

private Query<User> queryToFindMe() {

return datastore.createQuery(User.class)

.field(Mapper.ID_KEY).equal(id);

}

public void loggedIn(){

long now = System.currentTimeMillis();

UpdateOperations<User>  ops  = datastore.

createUpdateOperations(User.class).set("lastLogin", now);

ds.update(queryToFindMe(), ops);

lastLogin = now;

}

}

首先,从http://code.google.com/p/morphia/downloads/list下载Morphia开发包,最新版为morphia-0.99.jar,然后从http://www.mongodb.org/downloads 下载MongoDB数据库 java版驱动最新版为mongo-2.7.2.jar,直接将这两个jar包include到项目中即可,当然在程序的运行前应保证MongoDB数据库后台服务进程已经启动。(MongoDB数据库的具体安装使用请参考其它相关资料),要求使用Java SE 5或更高版本。

1. Morphia 中Java 注释使用

Morphia使用Java注释的特性来描述Java对象如何被持久化到MongoDB数据库中去。以下是Morphia比较常用的注释。

@Id

@Id 注释指示 Morphia 哪个字段用作文档 ID。如果试图持久保存对象(其 @Id 注释的字段为 null),则 Morphia 会自动生成 ID 值。

@Entity

@Entity 注释是必需的。其声明了在专用MongoDB集合上该类作为文档将持久保存。在默认情况下,Morphia 使用类名称来命名集合。

@Embedded

@Embedded 注释说明 Morphia将此对象实例嵌入到另一个对象中去。而不单独的放到一个MongoDB 集合。

@Reference

@Reference 注释说明对象是对另外一个集合中的文档的引用。在从 MongoDB 集合中加载对象时,Morphia 遵循着这些引用来建立对象关系。

@Indexed

类属性标记@Indexed注释, 表明为此属性增加索引。

@Property

类属性标记@ Property注释, 表明为此属性在MongoDB数据库取一个别名。

@Transient

类属性标记@Transient注释则表明这个字段将不被持久化到数据库。

2. Morphia编程模型

本节上通过定义一个简单的类以及一些操作代码片段来说明Morphia功能的编程模型,使得我们可以从总体上了解Morphia开发。

1. 定义被持久类

@Entity

class MyEntity {

@Id

ObjectId id;

String name;

}

2. 初始化morphia

Mongo mongo = new Mongo("localhost");//连接到本地mongoDB数据库

Morphia morphia = new Morphia();

morphia.mapPackage("MyEntity");//告诉Morphia映射哪些类

Datastore ds = morphia.createDatastore(mongo ,"myDB");//创建名为“myDB”数据库,mongo最好使用单实例模式

ds.ensureIndexes(); //在标记为@Id的类属性上创建索引

ds.ensureCaps(); //设置默认的mongoDB集合容量

3. 保存被持久化类

MyEntity e = ...;

ds.save(e);//将MyEntity对象持久化到mongoDB数据库中

4. 查询

MyEntity e =ds.find(MyEntity.class).get();//通过类型取的第一个数据项

MyEntity e = ds.find(MyEntity.class).field("name")

.equal("someName").get();

3. Datasotre接口

Datastore接口把Java对象保存到MongoDB或从MongoDB中访问Java对象提供了安全类型的方法。它提供了get/find/save/delete方法为你操作Java对象。

5.1  Get方法

Get方法返回一个实体对象通过@Id。get方法只是find(...)方法的一个精简版,通过ID访问。它会返回一个实体对象,或者null如果没有找到的话。

Datastore ds = ...

Hotel hotel = ds.get(Hotel.class, hotelId);

5.2  Find方法

find方法只是对Query的一个轻量级的封装。 作为封装它将返回一个Query,它实现Iterable<T>和QueryResults接口。

//在循环中使用

for(Hotel hotel : ds.find(Hotel.class, "stars >", 3))

print(hotel);

//作为一个List返回

List<Hotel> hotels = ds.find(Hotel.class, "stars >", 3).asList();

//对结果排序

List<Hotel> hotels = ds.find(Hotel.class, "stars >", 3).sort("-stars").asList();

//返回第一个符合条件的结果

Hotel gsHotel = ds.find(Hotel.class, "name", "Grand Sierra").get();

这里是有效的操作符列表["=", "==", "!=", "<>", ">", "<", ">=", "<=", "in", "nin", "all", "size", "exists"]。如果没有指定操作符默认使用"=",  就像上面的例子,"="和“==”是等价的表示相等,"!="和"<>"是等价的表示不相等。

5.3   Save方法

大部分对MongoDB数据库操作的工作及Morphia映射解析工作已由Morphia完成。本方法直截了当,只要我们在定义持久化类时使用好Morphia 注释即可。

Hotel hotel = new Hotel();

ds.save(hotel);

//@Id 属性如果没有指定的话,将被自动生成,

ObjectId id = hotel.getId();

5.4   Delete方法

它已很好的自我解释,delete方法将从MongoDB数据库删除数据项,基于一个查询如id或其它条件。

Datastore ds = ...

//通过指定主键Id,删除数据项

ds.delete(Hotel.class, "Grand Sierra Resort");

//基于一个查询,删除数据项

ds.delete(ds.createQuery(Hotel.class).filter("pendingDelete", true));

在morphia支持mongoDB以原子方式做一些操作的功能。如删除一个实体,并且同时返回要删除的项。 FindAndDelete方法首先查询要删除的项,并且删除。

5.5  Update方法

Updates应用在服务器上并且允许复杂但非常有效的修改。 假设要跟踪一个用户的最近网站登录信息。在任何成功登录网站的用户都修改时间,但是将不必加载此用户的信息然后在重新保存整个对象信息。而是相反地,你可以局部的修改并且执行一个有效的修改。

@Entity

class User

{

@Id private ObjectId id;

private long lastLogin;

//... 其它属性

private Query<User> queryToFindMe() {

return datastore.createQuery(User.class)

.field(Mapper.ID_KEY).equal(id);

}

public void loggedIn(){

long now = System.currentTimeMillis();

UpdateOperations<User>  ops  = datastore.

createUpdateOperations(User.class).set("lastLogin", now);

ds.update(queryToFindMe(), ops);

lastLogin = now;

}

}

Morphia开发简介的更多相关文章

  1. Scrum敏捷开发简介

    Agile 敏捷开发实践中,强调团队的自我管理.在 Scrum 中,自我团队管理体现在每天的 Scrum 会议中和日常的协同工作,在每天的 Scrum 例会中,团队成员一般回答一下几个问题 : 昨天完 ...

  2. Kendo UI 移动应用开发简介

    Kendo UI 移动应用开发简介 Kendo UI 支持开发 Web 应用,前面介绍的 SPA,也支持开发移动应用,至于使用 HTML5 + JavaScript + CSS 开发移动是不是一个好的 ...

  3. Webservice WCF WebApi 前端数据可视化 前端数据可视化 C# asp.net PhoneGap html5 C# Where 网站分布式开发简介 EntityFramework Core依赖注入上下文方式不同造成内存泄漏了解一下? SQL Server之深入理解STUFF 你必须知道的EntityFramework 6.x和EntityFramework Cor

    Webservice WCF WebApi   注明:改编加组合 在.net平台下,有大量的技术让你创建一个HTTP服务,像Web Service,WCF,现在又出了Web API.在.net平台下, ...

  4. Linux C++ 开发简介

    主要介绍将Windows程序迁移到Linux系统相关知识 简介 Windows程序迁移到Linux系统可能需要修改很多代码, 既需要了解Linux平台的开发知识, 也需要了解Windows平台代码如何 ...

  5. Linux C++ 开发简介(包括Linux守护线程)

    阅读目录 简介 操作系统 编辑器 编译器 构建系统 调试 IDE 可执行程序.动态库.静态库 服务 Windows服务简介 创建Windows服务 注册Windows服务 管理Windows服务 Li ...

  6. 机器学习的Spark与Scala开发简介

     一.机器学习常用开发软件:Spark.Scala 1. Spark简介: MLlib包含的库文件有: 分类 降维 回归 聚类 推荐系统 自然语言处理 在线学习 统计学习方法:偏向理论性,数理统计的方 ...

  7. Python自动化开发-简介

    1.Python简介 Python创始人  Guido Van Rossum,人称"龟叔",1989年圣诞节期间,为了在阿姆斯特丹打发时间,开发的一个新的脚本解释程序 作为ABC语 ...

  8. 微信小程序原生开发简介

    简介: 总结: 1. 逻辑层使用js引擎,视图层使用webview渲染 2. 微信小程序已经支持了绝大部分的 ES6 API 3. 可以自动补全css的兼容语法 文档:https://develope ...

  9. JUC——JUC开发简介(一)

    前言 JUC是Java5.0开始提供的一组专门实现多线程并发处理的开发框架,利用JUC开发架构可以有效的解决实际线程项目开发之中出现的死锁.阻塞.资源访问与公平机制. 此笔记主要记录java.util ...

随机推荐

  1. 路由Vue-router 的使用总结

    1.关于 router-view 匹配 vue 项目使用 vue-router,所有的根级别的路由都是在 App.vue 文件中的 router-view 中渲染的.比如下面的 path: '/' . ...

  2. Cluster基础(三):配置HAProxy负载平衡集群、Keepalived高可用服务器、Keepalived+LVS服务器

    一.配置HAProxy负载平衡集群 目标: 准备三台Linux服务器,两台做Web服务器,一台安装HAProxy,实现如下功能: 客户端访问HAProxy,HAProxy分发请求到后端Real Ser ...

  3. [CSP-S模拟测试92]题解

    A.数列 显然每个数的答案是互相独立的,直接扩欧求解.我们需要最小化$ax+by=gcd(a,b)$中的$|x|+|y|$,而显然当x或y靠近0时答案可能最优,列个不等式求一下即可. 能$O(1)$千 ...

  4. Docker 里面新建mysql 容器

    1.获取MySQL镜像, a.直接从docker hub 下载docker镜像 docker pull +镜像名称 b.从别的项目上把镜像export出来 dockr load  i + 镜像的TAR ...

  5. python数据类

    前言 之前有写过一篇python元类的笔记,元类主要作用就是在要创建的类中使用参数metaclass=YourMetaclass调用自定义的元类,这样就可以为所有调用了这个元类的类添加相同的属性了. ...

  6. Vagrant 手册之同步目录 - VirtualBox

    原文地址 如果你使用的 provider 是 VirtualBox,那么 VirtualBox 同步目录就是默认的同步目录类型.这些同步目录使用 VirtualBox 的共享目录系统来同步客户机跟宿主 ...

  7. Java IO(1)

    IO这一部分内容还是比较多的,对于基础的枯燥但是又重要的内容还是将它记下来比较好. 关于File类 Ø File类直接继承与Object类,File类描述了文件本身的一些属性,File类用来获取或者处 ...

  8. Vue3.0响应式实现

    基于Proxy // 弱引用映射表 es6 防止对象不能被回收 let toProxy = new WeakMap(); // 原对象: 代理过得对象 let toRaw = new WeakMap( ...

  9. Interface-接口的实现与注意事项

    package cn.learn.Interface; public interface MyInterfaceA { public abstract void methodA(); public a ...

  10. Scala面向对象

    面向对象编程OOP: Scala vs Java 都有这三特性 封装:把属性.方法封装到类中 Person: int id, String name, Date birthday.... 需要gett ...