博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java操作MongoDB实现CRUD
阅读量:6614 次
发布时间:2019-06-25

本文共 6196 字,大约阅读时间需要 20 分钟。

hot3.png

开发环境

1、Mac

2、IDEA

3、MongoDB 3.6.5

4、Maven

项目实例

1、创建Maven项目mongodb_test,这里不废话

2、pom.xml添加jar依赖,这里用到了两个jar:mongo-java-driver:3.7.0(尽量和你MongoDB版本一致),Junit4.7(我用到了Junit,没用可以不引)

4.0.0
mongodb_test
mongodb_test
1.0-SNAPSHOT
http://maven.apache.org
org.mongodb
mongo-java-driver
3.7.0
junit
junit
4.7
test

3、创建MongoDB连接工具类 MongoConnection,其中有两种连接方式:验证用户名+密码,不验证用户名+密码;

package connection;import com.mongodb.MongoClient;import com.mongodb.MongoCredential;import com.mongodb.ServerAddress;import com.mongodb.client.MongoDatabase;import java.util.ArrayList;import java.util.List;/** * MongoDB连接工具类 * @author lihaoshan * @date 2018-05-30 * */public class MongoConnection {    /**     * 需要验证用户名、密码的连接方式     * @return mongoDatabase     * */    public MongoDatabase getConnection(){        try{            //连接到MongoDB服务,如果是远程连接可以将localhost改为服务器所在的IP地址            //ServerAddress()参数分别为服务器地址、端口            ServerAddress serverAddress = new ServerAddress("localhost",27017);            List
serverAddressList = new ArrayList
(); serverAddressList.add(serverAddress); //createScramSha1Credential()参数分别为用户名、数据库名称、密码 MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("userName","databaseName","password".toCharArray()); List
mongoCredentialList = new ArrayList
(); mongoCredentialList.add(mongoCredential); //通过连接认证获取MongoDB连接 MongoClient mongoClient = new MongoClient(serverAddressList,mongoCredentialList); //连接数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("databaseName"); System.out.println("MongoDB连接成功"); return mongoDatabase; } catch (Exception e){ System.err.println(e.getClass().getName() + ": " + e.getMessage()); } return null; } /** * 不需要验证用户名、密码的连接方式 * @return mongoDatabase * */ public MongoDatabase getConnectionBasis(){ try{ //连接到MongoDB服务 MongoClient mongoClient = new MongoClient("localhost",27017); MongoDatabase mongoDatabase = mongoClient.getDatabase("users"); System.out.println("MongoDB连接成功"); return mongoDatabase; } catch (Exception e){ System.out.println(e.getClass().getName() + ":" + e.getMessage()); } return null; }}

4、创建junit测试类 MongoDBTest,其中方法为MongoDB的CRUD操作

import com.mongodb.client.FindIterable;import com.mongodb.client.MongoCollection;import com.mongodb.client.MongoCursor;import com.mongodb.client.MongoDatabase;import com.mongodb.client.model.Filters;import connection.MongoConnection;import org.bson.Document;import org.junit.Test;import java.text.SimpleDateFormat;import java.util.ArrayList;import java.util.List;/** * MongoDB 测试 * @author lihaoshan * @date 2018-05-30 * */public class MongoDBTest {    MongoConnection mongoConnection = new MongoConnection();    //连接数据库(不需要验证用户名、密码方式)    MongoDatabase mongoDatabase = mongoConnection.getConnectionBasis();    @Test    public void test(){        MongoCollection
documentCollection = getCollection(); //新增文档// insertDomcument(documentCollection); //更新文档// update(documentCollection); //删除文档// delete(documentCollection); //查询所有文档 findAll(documentCollection); } /** * 获取 集合【对应RDBMS 中的数据表】com.mongodb.client.MongoDatabase.getCollection("集合名") */ public MongoCollection
getCollection(){ MongoCollection
collection = mongoDatabase.getCollection("users"); System.out.println("转换到指定集合"); return collection; } /** * 插入文档 * */ public void insertDomcument(MongoCollection
collection){ //创建文档对象com.bson.Document 参数为key-value格式 Document document = new Document(); document.append("name","李汶泽"); document.append("age","28"); List
documentList = new ArrayList
(); documentList.add(document); collection.insertMany(documentList); System.out.println("插入文档成功"); } /** * 更新 所有文档【表内 数据】com.mongodb.client.MongoCollection
.updateMany() */ public void update(MongoCollection
collection){ collection.updateMany(Filters.eq("age", 100), new Document("$set",new Document("age",30))); FindIterable
findIterable = collection.find(); MongoCursor
cursor = findIterable.iterator(); while (cursor.hasNext()) { System.out.println("更新后的MongoDB数据:"+cursor.next()); } } /** * 删除 文档 com.mongodb.client.MongoCollection
.deleteMany()/deleteOne() */ public void delete(MongoCollection
collection){ // 删除符合条件的 第一个文档 collection.findOneAndDelete(Filters.eq("age", 26)); //删除符合条件的 所有文档// collection.deleteMany(Filters.gte("age", 20)); FindIterable
findIterable = collection.find(); MongoCursor
cursor = findIterable.iterator(); while(cursor.hasNext()){ System.out.println("删除后的MongoDB数据:"+cursor.next()); } } /** * 查询 所有文档【表内 数据】com.mongodb.client.MongoCollection
.find() * 查询 本条数据的时间节点 _id采用ObjectId格式 * * ObjectId 是一个12字节 BSON 类型数据,有以下格式: * 前4个字节表示时间戳 * 接下来的3个字节是机器标识码 * 紧接的两个字节由进程id组成(PID) * 最后三个字节是随机数。 */ public void findAll(MongoCollection
collection){ /** * 1. 获取迭代器FindIterable
* 2. 获取游标MongoCursor
* 3. 通过游标遍历检索出的文档集合 * */ FindIterable
findIterable = collection.find(); MongoCursor
mongoCursor = findIterable.iterator(); while(mongoCursor.hasNext()){ Document document = mongoCursor.next(); System.out.println("MongoDB数据:"+document); System.out.println("插入时间:"+new SimpleDateFormat().format(document.getObjectId("_id").getDate())); } }}

5、到这里MongoDB的CRUD简单操作就基本完成了,其他的后续再补充;

码云

https://gitee.com/haoshan/mongodb_test

转载于:https://my.oschina.net/lihaoshan/blog/1821360

你可能感兴趣的文章
CSS-图片不变形设置
查看>>
Git异常:fatal: could not create work tree dir 'XXX': No such file or directory
查看>>
GNU make manual 翻译(八十二)
查看>>
python批量下载图片的三种方法
查看>>
/bin/bash^M: bad interpreter: 没有那个文件或目录
查看>>
iOS - OC NSData 数据
查看>>
Java web 开发填坑记 1 -如何正确的下载 eclipse
查看>>
iOS - Quartz 2D 第三方框架 Charts 绘制图表
查看>>
MM顾问的常见面试问题(ZZ)
查看>>
转:Windows 8上强制Visual Studio以管理员身份运行
查看>>
迟来的加勒比海盗3 观后
查看>>
类与对象 - PHP手册笔记
查看>>
谈一谈互联网创业补贴变味后的现象
查看>>
MapGIS转Shp文件的单位问题
查看>>
使用Karate轻松实现自动API测试
查看>>
React
查看>>
CentOS -bash: warning: setlocale: LC_MESSAGES: cannot change locale (en_US.UTF-8)
查看>>
编写一个基本的Android应用程序
查看>>
我的友情链接
查看>>
查看Linux操作系统安装的位数(getconf 命令应用)
查看>>