博客
关于我
一篇文章带你使用 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 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>