文档章节

Morphia测试

l
 lmx160801
发布于 2017/04/23 20:40
字数 541
阅读 14
收藏 0

package org.chaoqian.test;

import java.util.ArrayList;
import java.util.List;

import org.bson.BasicBSONObject;
import org.chaoqian.model.Address;
import org.chaoqian.model.Hotel;
import org.junit.Test;
import org.mongodb.morphia.Datastore;
import org.mongodb.morphia.Key;
import org.mongodb.morphia.Morphia;
import org.mongodb.morphia.query.Query;

import com.mongodb.MongoClient;

public class MorphiaTest {
    Morphia morphia = new Morphia();
    MongoClient mongoClient = new MongoClient("192.168.2.104",27017);
    Datastore ds = morphia.createDatastore(mongoClient, "test");

    /**
     * 生成指定个数的hotelList
     * <p>
     * 
     * @Title: getHotelList
     *         </p>
     * 
     * @param num
     * @return
     */
    private static List<Hotel> getHotelList(int num) {
        List<Hotel> list = new ArrayList<Hotel>();
        for (int i = 30; i < num; i++) {
            Hotel hotel = new Hotel();
            hotel.setName("编号为[" + i + "]的旅店");
            hotel.setStars(i % 10);
            Address address = new Address();
            address.setCountry("中国");
            address.setCity("北京");
            address.setStreet("上地南路");
            address.setPostCode("10000" + (i % 10));
            hotel.setAddress(address);
            list.add(hotel);
        }
        return list;
    }

    /**
     * 将hotelList插入数据库
     * <p>
     * 
     * @Title: saveHotelList
     *         </p>
     * 
     * @param hotelDAO
     * @param hotelList
     */
    @Test
    public void saveTest() {
        List<Hotel> hotelList = getHotelList(40);
        for (Hotel hotel : hotelList) {
            // Key<Hotel> key=hotelDAO.save(hotel,WriteConcern.SAFE);
            Key<Hotel> key = ds.save(hotel);
            System.out.println("id为[" + key.getId() + "]的记录已被插入");
        }
    }
    
    @Test
    public void saveTest2() {
        Hotel hotel = new Hotel();
        hotel.setName("hotel旅店");
        hotel.setStars(5);
        Address address = new Address();
        address.setCountry("中国");
        address.setCity("北京");
        address.setStreet("上地南路");
        address.setPostCode("10000001");
        ds.save(address);
        hotel.setAddressid(address);
        //hotel.setAddress(address);
        Key<Hotel> key = ds.save(hotel);
        System.out.println("id为[" + key.getId() + "]的记录已被插入");
        
        
    }
    @Test
    public void findTest() {
        Hotel hotel = new Hotel();
        hotel.setName("hotel旅店");
        hotel.setStars(5);
        Address address = new Address();
        address.setCountry("中国");
        address.setCity("北京");
        address.setStreet("上地南路");
        address.setPostCode("10000001");
        hotel.setAddress(address);
        Query<Hotel> filter = ds.createQuery(Hotel.class).filter("star >",4).filter("star <", 6);
        ds.find(Hotel.class);
        for (Hotel hotel2 : filter) {
            System.out.println(hotel2);
        }
        
        //ds.createQuery(Hotel.class).
  
    }
}

 

-----------------------------------------------------------------------------------------------

package org.chaoqian.model;

import org.bson.types.ObjectId;
import org.mongodb.morphia.annotations.Embedded;
import org.mongodb.morphia.annotations.Entity;
import org.mongodb.morphia.annotations.Id;
import org.mongodb.morphia.annotations.Reference;

@Entity(value="hotel")
public class Hotel {
    @Id 
    private ObjectId id;
    
    private String name;
    
    private int stars;
    
    @Embedded
    private Address address;

    
    @Reference()
    private Address addressid;
    public Hotel() {
        super();
        // TODO Auto-generated constructor stub
    }

    public Hotel(ObjectId id, String name, int stars, Address address) {
        super();
        this.id = id;
        this.name = name;
        this.stars = stars;
        this.address = address;
    }

    public ObjectId getId() {
        return id;
    }

    public void setId(ObjectId id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getStars() {
        return stars;
    }

    public void setStars(int stars) {
        this.stars = stars;
    }

    public Address getAddress() {
        return address;
    }

    public void setAddress(Address address) {
        this.address = address;
    }

    public Address getAddressid() {
        return addressid;
    }

    public void setAddressid(Address addressid) {
        this.addressid = addressid;
    }

    @Override
    public String toString() {
        return "Hotel [id=" + id + ", name=" + name + ", stars=" + stars + ", address=" + address + "]";
    }    
     
    
 }

------------------------------------------------------------------

package org.chaoqian.model;

import org.bson.types.ObjectId;
import org.mongodb.morphia.annotations.Embedded;
import org.mongodb.morphia.annotations.Id;

@Embedded
public class Address {
    @Id
    private ObjectId id;
    
