Java操作MongoDB进行增删改查实例教程

作者:袖梨 2022-06-29

现在我们就用Java来操作MongoDB的数据。

一、准备工作

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

2、 下面建立一个JavaProject工程,导入下载下来的驱动包。即可在Java中使用mongoDB,目录如下:

clip_image002

 

二、Java操作MongoDB示例

在本示例之前你需要启动mongod.exe的服务,启动后,下面的程序才能顺利执行;

1、 建立SimpleTest.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());
}

 

完整源码

 

 代码如下 复制代码

package com.hoo.test;

import java.net.UnknownHostException;

import com.mongodb.DB;

import com.mongodb.DBCollection;

import com.mongodb.DBCursor;

import com.mongodb.Mongo;

import com.mongodb.MongoException;

import com.mongodb.util.JSON;

public class SimpleTest {

    public static void main(String[] args) throws UnknownHostException, MongoException {

        Mongo mg = new Mongo();

        //查询所有的Database

        for (String name : mg.getDatabaseNames()) {

            System.out.println("dbName: " + name);

        }

       

        DB db = mg.getDB("test");

        //查询所有的聚集集合

        for (String name : db.getCollectionNames()) {

            System.out.println("collectionName: " + name);

        }

        DBCollection users = db.getCollection("users");

        //查询所有的数据

        DBCursor cur = users.find();

        while (cur.hasNext()) {

            System.out.println(cur.next());

        }

        System.out.println(cur.count());

        System.out.println(cur.getCursorId());

        System.out.println(JSON.serialize(cur));

    }

}

 

2、 完成CRUD操作,首先建立一个MongoDB4CRUDTest.java,基本测试代码如下:

 

 代码如下 复制代码

package com.hoo.test;

import java.net.UnknownHostException;

import java.util.ArrayList;

import java.util.List;

import org.bson.types.ObjectId;

import org.junit.After;

import org.junit.Before;

import org.junit.Test;

import com.mongodb.BasicDBObject;

import com.mongodb.Bytes;

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.QueryOperators;

import com.mongodb.util.JSON;

public class MongoDB4CRUDTest {

   

    private Mongo mg = null;

    private DB db;

    private DBCollection users;

   

    @Before

    public void init() {

        try {

            mg = new Mongo();

            //mg = new Mongo("localhost", 27017);

        } catch (UnknownHostException e) {

            e.printStackTrace();

        } catch (MongoException e) {

            e.printStackTrace();

        }

        //获取temp DB;如果默认没有创建,mongodb会自动创建

        db = mg.getDB("temp");

        //获取users DBCollection;如果默认没有创建,mongodb会自动创建

        users = db.getCollection("users");

    }

   

    @After

    public void destory() {

        if (mg != null)

            mg.close();

        mg = null;

        db = null;

        users = null;

        System.gc();

    }

   

    public void print(Object o) {

        System.out.println(o);

    }

}

 

3、 添加操作

在添加操作之前,我们需要写个查询方法,来查询所有的数据。代码如下:

 

 代码如下 复制代码

private void queryAll() {

    print("查询users的所有数据:");

    //db游标

    DBCursor cur = users.find();

    while (cur.hasNext()) {

        print(cur.next());

    }

}

@Test

public void add() {

    //先查询所有数据

    queryAll();

    print("count: " + users.count());

   

    DBObject user = new BasicDBObject();

    user.put("name", "hoojo");

    user.put("age", 24);

    //users.save(user)保存,getN()获取影响行数

    //print(users.save(user).getN());

   

    //扩展字段,随意添加字段,不影响现有数据

    user.put("sex", "男");

    print(users.save(user).getN());

   

    //添加多条数据,传递Array对象

    print(users.insert(user, new BasicDBObject("name", "tom")).getN());

   

    //添加List集合

    List list = new ArrayList();

    list.add(user);

    DBObject user2 = new BasicDBObject("name", "lucy");

    user.put("age", 22);

    list.add(user2);

    //添加List集合

    print(users.insert(list).getN());

   

    //查询下数据,看看是否添加成功

    print("count: " + users.count());

    queryAll();

}

 

4、 删除数据

 

 代码如下 复制代码

@Test

public void remove() {

    queryAll();

    print("删除id = 4de73f7acd812d61b4626a77:" + users.remove(
new BasicDBObject("_id", new ObjectId("4de73f7acd812d61b4626a77"))).getN());

    print("remove age >= 24: " + users.remove(
new BasicDBObject("age", new BasicDBObject("$gte", 24))).getN());

}

 

5、 修改数据

 

 代码如下 复制代码

@Test

public void modify() {

    print("修改:" + users.update(new BasicDBObject("_id",
new ObjectId("4dde25d06be7c53ffbd70906")), new BasicDBObject("age", 99)).getN());

    print("修改:" + users.update(

            new BasicDBObject("_id",
new ObjectId("4dde2b06feb038463ff09042")),

            new BasicDBObject("age", 121),

            true,//如果数据库不存在,是否添加

            false//多条修改

            ).getN());

    print("修改:" + users.update(

            new BasicDBObject("name", "haha"),

            new BasicDBObject("name", "dingding"),

            true,//如果数据库不存在,是否添加

            true//false只修改第一天,true如果有多条就不修改

            ).getN());

   

    //当数据库不存在就不修改、不添加数据,当多条数据就不修改

}

 

相关文章

精彩推荐