mongo小记
进mongo mongo 先添加admin表的账号密码 . use admin
.
db.createUser(
{
user: "admin",
pwd: "admin",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
. db.auth('admin','admin')
在admin登录情况下,切换到自己数据库操作 . use test
. db.createUser({user:'test',pwd:'test',roles:[{role:"dbOwner",db:"test"}]})
退出重新登录 . mongo
. use test
. db.auth('test','test')
import com.mongodb.MongoClient;
import com.mongodb.MongoClientOptions;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase; import org.bson.Document;
import org.bson.types.ObjectId;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.stereotype.Repository; import java.util.ArrayList;
import java.util.Arrays;
import java.util.List; /**
* mongodb数据库操作
*
* @author Duan Yong
* @since 2016/11/11.
*/
@Repository
@SuppressWarnings("unchecked")
public class MongoDAO implements InitializingBean { private static Logger LOGGER = LoggerFactory.getLogger(MongoDAO.class);
private static MongoDatabase db; /**
* 根据名字获取数据库表
*/
public MongoCollection getCollection(String name) {
return db.getCollection(name);
} /**
* 返回文档list
*/
public List<Document> find(String collectionName, Document query, Document key, Document order, int skip,
int limit) {
MongoCollection collection = db.getCollection(collectionName);
List<Document> result = new ArrayList<>();
if (query == null) {
return result;
}
FindIterable<Document> iterable = collection.find(query);
if (order != null) {
iterable = iterable.sort(order);
}
if (skip > 0) {
iterable = iterable.skip(skip);
}
if (limit > 0) {
iterable = iterable.limit(limit);
}
if (key != null) {
iterable = iterable.projection(key);
}
iterable.into(result);
return result;
} /**
* 根据_id删除记录
*/
public void deleteById(String collectionName, String id) {
MongoCollection<Document> collection = db.getCollection(collectionName);
collection.deleteOne(new Document("_id", new ObjectId(id)));
} /**
* 根据查询条件删除记录
*/
public void delete(String collectionName, Document query) {
MongoCollection<Document> collection = db.getCollection(collectionName);
collection.deleteMany(query);
} /**
* 根据查询条件返回第一条
*
* @param collectionName,数据库名
* @param query,数据库表中记录id
*/
public Document findOne(String collectionName, Document query) {
MongoCollection<Document> collection = db.getCollection(collectionName);
return collection.find(query).first();
} /**
* 插入一条记录到数据库
*/
public void insert(String collectionName, Document document) {
MongoCollection collection = db.getCollection(collectionName);
collection.insertOne(document);
} /**
* 更新记录
*/
public void updateById(String collectionName, ObjectId id, Document document) {
MongoCollection collection = db.getCollection(collectionName);
collection.updateOne(new Document("_id",id), new Document("$set", document));
} @Override
public void afterPropertiesSet() throws Exception {
MongoClientOptions mongoClientOptions = new MongoClientOptions.Builder()
.connectionsPerHost(PropertiesUtil.getInt("mongoDB.option.activeConnectionCount", 10))
.connectTimeout(PropertiesUtil.getInt("mongoDB.option.connectTimeout"))
.socketTimeout(PropertiesUtil.getInt("mongoDB.option.socketTimeout"))
.maxWaitTime(PropertiesUtil.getInt("mongoDB.option.maxWaitTime"))
.threadsAllowedToBlockForConnectionMultiplier(
PropertiesUtil.getInt("mongoDB.option.threadsAllowedToBlockForConnectionMultiplier"))
.build();
String address = PropertiesUtil.get("mongoDB.address");
String database = PropertiesUtil.get("mongoDB.database");
String user = PropertiesUtil.get("mongoDB.user");
String pwd = PropertiesUtil.get("mongoDB.pwd");
try {
List<ServerAddress> serverAddresses = new ArrayList<>();
for (String add : address.split(" ")) {
serverAddresses.add(new ServerAddress(add));
}
MongoCredential credential = MongoCredential.createCredential(user, database, pwd.toCharArray());
MongoClient mongoClient = new MongoClient(serverAddresses, Arrays.asList(credential), mongoClientOptions);
db = mongoClient.getDatabase(database);
LOGGER.info("init mongoDao : " + address);
} catch (Exception e) {
LOGGER.error("init mongoDao error", e);
}
}
}
PS:propertisUtil自己写一个吧
mongo小记的更多相关文章
- MongoDB 小记
之前本人说过一款非关系型数据库的代表 Redis 的 < Redis 小记 >文章,觉得意犹未尽,今天就来介绍一款数据库 MongoDB ,先来看一下 MongoDB是一款基于分布式文件存 ...
- 谈一谈NOSQL的应用,Redis/Mongo
1.心路历程 上年11月份来公司了,和另外一个同事一起,做了公司一个移动项目的微信公众号,然后为了推广微信公众号,策划那边需要我们做一些活动,包括抽奖,投票.最开始是没有用过redis的,公司因为考虑 ...
- [原]Paste.deploy 与 WSGI, keystone 小记
Paste.deploy 与 WSGI, keystone 小记 名词解释: Paste.deploy 是一个WSGI工具包,用于更方便的管理WSGI应用, 可以通过配置文件,将WSGI应用加载起来. ...
- MongoDB分组汇总操作,及Spring data mongo的实现
转载请在页首注明作者与出处 一:分组汇总 1.1:SQL样例 分组汇总的应用场景非常多,比如查询每个班级的总分是多少,如果用关系形数据库,那么sql是这样子的 ),class from score g ...
- mongo DB for C#
(1)Download the MongoDB C#驱动. http://www.nuget.org/packages/mongocsharpdriver/. (2) Add Reference to ...
- MySql 小记
MySql 简单 小记 以备查看 1.sql概述 1.什么是sql? 2.sql发展过程? 3.sql标准与方言的关系? 4.常用数据库? 5.MySql数据库安装? 2.关键概念 表结构----- ...
- Mongo基础使用,以及在Express项目中使用Mongoose
MongoDB的基本使用 MongoDB特点: 使用BSON存储数据 支持相对丰富的查询操作(相对其他nosql数据库) 支持索引 副本集(支持多个实例/多个服务器运行同个数据库) 分片(数据库水平扩 ...
- 【mongo】mongoVUE使用
1.查询存在字段"test"的项 {"test":{$exists:true}} 2.在表中插入字段 {$set:{"}} 3.正则匹配 {" ...
- Git小记
Git简~介 Git是一个分布式版本控制系统,其他的版本控制系统我只用过SVN,但用的时间不长.大家都知道,分布式的好处多多,而且分布式已经包含了集中式的几乎所有功能.Linus创造Git的传奇经历就 ...
随机推荐
- 分布式流式计算平台——S4
本文是作者在充分阅读和理解Yahoo!最新发布的技术论文<S4:Distributed Stream Computing Platform>的基础上,所做出的知识分享. S4是Yahoo! ...
- Navicat 连接阿里云RDS
背景: Navicat 是一个非常优秀与易用的数据库可视化管理软件,相信很多人都用过.这次服务器升级,数据库用了阿里云的RDS,阿里云自带的数据库管理面板功能有限,用不习惯.所以还是想着用 Navic ...
- Docker私有仓库Registry实战
参考: https://www.cnblogs.com/soar1688/p/6828329.html 1. 关于Registry 官方的Docker hub是一个用于管理公共镜像的好地方,我们可以在 ...
- (zxing.net)二维码PDF417的简介、实现与解码
一.简介 二维码PDF417是一种堆叠式二维条码.PDF417条码是由美国SYMBOL公司发明的,PDF(Portable Data File)意思是“便携数据文件”.组成条码的每一个条码字符由4个条 ...
- [Oracle]Oracle部分函数
1.nvl(a,b) 若a为null,则b 2.to_char(date,'YY-MM-DD') 按格式将date类型转为字符串 to_date('1999/1/1','YY-MM-DD') 将字符串 ...
- 记开发个人图书收藏清单小程序开发(五)Web开发
决定先开发Web端试试. 新增Web应用: 选择ASP.NET Core Web Application,填写好Name和Location,然后点击OK. 注意红框标出来的,基于.NET Core 2 ...
- Ubuntu add-apt-repository: command not found
在Ubuntu下,时不时会有这个错误的. add-apt-repository: command not found 这个是缺少程序,安装一下就可以了.只是不知道安装的名字. 按以下命令走一趟就可以的 ...
- scrapy 资料整合
先看看scrapy的框架流程, 1,安装 scrapy 链接 查看即可. 2,新建scrapy项目 scrapy startproject 项目名 目录结构图 3,cd到项目名下,创建任务. scra ...
- Java概念辨析:equals和== equals和hashCode
1. equals和== ======================================================================================= ...
- tomcat 线程模型
最近看到了内网ATA上的一篇断网故障时Mtop触发tomcat高并发场景下的BUG排查和修复(已被apache采纳),引起了我的好奇,感觉原作者对应底层十分了解,写的很复杂.原来对于tomcat的线程 ...