MongoDB项目中常用方法
使用MongoDB连接池MongoOptions来进行连接 以及相关方法的调用
//获得驱动地址(这里的驱动 写入了配置文件中)
String serverAddressStr = Configure.getInstance().getProperty("SERVER_ADDRESSES");
log.debug("serverAddressStr:" + serverAddressStr); 如果需要连接的MongoDB为多个,则用逗号分隔开,加入集合中以便后续使用
String[] serverAddressArray = serverAddressStr.split(",");
for (String address : serverAddressArray) {
log.debug("address:" + address);
addresslist.add(new ServerAddress(address));
}
//声明MongoOptions对象
MongoOptions options = new MongoOptions();
//autoConnectRetry方法用于在连接失败后是否重新连接,可写成配置项
String autoConnectRetry = Configure.getInstance().getProperty("AUTO_CONNECT_RETRY");
if (StringUtils.isNotEmpty(autoConnectRetry)) {
options.autoConnectRetry = Boolean.valueOf(autoConnectRetry);
}
//设置连接池的大小也可写成配置项 方便以后调整 使用的是autoConnectRetry方法
String connectionsPerHost = Configure.getInstance().getProperty("CONNECTIONS_PER_HOST");
if (StringUtils.isNotEmpty(connectionsPerHost)) {
options.connectionsPerHost = Integer.valueOf(connectionsPerHost);
}
//线程队列
String threadsAllowedToBlockForConnectionMultiplier = Configure.getInstance().getProperty("THREAD_ALLOWED");
log.debug("[THREAD_ALLOWED]:" + threadsAllowedToBlockForConnectionMultiplier);
if (StringUtils.isNotEmpty(threadsAllowedToBlockForConnectionMultiplier)) {
options.threadsAllowedToBlockForConnectionMultiplier = Integer.valueOf(threadsAllowedToBlockForConnectionMultiplier);
}
//最大阻塞时间
String connectTimeout = Configure.getInstance().getProperty("CONNECT_TIME_OUT");
log.debug("[CONNECT_TIME_OUT]:" + connectTimeout);
if (StringUtils.isNotEmpty(connectTimeout)) {
options.connectTimeout = Integer.valueOf(connectTimeout);
}
// 被阻塞线程从连接池获取连接的最长等待时间(ms)
// options.maxWaitTime = 12000;
String maxWaitTime = Configure.getInstance().getProperty("MAX_WAIT_TIME");
log.debug("[MAX_WAIT_TIME]:" + maxWaitTime);
if (StringUtils.isNotEmpty(maxWaitTime)) {
options.maxWaitTime = Integer.valueOf(maxWaitTime);
}
// 是否答应驱动从次要节点读取数据,默认为false
String slaveOk = Configure.getInstance().getProperty("SlAVE_OK");
log.debug("[SlAVE_OK]:" + slaveOk);
if (StringUtils.isNotEmpty(slaveOk)) {
options.slaveOk = Boolean.valueOf(slaveOk);
}
从某个中按照字段查找相应数据 并放入集合中
public DBObject findOne(String collectionName,String keystr,String value){
DB db = this.getDB();
DBCollection collection = db.getCollection(collectionName);
DBObject dbObject;
try {
dbObject = collection.findOne(new BasicDBObject(keystr, value));
log.debug("dbObject1:" + dbObject);
if (dbObject == null) {
db = this.switchCluster().getDB();
collection = db.getCollection(collectionName);
dbObject = collection.findOne(new BasicDBObject(keystr, value));
log.debug("dbObject1-2:" + dbObject);
}
} catch (MongoException e) {
db = this.switchCluster().getDB();
collection = db.getCollection(collectionName);
dbObject = collection.findOne(new BasicDBObject(keystr, value));
log.debug("dbObject2:" + dbObject);
}
return dbObject;
}
前台通过DBCollection 根据名称获取相应的value 然后加入list中~
public List<DBObject> getValue(List<String> columnNames) {
db = MongoDB.getInstance().getDB();
DBCollection collection = db.getCollection("labels");
List<DBObject> list = new ArrayList<DBObject>();
BasicDBList dbList = new BasicDBList();
dbList.addAll(columnNames);
DBObject inObj = new BasicDBObject("$in", dbList);
DBCursor cursor = collection.find(new BasicDBObject("column_name", inObj));
DBObject dbObj = null;
while (cursor.hasNext()) {
dbObj = cursor.next();
list.add(dbObj);
}
return list;
MongoDB项目中常用方法的更多相关文章
- 项目中常用方法总结(将将DataTable数据集映射到实体对象)【转】
本篇把项目中用到的一些通用方法总结出来, 这些方法因为经常需要在项目中用到,所以把它们归纳在一起, 形成一个.dll 文件是一个理想的选择. 这样也便于日后缩短开发周期. 一. 把一个DataGrid ...
- MongoDB在实际项目中的使用
MongoDB简介 MongoDB是近些年来流行起来的NoSql的代表,和传统数据库最大的区别是支持文档型数据库. 当然,现在的一些数据库通过自定义复合类型,可变长数组等手段也可以模拟文档型数据库. ...
- 使用MongoDB在项目中实际运用
一.MongoDB,一个数据库,我们怎么去使用它呢?我们首先了解一下什么是MongoDb 官网的介绍是:MongoDB是专为可扩展性,高性能和高可用性而设计的数据库.它可以从单服务器部署扩展到大型.复 ...
- .Net Core ORM选择之路,哪个才适合你 通用查询类封装之Mongodb篇 Snowflake(雪花算法)的JavaScript实现 【开发记录】如何在B/S项目中使用中国天气的实时天气功能 【开发记录】微信小游戏开发入门——俄罗斯方块
.Net Core ORM选择之路,哪个才适合你 因为老板的一句话公司项目需要迁移到.Net Core ,但是以前同事用的ORM不支持.Net Core 开发过程也遇到了各种坑,插入条数多了也特别 ...
- Java enum枚举在实际项目中的常用方法
在项目实际开发过程中,经常会遇到对某些固定的值.字典项的定义的需求,很多项目经常使用常量来定义,其实在jdk1.5就已经引入了枚举,使用枚举可以更好的解决这类需求,本文主要记录枚举的优势以及经常在项目 ...
- NoSql非关系型数据库之MongoDB应用(三):MongoDB在项目中的初步应用
业精于勤,荒于嬉:行成于思,毁于随. 我们可以结合相关的IDE做一个简单的增删改查了,实现MongoDB在项目中的初步应用. 前提是安装了MongoDB服务和MongoDB可视化工具,没有安装的可以点 ...
- Git Bash+EGit在项目中配合使用最常用方法总结(根据场景使用)
最近在项目中使用Git进行代码管理,之前一直用SVN进行管理,现在谈一谈Git在项目中如何与EGit插件配合使用,高效同步开发. 使用过SVN一段时间的人,初识Git一定感觉很别扭,发现会遇到各种各样 ...
- Mongo基础使用,以及在Express项目中使用Mongoose
MongoDB的基本使用 MongoDB特点: 使用BSON存储数据 支持相对丰富的查询操作(相对其他nosql数据库) 支持索引 副本集(支持多个实例/多个服务器运行同个数据库) 分片(数据库水平扩 ...
- 在WebStorm环境中给nodejs项目中添加packages
照前文 http://www.cnblogs.com/wtang/articles/4133820.html 给电脑设置了WebStorm的IDE的nodejs开发环境.新建了个express的网站 ...
随机推荐
- 前端面试库_JS部分_02
今天小编做了一个伟大的决定-----把我的初恋追回来.她在我心中一直是美好的,以前也人渣过,脑袋发热过,到了现在才真的是想有一个人陪伴着我,我与她约定晚些相见,我相信这个时间不会很久,虽然三年没有联系 ...
- EXT3_DX_ADD_ENTRY: DIRECTORY INDEX FULL!
inode问题故障1例故障关键字:ext3_dx_add_entry: Directory index full! 线上业务的一台服务器无缘无故突然挂了让机房帮忙连接显示器后发现报错 http://i ...
- JVMInternals
http://blog.jamesdbloom.com/JVMInternals.html http://blog.jamesdbloom.com/JavaCodeToByteCode_PartOne ...
- InvokeRequired和Invoke
C#中禁止跨线程直接访问控件,InvokeRequired是为了解决这个问题而产生的,当一个控件的InvokeRequired属性值为真时,说明有一个创建它以外的线程想访问它.此时它将会在内部调用ne ...
- lucene 基本原理整理
基本原理:http://www.cnblogs.com/forfuture1978/archive/2009/12/14/1623594.html 所有过程:http://www.cnblogs.co ...
- 胶囊碰撞体(CapsuleCollider)
胶囊碰撞体 (Capsule Collider) 胶囊碰撞体 (Capsule Collider) 由两个半球体与一个圆柱体相连接而构成.它与胶囊 (Capsule) 基元形状相同. 一堆胶囊碰撞 ...
- AIDL Service Android进程间通信机制
转载出处:http://www.apkbus.com/home.php?mod=space&do=blog&uid=664680&id=59465 我们知道,在Android ...
- linux服务之upstart与systemd
http://blog.fens.me/linux-upstart/ rpm -ql initscripts|more [root@84-monitor init]# rpm -qf /etc/ini ...
- 去掉linux 系统vi中出现^M字符的方法
转http://www.cnblogs.com/xudong-bupt/p/3584625.html ^M符号是windows系统下的換行符,在windows下的文本通过bin模式ftp上传到了unx ...
- newman 3.0改变
https://github.com/postmanlabs/newman/blob/develop/MIGRATION.md