現在我們就用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()); //當資料庫不存在就不修改、不添加資料,當多條資料就不修改 } |