一、为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. 网络请求 Requests

    网络请求 Requests url: 就是需要请求,并进行下一步处理的urlcallback: 指定该请求返回的Response,由那个函数来处理.method: 一般不需要指定,使用默认GET方法请 ...

  2. webbrowser 里的js函数和C#的函数互相调用方式

    1.c#程序里要添加  [System.Runtime.InteropServices.ComVisibleAttribute(true)] 和  webBrowser1.ObjectForScrip ...

  3. 记一次java电话面试

    答案补充中... 一.java基础 1.简述java的几种基本数据类型 JAVA的基本数据类型有:byte.char.boolean.short.int.long.float.double 2.什么是 ...

  4. Spring boot配置logback

    在application-dev.yml增加配置 配置文件的路径为 rescoures/evn/dev/logback-spring.xml <?xml version="1.0&qu ...

  5. 从零开始打jar包--补充

    想试一下动态编译的功能,所以想看一下java如何编译 原文见:http://www.cnblogs.com/flashsun/p/7246260.html 但这篇文章有些错误及遗漏之处,导致有些没有办 ...

  6. MSMQ .NET下的应用

    Message Message是MSMQ的数据存储单元,我们的用户数据一般也被填充在Message的body当中,因此很重要,让我们来看一看其在.net中的体现,如图: 在图上我们可以看见,Messa ...

  7. MySQL 设置root密码报错:mysqladmin: connect to server at 'localhost' failed

    MySQL 设置root密码报错:mysqladmin: connect to server at 'localhost' failed 1.安装完MySQL设置root密码报错如下 [root@vm ...

  8. ORA-00984: 列在此处不允许 SQL parse error location

      ORA-00984: 列在此处不允许SQL parse error location Oracle 插入数据的时候一直提示列在此处不允许.网上搜索答案说是类型不匹配的多,但我的错误确是一个低级错误 ...

  9. MegaCLi命令总结

    MegaCli命令总结 MegaCli 版本8.00.29,raid卡为lsi 8888elp,固件11.0.1-0036 1    巡读 一MegaCli -adppr -enblauto  -a0 ...

  10. JavaScript 集合对象

    1. 集合对象 1.1 Object 关于Object类型的创建和底层存储原理我在另一篇文章有说明: JavaScript 对象属性底层原理 我们知道了大多数情况下Object底层都是Hash结构,我 ...