Java中获取MongoDB连接的方法详解

首先是所需jar包,Maven中的配置如下:

<dependency>
  <groupId>org.mongodb</groupId>
  <artifactId>mongodb-driver</artifactId>
  <version>3.4.1</version>
</dependency>
<dependency>
  <groupId>org.mongodb</groupId>
  <artifactId>bson</artifactId>
  <version>3.4.1</version>
</dependency>
<dependency>
  <groupId>org.springframework.data</groupId>
  <artifactId>spring-data-mongodb</artifactId>
  <version>1.7.0.RELEASE</version>
</dependency>
<dependency>
  <groupId>org.mongodb</groupId>
  <artifactId>mongo-java-driver</artifactId>
  <version>3.9.1</version>
</dependency>

获取连接的代码如下(本中用的是模板类):

List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(new ServerAddress(dataSource.getSourceIp(), Integer.valueOf(dataSource.getSourcePort())));
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(MongoCredential.createScramSha1Credential(dataSource.getUsername(), dataSource.getSourceName(), dataSource.getPassword().toCharArray()));
MongoClient mongoClient = new MongoClient(addrs, credentials);
MongoDbFactory mongoDbFactory = new SimpleMongoDbFactory(mongoClient, dataSource.getSourceName());
MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory);
mongoTemplate.getCollectionNames();

或者用如下方式获取:

ServerAddress serverAddress = new ServerAddress("192.168.16.121",27017);
List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(serverAddress);
//MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码
MongoCredential credential = MongoCredential.createScramSha1Credential("root", "admin", "123456Ab".toCharArray());
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(credential);
//通过连接认证获取MongoDB连接
MongoClient mongoClient = new MongoClient(addrs,credentials);
//连接到数据库
MongoDatabase mongoDatabase = mongoClient.getDatabase("admin");
mongoDatabase.getCollection("test").find().iterator();
// 关闭数据库连接
mongoClient.close();

附带简单增删改查的例子:

package test;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

import org.junit.Test;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.MongoDbFactory;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.SimpleMongoDbFactory;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;

import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.WriteResult;

import bean.Book;
import bean.Good;
import bean.ShopDO;
import net.sf.json.JSONObject;

public class MongoTemplateTest {
  public static MongoTemplate mongoTemplate = getMongoTemplate();

  public static void main(String[] args) {
    System.out.println(mongoTemplate.getCollectionNames());
  }

  public static MongoTemplate getMongoTemplate(){
    String host = "192.168.16.121";
    int port = 27017;
    String databaseName = "test";
    String username = "root";
    String password = "123456Ab";

    //ServerAddress(host,port)两个参数分别为 IP地址 端口号
    ServerAddress serverAddress = new ServerAddress(host,port);
    List<ServerAddress> addrs = new ArrayList<ServerAddress>();
    addrs.add(serverAddress);

    //MongoCredential.createScramSha1Credential(username,source,password)三个参数分别为 用户名 数据库名称 密码
    MongoCredential credential = MongoCredential.createScramSha1Credential(username, databaseName, password.toCharArray());
    List<MongoCredential> credentials = new ArrayList<MongoCredential>();
    credentials.add(credential); 

    //通过连接认证获取MongoDB连接
    MongoClient mongoClient = new MongoClient(addrs,credentials);
    MongoDbFactory mongoDbFactory = new SimpleMongoDbFactory(mongoClient, databaseName);
    MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory);

