亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

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

Java操作MongoDB數據庫示例分享

熱門標簽:智能電銷機器人銷售話術 企業智能外呼系統價格多少 高德地圖標注商戶位置 福州電銷機器人源代碼 徐州ai電銷機器人原理 兗州電話外呼營銷系統 機器人外呼系統軟件存在問題 南京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/>
   * 如果不存在,則創建一個該名稱的數據庫,并設置用戶名和密碼為配置文件中的參數值/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                        *
 *                                                               *
 ************************* 變更記錄 *********************************
 *
 * 創建者:yongtree  創建日期: 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                        *
 *                                                               *
 ************************* 變更記錄 *********************************
 *
 * 創建者:yongtree  創建日期: 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數據庫的示例代碼

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

巨人網絡通訊聲明:本文標題《Java操作MongoDB數據庫示例分享》,本文關鍵詞  Java,操作,MongoDB,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Java操作MongoDB數據庫示例分享》相關的同類信息!
  • 本頁收集關于Java操作MongoDB數據庫示例分享的相關信息資訊供網民參考!
  • 推薦文章
    韩国毛片免费大片| 青草国产在线观看| 台湾毛片| 99色视频在线观看| 国产伦理精品| 国产a视频| 亚洲第一色在线| 二级特黄绝大片免费视频大片| 日韩男人天堂| 国产成人女人在线视频观看| 成人免费观看视频| 国产成人欧美一区二区三区的| 91麻豆精品国产综合久久久| 高清一级做a爱过程不卡视频| 国产极品精频在线观看| a级毛片免费观看网站| 日韩专区亚洲综合久久| 日韩男人天堂| 欧美另类videosbestsex视频| 亚洲wwwwww| 国产视频一区在线| 夜夜操网| 精品国产一区二区三区久久久蜜臀| 99久久精品国产国产毛片 | 精品视频在线看 | 麻豆网站在线看| 香蕉视频久久| 国产亚洲精品成人a在线| 国产一区二区精品尤物| 台湾美女古装一级毛片| 久久久久久久久综合影视网| 青青久久精品| 亚欧成人乱码一区二区| 麻豆网站在线免费观看| 精品国产三级a| 成人高清视频在线观看| 久久福利影视| 亚洲精品中文字幕久久久久久| 日本特黄特色aa大片免费| 欧美一区二区三区在线观看| 你懂的日韩| 欧美大片a一级毛片视频| 欧美另类videosbestsex久久| 香蕉视频久久| 国产成人女人在线视频观看| 日韩在线观看网站| 国产网站在线| 欧美激情一区二区三区视频| 中文字幕97| 久久精品大片| a级毛片免费全部播放| 日韩欧美一及在线播放| 国产国语对白一级毛片| 成人免费观看网欧美片| 一级女性全黄久久生活片| 美女免费毛片| 免费一级片在线| 国产a免费观看| 免费毛片播放| 青青久久精品国产免费看| 亚洲精品永久一区| 国产成人女人在线视频观看| 91麻豆精品国产高清在线| 成人免费观看网欧美片| 成人a大片在线观看| 一本伊大人香蕉高清在线观看| 日本特黄特色aa大片免费| 成人av在线播放| 99久久精品国产国产毛片 | 欧美1卡一卡二卡三新区| 欧美18性精品| 高清一级毛片一本到免费观看| 欧美激情一区二区三区在线播放| 久草免费在线观看| 精品国产三级a| 青青久久精品| 国产美女在线观看| 欧美激情影院| 日韩专区在线播放| 国产一区二区精品在线观看| 一级毛片视频播放| 欧美激情伊人| 精品国产一区二区三区国产馆| 精品国产亚洲人成在线| 九九热精品免费观看| 精品国产亚一区二区三区| 青青久热| 久久99中文字幕| 欧美一级视频免费| 成人a大片在线观看| 91麻豆精品国产自产在线 | 99色吧| 国产美女在线观看| 九九久久99综合一区二区| 999精品在线| 国产原创视频在线| 久久精品大片| 99色吧| 日韩免费在线视频| 国产一区二区精品尤物| 成人免费观看视频| 99久久精品国产高清一区二区 | 青青青草影院 | 一级女性大黄生活片免费| 四虎影视库| 青青青草影院 | 午夜欧美成人香蕉剧场| 尤物视频网站在线| 精品国产三级a| 成人免费观看的视频黄页| 久久福利影视| 黄色免费三级| 国产成人精品影视| 国产高清在线精品一区a| 四虎影视库国产精品一区| 日韩专区亚洲综合久久| 成人a大片高清在线观看| 国产不卡在线播放| 成人在激情在线视频| 国产一区二区福利久久| 四虎影视库国产精品一区| 色综合久久天天综合绕观看| 日本在线不卡免费视频一区| 日日夜夜婷婷| 精品国产香蕉在线播出 | 午夜在线影院| 国产一区二区精品久久91| 毛片的网站| 亚洲wwwwww| 尤物视频网站在线| 高清一级做a爱过程不卡视频| 欧美一级视频免费| 欧美a级v片不卡在线观看| 四虎影视久久久| 色综合久久手机在线| 91麻豆精品国产片在线观看| 99久久精品国产国产毛片 | 国产一区二区精品在线观看| 精品国产三级a| 黄色短视屏| 国产不卡在线观看| 可以在线看黄的网站| 九九干| 欧美激情一区二区三区视频高清| 精品久久久久久中文字幕2017| 国产高清在线精品一区a| 亚洲天堂免费| 91麻豆精品国产综合久久久| 色综合久久手机在线| 精品国产三级a| 精品在线观看一区| 人人干人人插| 国产亚洲精品aaa大片| 国产综合91天堂亚洲国产| 欧美a级片视频| 国产不卡精品一区二区三区| 一级毛片视频免费| 免费国产在线观看不卡| 国产综合91天堂亚洲国产| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品久久久久久中文| 久久成人亚洲| 一a一级片| 久久国产影院| 国产一区二区精品| 国产网站免费在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 二级片在线观看| 午夜欧美成人久久久久久| 毛片的网站| 欧美一区二区三区性| 99色精品| 香蕉视频亚洲一级| 美国一区二区三区| 欧美激情在线精品video| 国产一区免费在线观看| 韩国三级视频网站| 国产原创视频在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 青青久热| 精品视频一区二区| 99久久网站| 一级女性全黄久久生活片| 色综合久久天天综合| 国产精品123| 久久精品免视看国产成人2021| 国产麻豆精品免费密入口| 黄视频网站免费看| 久久福利影视| 天天做日日爱夜夜爽| 精品视频在线看 | 色综合久久天天综线观看| 99久久精品费精品国产一区二区| 黄色免费网站在线| 国产一区二区精品| 麻豆午夜视频| 亚洲 男人 天堂| 国产麻豆精品免费视频| 九九九国产| 日日爽天天|