    private String street;
    private String city;
    private String postCode;
    private String country;
    
    public Address() {
        super();
        // TODO Auto-generated constructor stub
    }
    public Address(String street, String city, String postCode, String country) {
        super();
        this.street = street;
        this.city = city;
        this.postCode = postCode;
        this.country = country;
    }
    public String getStreet() {
        return street;
    }
    public void setStreet(String street) {
        this.street = street;
    }
    public String getCity() {
        return city;
    }
    public void setCity(String city) {
        this.city = city;
    }
    public String getPostCode() {
        return postCode;
    }
    public void setPostCode(String postCode) {
        this.postCode = postCode;
    }
    public String getCountry() {
        return country;
    }
    public void setCountry(String country) {
        this.country = country;
    }
    public ObjectId getId() {
        return id;
    }
    public void setId(ObjectId id) {
        this.id = id;
    }
    @Override
    public String toString() {
        return "Address [street=" + street + ", city=" + city + ", postCode=" + postCode + ", country=" + country + "]";
    }
    
}

 

© 著作权归作者所有

上一篇: 将博客搬至CSDN
下一篇: token过滤器
l
粉丝 0
博文 9
码字总数 2921
作品 0
私信 提问
加载中

评论(1)

JavaGG
JavaGG
为什么没结果的。。
NoSQL 之 Morphia 操作 MongoDB

上两篇文章:http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html http://www.cnblogs.com/hoojo/archive/2011/06/02/2068665.html 介绍到了在MongoDB的控制台完成MongoDB的数据操......

ibm_hoojo
2012/02/17
0
0
使用Morphia完成对象到MongoDB的映射

Morphia是一个实现Java对象到MongoDB双向映射的类库。最近,James Williams在自己Blog上张贴了一篇相关的文章。 尽管MongoDB已经有了Grails插件,但James似乎更偏爱Morphia: 有人可能会奇怪...

红薯
2010/08/24
3.1K
2
使用 Morphia 和 MongoDB 实现域模型持久性

简介: MongoDB 是面向文档的开源数据库,Morphia 是面向 MongoDB 的类型安全的对象映射库。本文解释了在文档和对象之间进行映射的好处,并演示了如何使用 Morphia 来实现这个功能。然后演示...

IBMdW
2011/06/14
1K
2
PlayMorphia

PlayMorphia是基于Morphia库的PlayFramework插件,为PlayFramework应用程序开发提供便捷访问MongoDB的支持。其特性如下: Play数据模型的无缝集成,直接支持CRUD 支持嵌入和引用两种对象组合...

匿名
2012/05/01
859
0
PlayMorphia 1.2.8-RC1 发布

PlayMorphia是基于Morphia库的PlayFramework插件,为PlayFramework应用程序开发提供便捷访问MongoDB的支持。v1.2.8-RC1版有以下更新: 缺省打开自动添加日期时间戳 批处理插入 增加字串类型系...

罗格林
2012/06/10
244
0

没有更多内容

加载失败,请刷新页面

加载更多

开发中常用的正则表达式

为了能够更好地理解如何在C#环境中使用正则表达式,这里整理了一些常用的正则表达式: 罗马数字: string p1 = "^m*(d?c{0,3}|c[dm])" + "(l?x{0,3}|x[lc])(v?i{0,3}|i[vx])$"; string t1 =......

木庄
19分钟前
4
0
【.NET程序打包】VS2019使用Installer Projects打包

C#—使用Installer Projects打包桌面应用程序 前言 打包桌面应用程序实在是一个不常使用的东西,偶尔使用起来经常会忘东忘西的耽误时间,因此,这篇文章多以图片记录过程,也是用于备忘。 下...

_Somuns
23分钟前
4
0
自定义注解,使用动态代理解决网站的字符集编码问题

第1章设置环境 安装操作系统,安装备份(镜像): JDK: 设置环境变量Eclipse:解压即可 Eclipse自身解压目录不包括中文 代码工作空间目录不包括中文Tomcat:解压不要包含中文目录M...

蓝来杯往
28分钟前
3
0
Solr中的字段类型field type

Solr含有多种字段类型,可用的字段类型基本都定义在了包org.apache.solr.schema中,列举如下: 类 说明 BinaryField 二进制数据 BoolField 布尔值,其中’t’/’T’/’1’都是true Collatio...

gantaos
42分钟前
4
0
《JAVA核心知识》学习笔记 (21. JAVA 算法)

21. JAVA 算法

Shingfi
48分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部