博客
关于我
一篇文章带你使用 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中json_extract的使用方法
    查看>>
    mysql中kill掉所有锁表的进程
    查看>>
    mysql中like % %模糊查询
    查看>>
    MySql中mvcc学习记录
    查看>>
    mysql中null和空字符串的区别与问题!
    查看>>
    MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
    查看>>
    MYSQL中TINYINT的取值范围
    查看>>
    MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
    查看>>
    Mysql中varchar类型数字排序不对踩坑记录
    查看>>
    MySQL中一条SQL语句到底是如何执行的呢?
    查看>>
    MySQL中你必须知道的10件事,1.5万字!
    查看>>
    MySQL中使用IN()查询到底走不走索引?
    查看>>
    Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
    查看>>
    MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
    查看>>
    mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
    查看>>
    mysql中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>
    MySQL中地理位置数据扩展geometry的使用心得
    查看>>
    Mysql中存储引擎简介、修改、查询、选择
    查看>>