    return mongoTemplate;
  }

  /**
   * 插入数据
   */
  @Test
  public void save(){
    ShopDO shop1 = new ShopDO(100L,"菜鸟教程");
    ShopDO shop2 = new ShopDO(101L,"有道笔记");
    mongoTemplate.save(shop1,"col");
    mongoTemplate.save(shop2,"col");
    System.out.println("mongoDB插入数据成功,集合为col,文档为:"+mongoTemplate.getCollection("col"));
  }

  @Test
  public void save1(){
    Book book = new Book(22L,"英语","32.5");
    mongoTemplate.save(book,"col");
  }

  @Test
  public void save2(){
    Good good = new Good(new HashMap<String,String>(){{put("id","1");put("name","动物");}});
    mongoTemplate.save(good,"col");
  }

  @Test
  public void save3(){
    mongoTemplate.save(JSONObject.fromObject("{\"这样\":\"we\",\"好吧\":\"hai\"}"),"col");
    System.out.println("mongoDB插入数据成功,集合为col,文档为:"+mongoTemplate.getCollection("col"));
  }

  /**
   * 查询所有
   */
  @Test
  public void findAll(){
    List<ShopDO> list = mongoTemplate.findAll(ShopDO.class,"col");
    System.out.println("mongoDB查询数据成功,集合为col,文档为:");
    for (ShopDO shopDO:list){
      System.out.println(shopDO.getNo()+"/"+shopDO.getName());
    }
  }

  /**
   * 单条件查询
   */
  @Test
  public void simpleQuery(){
    Query query = Query.query(Criteria.where("no").is(100L));
    List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
    System.out.println("mongoDB按条件ID查询数据成功,集合为col,文档为:");
    for (ShopDO shopDO:list){
     System.out.println(shopDO.getNo()+"/"+shopDO.getName());
    }
  }

  /**
   * 多条件查询
   */
  @Test
  public void muchQuery(){
    Criteria criteria = new Criteria();
    //or是条件或查询,and是条件与查询
    criteria.orOperator(
    Criteria.where("no").is(100),
    Criteria.where("name").is("菜鸟教程"));
    Query query = new Query(criteria);  //组合查询放入query
    Sort sort = new Sort(new Sort.Order(Sort.Direction.DESC,"no")); //结果集进行排序
    query.with(sort);
    List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
    System.out.println("mongoDB组合查询数据成功,集合为col,文档为:");
    for (ShopDO shopDO:list){
      System.out.println(shopDO.getNo()+"/"+shopDO.getName());
    }
  }

  /**
   * 分页查询
   */
  @Test
  public void LimitQuery(){
    Query query = new Query();
    query.skip(1).limit(3);
    List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
    System.out.println("mongoDB分页查询下标为1开始总共3行数据,集合为col,文档为:");
    for (ShopDO shopDO:list){
      System.out.println(shopDO.getNo()+"/"+shopDO.getName());
    }
  }

  /**
   * 模糊查询
   */
  @Test
  public void LikeQuery(){
    Query query = new Query(Criteria.where("name").regex("菜鸟"));
    List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
    System.out.println("mongoDB查询名称叫菜鸟的数据成功,集合为col,文档为:");
     for (ShopDO shopDO:list){
        System.out.println(shopDO.getNo()+"/"+shopDO.getName());
      }
    Update update = new Update();
    update.set("name","菜鸟教程old");
    WriteResult wr = mongoTemplate.updateMulti(query,update,"col");
    System.out.println("mongoDB更新数据成功,集合为col,行数为:" + wr.getN());
  }

  /**
   * 更新
   */
  @Test
  public void update(){
    Query query = new Query(Criteria.where("no").is(100));
    List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
    System.out.println("mongoDB查询no为100的数据成功,集合为col,文档为:");
    for (ShopDO shopDO:list){
      System.out.println(shopDO.getNo()+"/"+shopDO.getName());
    }
    Update update = new Update();
    update.set("name","菜鸟教程new");
    WriteResult wr = mongoTemplate.updateFirst(query,update,"col");
    System.out.println("mongoDB更新数据成功,集合为col,行数为:" + wr.getN());
  }

  /**
   * 删除
   */
  @Test
  public void delete(){
    Query query = new Query(Criteria.where("no").is(1));
    WriteResult result = mongoTemplate.remove(query, "col");
    System.out.println("mongoDB删除数据成功,集合为col,行数为:" + result.getN() + "删除的ID为"+result.getUpsertedId());
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 详解Java 连接MongoDB集群的几种方式

    先决条件 先运行mongodb肯定是必须的,然后导入以下包: import com.mongodb.MongoClient; import com.mongodb.MongoClientURI; import com.mongodb.ServerAddress; import com.mongodb.MongoCredential; import com.mongodb.MongoClientOptions; MongoClient MongoClient()实例表示到数据库的连接池; 你将只需

  • Java连接MongoDB进行增删改查的操作

    Java连接MongoDB进行增删改查的操作 1.创建数据库的连接,进行增删改查 (分别为接口和实现类) package com.dao; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mo

  • java实现mongodb的数据库连接池

    MongoDB是介于关系数据库和非关系数据库之间的一种产品,文件的存储格式为BSON(一种JSON的扩展),这里就主要介绍Java通过使用mongo-2.7.3.jar包实现mongodb连接池,具体的java代码实现如下: 数据库连接池配置参数: /** *@Description: mongo连接池配置文件 */ package cn.lulei.mongo.pool; public class MongoConfig { private static String userName;//用

  • java连接mongoDB并进行增删改查操作实例详解

    本文实例讲述了java连接mongoDB并进行增删改查操作.分享给大家供大家参考,具体如下: 1.安装 MongoDB JDBC驱动程序 在java中使用mongoDB之前,首先需要拥有java连接mongoDB的第三方驱动包(jar包) 1)maven项目可通过在pom.xml中添加依赖 <dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-ja

  • Mongodb3.0.5 副本集搭建及spring和java连接副本集配置详细介绍

    Mongodb3.0.5 副本集搭建及spring和java连接副本集配置详细介绍 一.基本环境: mongdb3.0.5数据库 spring-data-MongoDB-1.7.2.jar mongo-Java-driver-3.0.2.jar Linux-redhat6.3 tomcat7 二.搭建mongodb副本集: 1.  分别在三台linux系统机上安装mongodb,(为避免和机器上原有的mongodb端口冲突,这里设为57017): 192.168.0.160 192.168.0.

  • Java mongodb连接配置实践

    之前百度,google了很多,发现并没有介绍mongodb生产环境如何配置的文章, 当时想参考下都不行, 所以写篇文章,大家可以一块讨论下. 1. MongoClientOptions中的连接池配置: 配置如下: connectionPoolSettings = ConnectionPoolSettings.builder() .minSize(getMinConnectionsPerHost()) .maxSize(getConnectionsPerHost()) .maxWaitQueueS

  • Java中获取MongoDB连接的方法详解

    首先是所需jar包,Maven中的配置如下: <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver</artifactId> <version>3.4.1</version> </dependency> <dependency> <groupId>org.mongodb</groupId>

  • Java中Optional类及orElse方法详解

    目录 引言 Java 中的 Optional 类 ofNullable() 方法 orElse() 方法 案例 orElseGet() 方法 案例 orElse() 与 orElseGet() 之间的区别 引言 为了让我更快的熟悉代码,前段时间组长交代了一个小任务,大致就是让我整理一下某个模块中涉及的 sql,也是方便我有目的的看代码,也是以后方便他们查问题(因为这个模块,涉及的判断很多,所以之前如果 sql 出错了,查问题比较繁琐). 昨天算是基本完成了,然后今天组长就让给我看一个该模块的缺陷

  • Java中对象数组的使用方法详解

    本文实例讲述了Java中对象数组的使用方法.分享给大家供大家参考,具体如下: 一 点睛 对象可以用数组来存放,通过下面两个步骤来实现. 1 声明以类为数据类型的数组变量,并用new分配内存空间给数组. 2 用new产生新的对象,并分配内存空间给它. 下面介绍4种方式来定义对象数组 方式一:静态方式 Person p1[] = { new Person(), new Person(), new Person() }; 方式二:动态初始化化 Person p2[]; p2 = new Person[

  • Vue 实现从文件中获取文本信息的方法详解

    本文实例讲述了Vue 实现从文件中获取文本信息的方法.分享给大家供大家参考,具体如下: 最近在使用vue做项目的时候,遇到一个需求,界面中需要显示大量的说明文字,为了保持界面的整洁和赶紧,决定采用单独的文件来存储显示信息,然后通过文件读取的方式显示到界面上. 刚开始我使用的是File和FileReader对象获取,但是比较气人的是这两个对象是IE浏览器特有的属性,chrome不支持,而且为了安全起见,现在浏览器是不推崇这种做法的,因为很容易造成文件被外部恶意删除或增加内容,安全性太低.无奈之下,

  • java集合——Java中的equals和hashCode方法详解

    Java中的equals方法和hashCode方法是Object中的,所以每个对象都是有这两个方法的,有时候我们需要实现特定需求,可能要重写这两个方法,今天就来介绍一些这两个方法的作用. equals()和hashCode()方法是用来在同一类中做比较用的,尤其是在容器里如set存放同一类对象时用来判断放入的对象是否重复. 这里我们首先要明白一个问题: equals()相等的两个对象,hashcode()一定相等,equals()不相等的两个对象,却并不能证明他们的hashcode()不相等.换

  • Java中关键字synchronized的使用方法详解

    synchronized是Java里的一个关键字,起到的一个效果是"监视器锁"~~,它的功能就是保证操作的原子性,同时禁止指令重排序和保证内存的可见性! public class TestDemo { static class Counter{ public int count = 0; public void add(){ count++; } } public static void main(String[] args) throws InterruptedException {

  • Java中图像锐化操作的方法详解

    一.该图像锐化的思想: 本文的图像锐化是将图像中的R,G,B的值分别从原图像中提出,然后将分别将这三个R,G,B的值分别与卷积核进行卷积,最终再将最后的三个卷积的结果合成为一个像素值,从而实现图像的锐化效果. 二.整体的图像锐化的代码为: package com.yf1105; import java.awt.Color; import java.awt.Graphics; import java.awt.image.BufferedImage; import java.io.File; imp

  • python连接mongodb集群方法详解

    简单的测试用例 #!/usr/bin/python # -*- coding: UTF-8 -*- import time from pymongo import MongoClient # 连接单机 # single mongo # c = MongoClient(host="192.168.89.151", port=27017) # 连接集群 c = MongoClient('mongodb://192.168.89.151,192.168.89.152,192.168.89.1

  • Mongodb中MapReduce实现数据聚合方法详解

    Mongodb是针对大数据量环境下诞生的用于保存大数据量的非关系型数据库,针对大量的数据,如何进行统计操作至关重要,那么如何从Mongodb中统计一些数据呢? 在Mongodb中,给我们提供了三种用于数据聚合的方式: (1)简单的用户聚合函数: (2)使用aggregate进行统计: (3)使用mapReduce进行统计: 今天我们首先来讲讲mapReduce是如何统计,在后续的文章中,将另起文章进行相关说明. MapReduce是啥呢?以我的理解,其实就是对集合中的各个满足条件的文档进行预处理

  • java 中JDBC连接数据库代码和步骤详解及实例代码

    java 中JDBC连接数据库代码和步骤详解 JDBC连接数据库 •创建一个以JDBC连接数据库的程序,包含7个步骤:  1.加载JDBC驱动程序:  在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),这通过java.lang.Class类的静态方法forName(String  className)实现. 例如: try{ //加载MySql的驱动类 Class.forName("com.mysql.jdbc.Driver") ; }catch(Class

随机推荐