当前位置:数据库 > SQLServer >>

NoSQL 之 Morphia 操作 MongoDB

上文章 http://www.zzzyk.com/database/201202/119911.html
 
介绍到了在MongoDB的控制台完成MongoDB的数据操作、以及通过Java MongoDB 的驱动完成在Java中对MongoDB的操作,通过前两篇文章我们对MongoDB有了全面、深刻的认识和理解。现在我们就看看利用Morphia库来操作MongoDB。
 
开发环境:
 
System:Windows
 
IDE:eclipse、MyEclipse 8
 
Database:mongoDB
 
开发依赖库:
 
JavaEE5、mongo-2.5.3.jar、junit-4.8.2.jar, morphia-0.99.jar
 
Email:hoojo_@126.com
 
Blog:http://blog.csdn.net/IBM_hoojo
 
http://hoojo.cnblogs.com/
 
一、准备工作
1、 首先,下载mongoDB对Java支持的驱动包
 
驱动包下载地址:https://github.com/mongodb/mongo-java-driver/downloads
 
mongoDB对Java的相关支持、技术:http://www.mongodb.org/display/DOCS/Java+Language+Center
 
驱动源码下载:https://download.github.com/mongodb-mongo-java-driver-r2.6.1-7-g6037357.zip
 
在线查看源码:https://github.com/mongodb/mongo-java-driver
 
Morphia jar包下载:http://code.google.com/p/morphia/downloads/list
 
2、 下面建立一个JavaProject工程,导入下载下来的驱动包。即可在Java中使用Morphia,目录如下:
 
 clip_image002
 
二、Java操作MongoDB示例
在本示例之前你需要启动mongod.exe的服务,在你安装mongoDB的目录中,找到mongod.exe启动服务后,下面的程序才能顺利执行;
 
1、Java操作mongoDB数据库,操作索引
 
Mongo mongo = new Mongo();
 
这样就创建了一个MongoDB的数据库连接对象,它默认连接到当前机器的localhost地址,端口是27017。
 
DB db = mongo.getDB(“test”);
 
这样就获得了一个test的数据库,如果mongoDB中没有创建这个数据库也是可以正常运行的。如果你读过上一篇文章就知道,mongoDB可以在没有创建这个数据库的情况下,完成数据的添加操作。当添加的时候,没有这个库,mongoDB会自动创建当前数据库。
 
得到了db,下一步我们要获取一个“聚集集合DBCollection”,通过db对象的getCollection方法来完成。
 
DBCollection users = db.getCollection("users");
 
这样就获得了一个DBCollection,它相当于我们数据库的“表”。
 
查询所有数据
 
DBCursor cur = users.find();
 
while (cur.hasNext()) {
 
System.out.println(cur.next());
 
}
 
用BasicDBObjectBuilder,向users对象中添加数据
 
user = BasicDBObjectBuilder.start("id", 1546555)
 
.append("name", "jojo").add("address", "gz")
 
.append("email", "hoojo_@126.com")
 
.get();
 
插入数据
 
users.insert(user);
 
可以利用JSON工具来序列化对象数据
 
JSON.serialize(cur)
 
完整源码
 
package com.hoo.test;
 
import java.net.UnknownHostException;
import com.hoo.entity.User;
import com.hoo.util.BasicDBObjectUtils;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.Mongo;
import com.mongodb.MongoException;
import com.mongodb.util.JSON;
 
/**
 * <b>function:</b> Mongo实例对象的相关方法测试
 * @author hoojo
 * @createDate 2011-5-24 下午02:42:29
 * @file MongoDBTest.java
 * @package com.hoo.test
 * @project MongoDB
 * @blog http://blog.csdn.net/IBM_hoojo
 * @email hoojo_@126.com
 * @version 1.0
 */
public class MongoDBTest {
 
    public static void main(String[] args) throws UnknownHostException, MongoException {
        Mongo mg = new Mongo();
       
        System.out.println("查询所有的Database的名称");
        for (String name : mg.getDatabaseNames()) {
            System.out.println("dbName: " + name);
        }
       
        System.out.println("查询test库中的所有collection集合(表)名称");
        DB db = mg.getDB("test");
        for (String name : db.getCollectionNames()) {
            System.out.println("collectionName: " + name);
        }
       
        System.out.println("添加测试数据");
        DBCollection users = db.getCollection("users");
        try {
            // 用自定义BasicDBObjectUtils工具类,将User Enity对象转换成DBObject
            DBObject user = BasicDBObjectUtils.castModel2DBObject(new User("345567", "jack", 22, "beijin"));
            users.insert(user);
            // 用BasicDBObjectBuilder构建一个DBObject对象
            user = BasicDBObjectBuilder.start("id", 1546555).append("name", "jojo").add("address", "gz").append("email", "hoojo_@126.com").get();
            users.insert(user);
        } catch (Exception e) {
            e.printStackTrace();
        }
       
        System.out.println("游标查询所有users集合数据");
        DBCursor cur = users.find();
        while (cur.hasNext()) {
            System.out.println(cur.next());
        }
        System.out.println("查询游标相关内容");
        System.out.println(cur.count());
        System.out.println(cur.getCursorId());
        System.out.println(cur.getOptions());
        System.out.println(cur.getQuery());
        System.out.println(cur.getSizes().listIterator());
       
        System.out.println(cur.itcount());
        //System.out
Oracle
MySQL
Access
SQLServer
DB2
Excel
SQLite
SYBASE
Postgres
如果你遇到数据库难题:
请访问www.zzzyk.com 试试
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,