亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

Java操作MongoDB數據庫示例分享

2020-10-29 18:53:09
字體:
來源:轉載
供稿:網友

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 Map<String, String> cfgMap = new HashMap<String, String>();  private static Hashtable<String, DB> mongoDBs = new Hashtable<String, 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 List<String> 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);  /**   * 根據List<Map<String,Object>>結構的數據集合,插入數據   *    * @param list   */  public abstract void insertBatch(List<DBObject> list);  /**   * 按照條件參數集合map,刪除數據   *    * @param map   */  public abstract void delete(DBObject obj);  /**   * 按照多種條件的并集,批量刪除數據   *    * @param list   */  public abstract void deleteBatch(List<DBObject> list);  /**   * 得到Collection()總的記錄數   *    * @return   */  public abstract long getCollectionCount();  public abstract long getCount(DBObject query);  public abstract List<DBObject> find(DBObject query);  public abstract List<DBObject> find(DBObject query,DBObject sort);  public abstract List<DBObject> 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 List<DBObject> findAll();  /**   * 根據ID找到唯一數據 有1個id字段標記   *    * @param id   * @return   */  public abstract DBObject getById(String id);  /**   * 獲取所有數據庫名稱   *    * @return   */  public List<String> 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(Map<String, 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(List<DBObject> list) {    if (list == null || list.isEmpty()) {      return;    }    List<DBObject> listDB = new ArrayList<DBObject>();    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(List<DBObject> 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 List<DBObject> find(DBObject obj) {    DBCursor cur = getCollection().find(obj);    return DBCursor2list(cur);  }  @Override  public List<DBObject> 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 List<DBObject> 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 List<DBObject> DBCursor2list(DBCursor cur) {    List<DBObject> list = new ArrayList<DBObject>();    if (cur != null) {      list = cur.toArray();    }    return list;  }  public void update(DBObject setFields, DBObject whereFields) {    getCollection().updateMulti(setFields, whereFields);  }  public List<DBObject> findAll() {    DBCursor cur = getCollection().find();    List<DBObject> list = new ArrayList<DBObject>();    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 List<String> getAllDBNames() {    return MongoDBConfig.getDBNames();  }}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人免费在线视频| 亚洲第一中文字幕在线观看| 97超级碰碰人国产在线观看| 日韩久久免费电影| 午夜精品久久久久久99热| 亚洲午夜激情免费视频| 2019亚洲日韩新视频| 国产精品日韩欧美| 欧美一级淫片播放口| 国产精品久久久久久中文字| 九九热视频这里只有精品| 色系列之999| 91综合免费在线| 久久五月天综合| 欧美激情免费看| 69久久夜色精品国产69| 国产精品日日摸夜夜添夜夜av| 日韩电影在线观看中文字幕| 2020欧美日韩在线视频| 亚洲美女喷白浆| 国产成人精品久久| 国产成人精品免高潮费视频| 亚洲欧美日韩国产成人| 精品日韩中文字幕| 久久99青青精品免费观看| 欧美人成在线视频| 欧美激情第1页| 国产精品综合不卡av| 欧美一级大胆视频| 日韩福利伦理影院免费| 精品无人区乱码1区2区3区在线| 欧美专区福利在线| 欧美性xxxxx极品| 久久久女女女女999久久| 日韩精品免费在线视频观看| 中文字幕v亚洲ⅴv天堂| 亚洲日韩第一页| 国语自产在线不卡| 成人免费观看49www在线观看| 一本色道久久88精品综合| 国产女精品视频网站免费| 国产亚洲欧美日韩一区二区| 欧美成人午夜剧场免费观看| 亚洲欧美国产视频| 国产精品欧美日韩一区二区| 精品成人国产在线观看男人呻吟| 91精品国产91久久久| 亚洲福利视频免费观看| 热99在线视频| 欧美猛交ⅹxxx乱大交视频| 精品久久久91| 欧美精品18videosex性欧美| 韩国三级日本三级少妇99| 久久综合免费视频影院| 亚洲人成在线观看网站高清| 国产一区视频在线播放| 久久精品免费播放| 蜜臀久久99精品久久久无需会员| 亚洲一区二区国产| 亚洲桃花岛网站| 欧美最近摘花xxxx摘花| 久久久久久这里只有精品| 日韩经典中文字幕在线观看| 久久久国产一区二区三区| 91久久嫩草影院一区二区| 不卡毛片在线看| 国产亚洲视频在线观看| 国产美女直播视频一区| 91亚洲精品一区二区| 欧美大全免费观看电视剧大泉洋| 情事1991在线| 中文欧美在线视频| 亚洲精品中文字幕女同| 欧美重口另类videos人妖| 国产高清视频一区三区| 亚洲欧美三级伦理| 91久久精品国产| www国产精品视频| 国产视频亚洲精品| 国产一区二区黑人欧美xxxx| 国产日韩中文在线| 97香蕉超级碰碰久久免费的优势| 中文字幕无线精品亚洲乱码一区| 91欧美日韩一区| 91欧美激情另类亚洲| 国产精品网红福利| 成人国产精品日本在线| 少妇激情综合网| 亚洲第一页在线| www.国产精品一二区| 日韩成人中文字幕| 成人午夜在线观看| 亚洲情综合五月天| 久久视频在线观看免费| 国模吧一区二区三区| 精品久久久国产精品999| 日韩精品在线观看视频| 亚洲精品久久久久久久久久久久| 欧美日韩xxxxx| 久久国产精品首页| 国产激情久久久久| 91视频-88av| 久久视频精品在线| 91丝袜美腿美女视频网站| 色偷偷噜噜噜亚洲男人| 亚洲精品视频中文字幕| 欧美在线视频免费| 午夜精品在线视频| 欧美日韩一区二区三区在线免费观看| 91久久精品国产91久久| 国色天香2019中文字幕在线观看| 欧美性猛交xxxx久久久| 午夜精品国产精品大乳美女| 亚洲色图综合网| 精品久久久久久中文字幕大豆网| 国产91精品在线播放| 91成人天堂久久成人| 91精品国产91久久久久久| 中文字幕久热精品视频在线| 日韩免费观看av| 91美女片黄在线观| 日本成熟性欧美| 国产精品精品视频| 不卡中文字幕av| 亚洲最大福利视频网站| 91精品久久久久久久久久久久久| 国产精品久久久久久亚洲影视| 亚洲欧美精品在线| 日韩在线视频网站| 一本一本久久a久久精品综合小说| 国产精品偷伦视频免费观看国产| 91亚洲永久免费精品| 欧美日韩一区二区在线| 久久久这里只有精品视频| 国产在线播放不卡| 精品人伦一区二区三区蜜桃网站| 福利一区福利二区微拍刺激| 亚洲国产精品久久91精品| 精品久久久免费| 亚洲一区二区三区乱码aⅴ| 欧美成人免费在线视频| 亚洲国产精久久久久久久| 欧美日韩一区免费| 成人午夜黄色影院| 91久久精品国产91久久性色| 精品久久久久久久大神国产| 亚洲女人初尝黑人巨大| 日韩欧美亚洲成人| 精品女厕一区二区三区| 亚洲国产成人精品女人久久久| 2019国产精品自在线拍国产不卡| 美女扒开尿口让男人操亚洲视频网站| 国产免费观看久久黄| 欧美黑人xxx| 亚洲欧美福利视频| 成人美女免费网站视频| 久久免费国产视频| 国产一区二区三区视频| 欧美日韩一区二区在线播放| 国产精品欧美久久久| 国产精品亚洲美女av网站| 日韩中文在线中文网在线观看| 久久艹在线视频| 社区色欧美激情 |