Java中使用MongoDB
一、为MongoDB设置用户名和密码
MongoDB中验证用户和密码的条件:
1. 服务器启动的时候打开授权认证,即修改MongoDB的配置文件mongodb.conf,增auth = true
# 设置数据目录的路径
dbpath = E:\programs\mongodb-4.0.\db # 设置日志信息的文件路径(需要写日志文件时,取消注释)
# logpath = E:\programs\mongodb-4.0.\log\mongodb.log # 打开日志输出操作(需要写日志文件时,取消注释)
# logappend = true # 需要用户验证;不需要用户时使用:noauth = true
auth = true port =
启动mongodb sever
mongod -f E:\programs\mongodb-4.0.8\mongodb.conf
2. 需要配置用户名和密码
用户名和密码是针对某个数据库的,首先切换到指定的数据库上,比如zs数据库
use zs
创建一个可以读写的角色,用户名为zs,密码为1
db.createUser({
"user" : "zs",
"pwd" : "1",
"roles" : [{"role" : "readWrite","db" : "zs"}]});
使用用户名和密码登陆mongodb的zs数据库
mongo localhost:27001/zs -u zs -p 1
二、在Java中使用MongoDB,以IDEA为例
1. 先建一个简单的Java工程,并在其中加入MongoDB的driver包
选择“File”菜单中的“Project Structure”菜单,按下图的右图数字顺序,添加mongodb-driver包、bson包和mongodb-driver-core包,新版本的mongodb要依赖上面三个包,注意要保证三个包的版本一致。如果缺少某个包的话,虽然编辑时没有提示错误,但运行时可能出错。
三个包的下载地址:
https://repo1.maven.org/maven2/org/mongodb
https://oss.sonatype.org/content/repositories/releases/org/mongodb
之后,可以看到已添加mongodb-driver包
2. Java操作Mongodb示例
package com.mongodb.demo; import com.mongodb.BasicDBObject;
import com.mongodb.MongoClient;
import com.mongodb.MongoClientURI;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.result.DeleteResult;
import com.mongodb.client.result.UpdateResult;
import org.bson.Document; import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern; public class Mongo3DemoJ {
public static void main(String[] args){
// 定义连接的URI地址
MongoClientURI uri = new MongoClientURI("mongodb://zs:1@localhost:27001/zs");
MongoClient client = new MongoClient(uri);
// 获取数据库
MongoDatabase db = client.getDatabase("zs");
// 获取集合(表)
MongoCollection col = db.getCollection("stucol");
// 删除表
col.drop();
// 插入数据
List<Document> all = new ArrayList<Document>();
for(int x =0; x<100; x++){
Document doc = new Document();
doc.append("sid",x);
doc.append("name","姓名 - " + x);
if (x%2 == 0)
doc.append("sex","男");
else
doc.append("sex","女");
all.add(doc);
}
// 插入多条数据
col.insertMany(all);
// 获取记录条数
System.out.println("已插入记录条数:" + db.getCollection("stucol").countDocuments()); //查询全部数据
System.out.println("查询全部学生姓名:");
MongoCursor<Document> cursor = col.find().iterator();
while(cursor.hasNext()){
// 全部查询列
// System.out.println(cursor.next());
// 查询姓名
System.out.println(cursor.next().get("name"));
} // 设置查询条件
BasicDBObject cond = new BasicDBObject();
// 查询条件为编号大于5,小于10
cond.put("sid", new BasicDBObject("$gt",5).append("$lt",10));
System.out.println("查询编号大于5小于10的全部学生姓名:");
// 按条件查询数据
cursor = col.find(cond).iterator();
while(cursor.hasNext()){
// 全部查询列
// System.out.println(cursor.next());
// 查询姓名
System.out.println(cursor.next().get("name"));
} // 模糊查询,查找名字里带“10”的
Pattern pattern = Pattern.compile("10");
// 设置查询条件
cond = new BasicDBObject();
cond.put("name", new BasicDBObject("$regex",pattern));
// 不区分大小写的写法
// cond.put("name", new BasicDBObject("$regex",pattern).append("$options","i"));
System.out.println("查询姓名里带10的全部学生姓名:");
// 按条件查询数据
cursor = col.find(cond).iterator();
while(cursor.hasNext()){
// 查询姓名
System.out.println(cursor.next().get("name"));
} // 分页查询
// 模糊查询,查找名字里带“1”的
pattern = Pattern.compile("1");
// 设置查询条件
cond = new BasicDBObject();
cond.put("name", new BasicDBObject("$regex",pattern));
System.out.println("查询姓名里带1的6到10个学生姓名:");
// 按条件查询数据
cursor = col.find(cond).skip(5).limit(5).iterator();
while(cursor.hasNext()){
// 查询姓名
System.out.println(cursor.next().get("name"));
} // 更新数据
BasicDBObject condA = new BasicDBObject("sid",0);
BasicDBObject condB = new BasicDBObject("$set",new BasicDBObject("name","SuperMam"));
UpdateResult result = col.updateMany(condA,condB);
System.out.print("已修改记录数");
System.out.println(result.getModifiedCount()); // 聚类查询
// 查询条件,按姓别统计人数
condA = new BasicDBObject("$group",new BasicDBObject("_id","$sex").append("count",new BasicDBObject("$sum",1)));
List<BasicDBObject> allB = new ArrayList<BasicDBObject>();
allB.add(condA);
System.out.println("聚类查询,按姓别统计人数");
cursor = col.aggregate(allB).iterator();
while(cursor.hasNext()){
Document doc = cursor.next();
System.out.println(doc.getString("_id") + ", " + doc.getInteger("count"));
} // 删除数据
// 查询条件
condA = new BasicDBObject("sid",0);
DeleteResult resultD = col.deleteOne(condA);
System.out.println("删除记录数:" + resultD.getDeletedCount());
client.close();
}
}
李兴华老师MongoDB培训笔记
http://yuedu.163.com/news_reader/#/~/source?id=d0b66e2ed0f84f8f8f4ea1a357964f36_1&cid=2cc98f9ffa0e4650bf9d0dc166f1a0e4_1
Java中使用MongoDB的更多相关文章
- 在java中使用MongoDB数据库
Java 安装 要想在 Java 程序中使用 MongoDB,需要先确定是否安装了 MongoDB JDBC 驱动,并且要在机器上安装了 Java.查看 Java 教程来确保在机器上安装好 Java. ...
- java中使用mongodb的几种方式
最近有时间看了一下mongodb,因为mongodb更容易扩展所以考虑使用mongodb来保存数据. 首先下载安装mongodb,这是很简单的,装好后使用mongod命令就可以启动数据库.正式部署的话 ...
- Java中实现MongoDB自增主键ID
1.了解MongoDB的ObjectId MongoDB的文档固定是使用“_id”作为主键的,它可以是任何类型的,默认是个ObjectId对象(在Java中则表现为字符串),那么为什么M ...
- Java中获取MongoDB连接的方法
首先是所需jar包,Maven中的配置如下: <dependency> <groupId>org.mongodb</groupId> <artifactId& ...
- 【MongoDB学习之五】Java中使用MongoDB
环境 MongoDB 3.0 CentOS6.5_x64 相关jar:mongo-java-driver-3.0.0.jar package com.mongodb; import java.util ...
- Java开发--操作MongoDB
http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html介绍到了在MongoDB的控制台完成MongoDB的数据操作,通过前一篇文章我们 ...
- java下执行mongodb
1.1连单台mongodb Mongo mg = newMongo();//默认连本机127.0.0.1 端口为27017 Mongo mg = newMongo(ip);//可以指定ip 端口默认 ...
- Java中遍历实体类(处理MongoDB)
在实际过程中,经常要将实体类进行封装,尤其是处理数据库的过程中:因此,对于遍历实体类能够与数据库中的一行数据对应起来. 我是使用的环境是Spring boot,访问的数据库时MongoDB 实体类遍历 ...
- MongoDB在java中的使用
在一年前就开始在项目中使用Mongodb作为爬虫(crawler)待下载URL.下载成功URL等的存储库,最近对项目进行版本更新,根据Mongodb的最近升级情况,也对项目中的Mongodb进行了相关 ...
随机推荐
- 宝塔linux面板 解决TP3.2 404
在配置文件中加入一下配置: location / { if (!-e $request_filename) { rewrite ^/(.*)$ /index.php/$1; } } location ...
- cok-filter
小工具 # -*- coding: utf-8 -*- import pandas as pd def filterExcel(cokpath, keywords): df = pd.read_exc ...
- 《重构-改善既有代码的设计》学习笔记---Replace Temp with Query(以查询取代临时变量)
临时变量的问题在于: 它们是暂时的,而且只能在所属函数内使用.由于临时变量只在所属函数内可见,所以,如果很多地方都在用这个临时变量,就会驱使你写出更长的函数.如果把临时变量替换为一个查询,那么其他函数 ...
- 2019春招——Vivo大数据开发工程师面经
Vvio总共就一轮技术面+一轮HR面,技术面总体而言,比较宽泛,比较看中基础,面试的全程没有涉及简历上的东西(都准备好跟他扯项目了,感觉是抽取的题库...)具体内容如下: 1.熟悉Hadoop哪些组件 ...
- C# 6.0:String Interpolation
在开发中经常需要对字符串进行格式化处理.我们一般使用String.Format()方法,它会将指定字符串中的每个格式项替换为相应对象的值的文本等效项.虽然这很普通,但有时会容易使人迷惑并造成错误.因为 ...
- conda,pip 安装指定版本的指定包
1.conda 安装指定版本的指定包 cuda search tensorflow-gpu 有如下结果: 然后使用conda install package=version 就能安装指定版本的pack ...
- OSPFV3综合实验 (第三组)
拓扑图 本次试验规划:拓扑分4个区域,其中区域2采用帧中继实现区域内互通的前提下配置OSPF.ospfv3.R7与R8之间配置rip实现互通,区域1作为nssa区域,实现路由注入.最终实现全局互通. ...
- CentOS_6.5配置iptables防火墙策略
###############配置filter表防火墙############### #清除预设表filter中的所有规则链的规则iptables -F #清除预设表filter中使用者自定链中的规则 ...
- MyBatis中使用#和$书写占位符有什么区别?
#将传入的数据都当成一个字符串,会对传入的数据自动加上引号:$将传入的数据直接显示生成在SQL中.注意:使用$占位符可能会导致SQL注射攻击,能用#的地方就不要使用$,写order by子句的时候应该 ...
- cesium 拾取模型表面的坐标
scene = viewer.scene;var handler = new Cesium.ScreenSpaceEventHandler(scene.canvas);handler.setInput ...