mongodb有三种方法来保存java对象,一种是通过类实现DBObject接口,一种是利用spring-mongodb工具的对象映射功能,把java对象转换成mongodb的BSON文档,一种是通过序列化类实例,转成二进制存储,mongodb是支持二进制的数据格式的。下面分别介绍三种方法:

1.实现DBObject接口

用这种方法的话类还是个DBObject,存取对象属性都要用到put和get方法,感觉很不方便,这个我们可以参考官网的例子:

public class Tweet implements DBObject {
    /* ... */
}
Tweet myTweet = new Tweet();
myTweet.put("user", userId);
myTweet.put("message", msg);
myTweet.put("date", new Date());

collection.insert(myTweet);
collection.setObjectClass(Tweet.class);

Tweet myTweet = (Tweet)collection.findOne();
Tweet myTweet = (Tweet)collection.findOne();
myTweet.put("message", newMsg);

collection.save(myTweet);


可能大家已经发现,这种方法只适用于新的类,如果是原有的类这样做就不合适了。

2.使用spring-mongodb

关于spring-mongodb对象映射的使用,可以参考我之前的文章:Mongodb与spring集成(2)------实体映射

使用spring-mongodb持久化对象有一个不好的地方就是它把目前还不支持把实体类的字段通过二进制的方式存储,而是把类中的字段都存储为字段的格式,如果一个类里面有其它封闭类作为属性,则从mongodb中读取时就要经过很多反射来映射到实体类上。为什么会有这样的需求呢?我是在把cas的ticket存储端换成mongodb时需要的,它有提供jpa的存储层,我们知道关系数据库中有种LOB的类型是用来存储二进制数据的,直接通过@LOB标注就可以,我觉得spring-mongodb也应该加个二进制存储的注解功能,有时间的话自己实现个。

3.序列化类实例,转成二进制存储

 接下来就说一下通过二进制存储类的方法,以下均使用官方java客户端操作:

序列化存储,主要用到ObjectOutputStream:

DBObject dbo = new BasicDBObject();
    ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
    ObjectOutputStream out = new ObjectOutputStream(outputStream);
    out.writeObject(yourJavaObject);
    dbo.put("JavaObject", outputStream.toByteArray());
    out.close();
    outputStream.close();
    collection.insert(dbo);

反序列化读取,主要用到ObjectInputStream:

DBObject object = collection.findOne();
    byte[] javaObjectByte = (byte[]) object.get("JavaObject");
    InputStream inputStream = new ByteArrayInputStream(javaObjectByte);
    ObjectInputStream in = new ObjectInputStream(inputStream);
    JavaObject javaObject = (Service) in.readObject();
    in.close();
    inputStream.close();

 

参考资料:http://www.mongodb.org/display/DOCS/Java+-+Saving+Objects+Using+DBObject