博客
关于我
一篇文章带你使用 Java 操作 MongoDB
阅读量:362 次
发布时间:2019-03-04

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

MongoDB Java 驱动操作指南

一、前期准备

首先需要下载并配置MongoDB的Java驱动。可以通过以下两种方式获取:

  • 通过Maven添加依赖

    在Maven项目中添加以下依赖项:

    org.mongodb
    mongodb-driver
    3.5.0

    如果手动下载,需要获取以下三个JAR包:

    • org.mongodb:bson:jar:3.5.0
    • org.mongodb:mongodb-driver-core:jar:3.5.0
    • org.mongodb:mongodb-driver:jar:3.5.0
  • 启动MongoDB

    在开始操作之前,请确保MongoDB服务已启动。

  • 二、获取集合

    完成前期准备后,使用MongoClient连接数据库并获取集合:

    MongoClient client = new MongoClient("192.168.248.136", 27017);MongoDatabase sang = client.getDatabase("sang");MongoCollection c = sang.getCollection("c1");

    三、CRUD 操作

    1. 增加操作

    插入单条数据:

    Document d1 = new Document();d1.append("name", "三国演义").append("author", "罗贯中");c.insertOne(d1);

    插入多条数据:

    List
    collections = new ArrayList<>();Document d1 = new Document();d1.append("name", "三国演义").append("author", "罗贯中");collections.add(d1);Document d2 = new Document();d2.append("name", "红楼梦").append("author", "曹雪芹");collections.add(d2);c.insertMany(collections);
    2. 修改操作

    修改单条数据:

    c.updateOne(Filters.eq("author", "罗贯中"), new Document("$set", new Document("name", "三国演义123")));

    修改多条数据:

    c.updateMany(Filters.eq("author", "罗贯中"), new Document("$set", new Document("name", "三国演义456")));
    3. 删除操作

    删除单条数据:

    c.deleteOne(Filters.eq("author", "罗贯中"));

    删除多条数据:

    c.deleteMany(Filters.eq("author", "罗贯中"));

    四、查询操作

    1. 查询所有文档
    FindIterable
    documents = c.find();MongoCursor
    iterator = documents.iterator();while (iterator.hasNext()) { System.out.println(iterator.next());}
    2. 按条件查询
    FindIterable
    documents = c.find(Filters.eq("author", "罗贯中"));MongoCursor
    iterator = documents.iterator();while (iterator.hasNext()) { System.out.println(iterator.next());}

    五、验证与配置

    1. 数据库验证

    如果需要验证数据库权限,使用以下方式:

    ServerAddress serverAddress = new ServerAddress("192.168.248.128", 27017);List
    credentialsList = new ArrayList<>();MongoCredential mc = MongoCredential.createScramSha1Credential("readuser", "sang", "123".toCharArray());credentialsList.add(mc);MongoClient client = new MongoClient(serverAddress, credentialsList);MongoDatabase sang = client.getDatabase("sang");MongoCollection c = sang.getCollection("c1");
    2. 连接配置

    可通过MongoClientOptions设置连接超时等参数:

    ServerAddress serverAddress = new ServerAddress("192.168.248.128", 27017);List
    credentialsList = new ArrayList<>();MongoCredential mc = MongoCredential.createScramSha1Credential("rwuser", "sang", "123".toCharArray());credentialsList.add(mc);MongoClientOptions options = MongoClientOptions.builder() .connectTimeout(1000 * 10) // 设置连接超时为10秒 .maxWaitTime(1000 * 10) // 设置最大等待时间为10秒 .build();MongoClient client = new MongoClient(serverAddress, credentialsList, options);MongoDatabase sang = client.getDatabase("sang");MongoCollection c = sang.getCollection("c1");

    通过以上步骤,您可以高效地进行MongoDB数据的增删改查操作,并通过合理配置实现对数据库的安全访问和连接管理。

    转载地址:http://odar.baihongyu.com/

    你可能感兴趣的文章
    mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
    查看>>
    mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
    查看>>
    mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
    查看>>
    MySQL 8.0 恢复孤立文件每表ibd文件
    查看>>
    MySQL 8.0开始Group by不再排序
    查看>>
    mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
    查看>>
    multi swiper bug solution
    查看>>
    MySQL Binlog 日志监听与 Spring 集成实战
    查看>>
    MySQL binlog三种模式
    查看>>
    multi-angle cosine and sines
    查看>>
    Mysql Can't connect to MySQL server
    查看>>
    mysql case when 乱码_Mysql CASE WHEN 用法
    查看>>
    Multicast1
    查看>>
    mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
    查看>>
    MySQL Cluster 7.0.36 发布
    查看>>
    Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
    查看>>
    MySQL Cluster与MGR集群实战
    查看>>
    multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
    查看>>
    mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
    查看>>
    Multiple websites on single instance of IIS
    查看>>