Java操作MongoDB進行增刪改查執行個體教程

來源:互聯網
上載者:User

現在我們就用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,目錄如下:

 

二、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<DBObject> list = new ArrayList<DBObject>();

    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());

   

    //當資料庫不存在就不修改、不添加資料,當多條資料就不修改

}

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.