一、为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的更多相关文章

  1. 在java中使用MongoDB数据库

    Java 安装 要想在 Java 程序中使用 MongoDB,需要先确定是否安装了 MongoDB JDBC 驱动,并且要在机器上安装了 Java.查看 Java 教程来确保在机器上安装好 Java. ...

  2. java中使用mongodb的几种方式

    最近有时间看了一下mongodb,因为mongodb更容易扩展所以考虑使用mongodb来保存数据. 首先下载安装mongodb,这是很简单的,装好后使用mongod命令就可以启动数据库.正式部署的话 ...

  3. Java中实现MongoDB自增主键ID

    1.了解MongoDB的ObjectId        MongoDB的文档固定是使用“_id”作为主键的,它可以是任何类型的,默认是个ObjectId对象(在Java中则表现为字符串),那么为什么M ...

  4. Java中获取MongoDB连接的方法

    首先是所需jar包,Maven中的配置如下: <dependency> <groupId>org.mongodb</groupId> <artifactId& ...

  5. 【MongoDB学习之五】Java中使用MongoDB

    环境 MongoDB 3.0 CentOS6.5_x64 相关jar:mongo-java-driver-3.0.0.jar package com.mongodb; import java.util ...

  6. Java开发--操作MongoDB

    http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html介绍到了在MongoDB的控制台完成MongoDB的数据操作,通过前一篇文章我们 ...

  7. java下执行mongodb

    1.1连单台mongodb Mongo mg = newMongo();//默认连本机127.0.0.1  端口为27017 Mongo mg = newMongo(ip);//可以指定ip 端口默认 ...

  8. Java中遍历实体类(处理MongoDB)

    在实际过程中,经常要将实体类进行封装,尤其是处理数据库的过程中:因此,对于遍历实体类能够与数据库中的一行数据对应起来. 我是使用的环境是Spring boot,访问的数据库时MongoDB 实体类遍历 ...

  9. MongoDB在java中的使用

    在一年前就开始在项目中使用Mongodb作为爬虫(crawler)待下载URL.下载成功URL等的存储库,最近对项目进行版本更新,根据Mongodb的最近升级情况,也对项目中的Mongodb进行了相关 ...

随机推荐

  1. 什么是真正的Java技术,本篇文章让你了解

    “你学习一门技术的最佳时机是三年前,其次是现在.”这句话对于哪一种行业都很适用,如果你已经学习过Java,那么恭喜你你很有先见之明,如果你并不了解Java,这篇文章带你快速掌握Java的几个核心知识点 ...

  2. Beginning Math and Physics For Game Programmers (Wendy Stahler 著)

    Chapter 1. Points and Lines (已看) Chapter 2. Geometry Snippets (已看) Chapter 3. Trigonometry Snippets  ...

  3. 使用 AppScan 进行扫描

    针对大型网站的扫描,我们按照戴明环 PDCA 的方法论来进行规划和讨论,建议 AppScan 使用步骤:计划(Plan).执行(Do).检查(check).分析(Analysis and Action ...

  4. PageHelper 自动去掉排序参数问题

    PageHelper.startPage( req.getCurrent()   , req.getSize() ,"ordersCreateDate desc" ); 如果 上面 ...

  5. html 出现粒子线条,鼠标移动会以鼠标为中心吸附的特效之canvas-nest.js插件

    我在网上看到一个很炫酷,很有趣的特效,网页上会有很多移动的粒子和线条,鼠标经过时会以鼠标为中心吸附过来,如果时间够久,会形成一个类似震动的.带辐条的车轮子的东西. 网上搜了一下,源码是github里面 ...

  6. spring事务详解(一)初探事务

    系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 引子 很多 ...

  7. ningx.conf location

    server { listen ; server_name localhost; location /dirName { alias "C:/Users/VALEB/Downloads/in ...

  8. Elisp 中变量赋值函数 set 与 setq 辨析

    在 Elisp 中,为变量赋值的函数有 set 与 setq,但是,两者存在很大的差异. 使用 set 赋值: 如果我们想为变量 flowers 赋值为一个 列表 '(rose violet dais ...

  9. [蓝桥杯]PREV-22.历届试题_国王的烦恼

    问题描述 C国由n个小岛组成,为了方便小岛之间联络,C国在小岛间建立了m座大桥,每座大桥连接两座小岛.两个小岛间可能存在多座桥连接.然而,由于海水冲刷,有一些大桥面临着不能使用的危险. 如果两个小岛间 ...

  10. ROS多根adsl叠加负载均衡PCC的做法

    命令行: / ip firewall mangle1.保证访问局域网IP的时候不被PCC了.add chain=prerouting dst-address=10.1.1.0/24 action=ac ...