濮阳杆衣贸易有限公司

主頁 > 知識庫 > Java操作MongoDB數據庫示例分享

Java操作MongoDB數據庫示例分享

熱門標簽:智能電銷機器人銷售話術 企業(yè)智能外呼系統(tǒng)價格多少 高德地圖標注商戶位置 福州電銷機器人源代碼 徐州ai電銷機器人原理 兗州電話外呼營銷系統(tǒng) 機器人外呼系統(tǒng)軟件存在問題 南京400電話怎樣辦理 沈陽營銷電銷機器人招商

MongoDB是一個文檔型數據庫,是NOSQL家族中最重要的成員之一,以下代碼封裝了MongoDB的基本操作。

MongoDBConfig.java

package com.posoftframework.mongodb;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import com.mongodb.DB;
import com.mongodb.Mongo;
/**
 * MongoDB配置類
 * 
 * @author yongtree
 * @date 2010-7-7 下午07:45:08
 * @version 1.0
 */
public class MongoDBConfig {
  private static Mongo mongo;
  private static DB db;
  private static final String MONGO_DB_ADDRESS = "localhost";
  private static final int MONGO_DB_PORT = 27017;
  private static final String MONGO_DB_USERNAME = "root";
  private static final String MONGO_DB_PASSWORD = "root";
  private static final String MONGO_DB_DBNAME = "mongodb";
  private static final String MONGO_DB_RESOURCE_FILE = "mongodb.cfg.properties";
  /**
   * Mongo數據庫參數
   */
  private static MapString, String> cfgMap = new HashMapString, String>();
  private static HashtableString, DB> mongoDBs = new HashtableString, DB>();
  /**
   * 初始化Mongo的數據庫
   */
  static {
    init();
  }
  public static File getConfigFile() {
    String path = MongoDBConfig.class.getResource("/").getPath();
    String fileName = path + MONGO_DB_RESOURCE_FILE;
    File file = new File(fileName);
    if (file.exists()) {
      return file;
    }
    return null;
  }
  @SuppressWarnings("unchecked")
  private static void initCfgMap() {
    File file = getConfigFile();
    if (file != null) {
      Properties p = new Properties();
      try {
        p.load(new FileInputStream(file));
        for (Enumeration enu = p.propertyNames(); enu.hasMoreElements();) {
          String key = (String) enu.nextElement();
          String value = (String) p.getProperty(key);
          cfgMap.put(key, value);
        }
      } catch (IOException e) {
        System.out.println("記載Mongo配置文件失敗!");
        e.printStackTrace();
      }
    } else {
      cfgMap.put("mongo.db.address", MONGO_DB_ADDRESS);
      cfgMap.put("mongo.db.port", String.valueOf(MONGO_DB_PORT));
      cfgMap.put("mongo.db.username", MONGO_DB_USERNAME);
      cfgMap.put("mongo.db.password", MONGO_DB_PASSWORD);
      cfgMap.put("mongo.db.dbname", MONGO_DB_DBNAME);
    }
  }
  /**
   * 初始化Mongo數據庫
   */
  private static void init() {
    initCfgMap();
    try {
      String address = cfgMap.get("mongo.db.address");
      int port = Integer.parseInt(cfgMap.get("mongo.db.port").toString());
      String dbName = cfgMap.get("mongo.db.dbname");
      String username = cfgMap.get("mongo.db.username");
      String password = cfgMap.get("mongo.db.password");
      mongo = new Mongo(address, port);
      if (dbName != null  !"".equals(dbName)) {
        db = mongo.getDB(dbName);
        if (username != null  !"".equals(username)) {
          db.addUser(username, password.toCharArray());
        }
        mongoDBs.put(dbName, db);
      }
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
  /**
   * 得到Mongo的實例
   * 
   * @return
   */
  public static Mongo getMongo() {
    return mongo;
  }
  /**
   * 得到Mongo的圖片數據庫
   * 
   * @return
   */
  public static DB getDB() {
    return db;
  }
  public static ListString> getDBNames() {
    return mongo.getDatabaseNames();
  }
  /**
   * 根據數據庫名稱,得到數據庫br/>
   * 如果不存在,則創(chuàng)建一個該名稱的數據庫,并設置用戶名和密碼為配置文件中的參數值/br>
   * 
   * @param dbName
   * @return
   */
  public static DB getDBByName(String dbName) {
    DB db = mongo.getDB(dbName);
    if (!mongoDBs.contains(db)) {
      db.addUser(cfgMap.get("mongo.db.username"), cfgMap.get(
          "mongo.db.password").toCharArray());
      mongoDBs.put(dbName, db);
    }
    return db;
  }
}

MongoService.java

/************************* 版權聲明 *********************************
 *                                                               *
 *           版權所有:百洋軟件                                                    *
 *     Copyright (c) 2010 by www.po-soft.com                        *
 *                                                               *
 ************************* 變更記錄 *********************************
 *
 * 創(chuàng)建者:yongtree  創(chuàng)建日期: 2010-7-7
 * 備注:
 * 
 * 修改者:    修改日期:
 * 備注:
 * 
 */
package com.posoftframework.mongodb;
import java.util.List;
import java.util.Map;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBObject;
/**
 * 操作MongoDB的DAO接口
 * 
 * @author yongtree
 * @date 2010-7-7 下午04:44:43
 * @version 1.0
 */
public interface MongoService {
  public abstract DBCollection getCollection();
  /**
   * 根據數據集合的Map,插入數據 map的key對應數據庫中的DBCollection的key值
   * 
   * @param obj
   */
  public abstract DBObject insert(DBObject obj);
  /**
   * 根據ListMapString,Object>>結構的數據集合,插入數據
   * 
   * @param list
   */
  public abstract void insertBatch(ListDBObject> list);
  /**
   * 按照條件參數集合map,刪除數據
   * 
   * @param map
   */
  public abstract void delete(DBObject obj);
  /**
   * 按照多種條件的并集,批量刪除數據
   * 
   * @param list
   */
  public abstract void deleteBatch(ListDBObject> list);
  /**
   * 得到Collection()總的記錄數
   * 
   * @return
   */
  public abstract long getCollectionCount();
  public abstract long getCount(DBObject query);
  public abstract ListDBObject> find(DBObject query);
  public abstract ListDBObject> find(DBObject query,DBObject sort);
  public abstract ListDBObject> find(DBObject query,DBObject sort,int start,int limit);
  /**
   * 根據whereFields參數,更新setFields值
   * 
   * @param setFields
   * @param whereFields
   */
  public abstract void update(DBObject setFields,
      DBObject whereFields);
  public abstract ListDBObject> findAll();
  /**
   * 根據ID找到唯一數據 有1個id字段標記
   * 
   * @param id
   * @return
   */
  public abstract DBObject getById(String id);
  /**
   * 獲取所有數據庫名稱
   * 
   * @return
   */
  public ListString> getAllDBNames();
  public abstract String getDbName();
  public abstract void setDbName(String dbName);
  public abstract DB getDb();
  public abstract String getCollName();
  public abstract void setCollName(String collName);
}

MongoServiceImpl.java

/************************* 版權聲明 *********************************
 *                                                               *
 *           版權所有:百洋軟件                                                    *
 *     Copyright (c) 2010 by www.po-soft.com                        *
 *                                                               *
 ************************* 變更記錄 *********************************
 *
 * 創(chuàng)建者:yongtree  創(chuàng)建日期: 2010-7-7
 * 備注:
 * 
 * 修改者:    修改日期:
 * 備注:
 * 
 */
package com.posoftframework.mongodb;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.bson.types.ObjectId;
import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
/**
 * 
 * @author yongtree
 * @date 2010-7-7 下午07:22:15
 * @version 1.0
 */
public class MongoServiceImpl implements MongoService {
  private String dbName;
  private String collName;
  private DB db;
  public MongoServiceImpl(String dbName, String collName) {
    this.dbName = dbName;
    this.collName = collName;
    try {
      db = MongoDBConfig.getDBByName(this.dbName);
    } catch (Throwable e) {
      e.printStackTrace();
    }
  }
  public MongoServiceImpl() {
    getDb();
  }
  public DBCollection getCollection() {
    return db.getCollection(this.collName);
  }
  public DBObject map2Obj(MapString, Object> map) {
    DBObject obj = new BasicDBObject();
    if (map.containsKey("class")  map.get("class") instanceof Class)
      map.remove("class");
    obj.putAll(map);
    return obj;
  }
  public DBObject insert(DBObject obj) {
    getCollection().insert(obj);
    return obj;
  }
  public void insertBatch(ListDBObject> list) {
    if (list == null || list.isEmpty()) {
      return;
    }
    ListDBObject> listDB = new ArrayListDBObject>();
    for (int i = 0; i  list.size(); i++) {
      listDB.add(list.get(i));
    }
    getCollection().insert(listDB);
  }
  public void delete(DBObject obj) {
    getCollection().remove(obj);
  }
  public void deleteBatch(ListDBObject> list) {
    if (list == null || list.isEmpty()) {
      return;
    }
    for (int i = 0; i  list.size(); i++) {
      getCollection().remove(list.get(i));
    }
  }
  public long getCollectionCount() {
    return getCollection().getCount();
  }
  public long getCount(DBObject obj) {
    if (obj != null)
      return getCollection().getCount(obj);
    return getCollectionCount();
  }
  public ListDBObject> find(DBObject obj) {
    DBCursor cur = getCollection().find(obj);
    return DBCursor2list(cur);
  }
  @Override
  public ListDBObject> find(DBObject query, DBObject sort) {
    DBCursor cur;
    if (query != null) {
      cur = getCollection().find(query);
    } else {
      cur = getCollection().find();
    }
    if (sort != null) {
      cur.sort(sort);
    }
    return DBCursor2list(cur);
  }
  @Override
  public ListDBObject> find(DBObject query, DBObject sort, int start,
      int limit) {
    DBCursor cur;
    if (query != null) {
      cur = getCollection().find(query);
    } else {
      cur = getCollection().find();
    }
    if (sort != null) {
      cur.sort(sort);
    }
    if (start == 0) {
      cur.batchSize(limit);
    } else {
      cur.skip(start).limit(limit);
    }
    return DBCursor2list(cur);
  }
  private ListDBObject> DBCursor2list(DBCursor cur) {
    ListDBObject> list = new ArrayListDBObject>();
    if (cur != null) {
      list = cur.toArray();
    }
    return list;
  }
  public void update(DBObject setFields, DBObject whereFields) {
    getCollection().updateMulti(setFields, whereFields);
  }
  public ListDBObject> findAll() {
    DBCursor cur = getCollection().find();
    ListDBObject> list = new ArrayListDBObject>();
    if (cur != null) {
      list = cur.toArray();
    }
    return list;
  }
  public DBObject getById(String id) {
    DBObject obj = new BasicDBObject();
    obj.put("_id", new ObjectId(id));
    DBObject result = getCollection().findOne(obj);
    return result;
  }
  public String getDbName() {
    return dbName;
  }
  public void setDbName(String dbName) {
    this.dbName = dbName;
    this.db = MongoDBConfig.getDBByName(this.dbName);
  }
  public String getCollName() {
    return collName;
  }
  public void setCollName(String collName) {
    this.collName = collName;
  }
  public DB getDb() {
    if (this.db == null) {
      if (this.dbName == null) {
        this.db = MongoDBConfig.getDB();
      } else {
        this.db = MongoDBConfig.getDBByName(this.dbName);
      }
    }
    return this.db;
  }
  public ListString> getAllDBNames() {
    return MongoDBConfig.getDBNames();
  }
}

您可能感興趣的文章:
  • Java的idea連接mongodb數據庫的詳細教程
  • Java操作MongoDB數據庫方法詳解
  • Java單例模式下的MongoDB數據庫操作工具類
  • Java操作Mongodb數據庫實現數據的增刪查改功能示例
  • 【MongoDB for Java】Java操作MongoDB數據庫
  • java實現mongodb的數據庫連接池
  • Java操作MongoDB數據庫的示例代碼

標簽:鶴崗 丹東 邯鄲 本溪 景德鎮(zhèn) 昭通 大理 吉安

巨人網絡通訊聲明:本文標題《Java操作MongoDB數據庫示例分享》,本文關鍵詞  Java,操作,MongoDB,數據庫,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Java操作MongoDB數據庫示例分享》相關的同類信息!
  • 本頁收集關于Java操作MongoDB數據庫示例分享的相關信息資訊供網民參考!
  • 推薦文章
    丹江口市| 巴里| 余干县| 大石桥市| 玛纳斯县| 威海市| 信丰县| 竹溪县| 诏安县| 长垣县| 饶阳县| 长白| 永城市| 临泉县| 泽普县| 嵊州市| 肇东市| 松阳县| 大城县| 平塘县| 绥芬河市| 横山县| 平遥县| 满洲里市| 萨迦县| 土默特右旗| 正安县| 红河县| 吴桥县| 延寿县| 辉南县| 华安县| 清原| 中宁县| 临洮县| 汕头市| 康保县| 安康市| 扎鲁特旗| 皮山县| 页游|