小编VIS*_*N P的帖子

从 Spring Boot 连接 Mongodb Atlas

我是使用 Spring Boot 的 Mongodb 新手。我有 MONGODB ATLAS U​​RI 连接字符串

mongodb://userName:<PASSWORD>@icarat-shard-00-00-7lopx.mongodb.net:27017,icarat-shard-00-01-7lopx.mongodb.net:27017,icarat-shard-00-02-7lopx.mongodb.net:27017/<DATABASE>?ssl=true&replicaSet=icarat-shard-0&authSource=admin
Run Code Online (Sandbox Code Playgroud)

然后在我的 Spring Boot 应用程序中,我在 application.properties 中设置了 uri,例如

spring.data.mongodb.uri: mongodb://userName:*****@icarat-shard-00-00-7lopx.mongodb.net:27017,icarat-shard-00-01-7lopx.mongodb.net:27017,icarat-shard-00-02-7lopx.mongodb.net:27017/vehicleplatform?ssl=true&replicaSet=icarat-shard-0&authSource=admin
Run Code Online (Sandbox Code Playgroud)

这个存储库接口

public interface OrganizationRepository extends   MongoRepository<Organization, String> {   

}
Run Code Online (Sandbox Code Playgroud)

当我注入 OrganizationRepository 接口时,它显示这样的错误

无法实例化 [com.mongodb.MongoClient]:工厂方法 'mongo' 抛出异常;嵌套异常为 java.lang.IllegalArgumentException:连接字符串包含无效的用户信息。如果用户名或密码包含冒号 (:) 或 at 符号 (@),则必须对其进行 urlencoded

这是我的文档类

@Document(collection="Organization")
public class Organization {

    @Id
    String id;

    String orgName; 

    String orgAddress;

    String pinCode;

//getter 

//setter
}
Run Code Online (Sandbox Code Playgroud)

这是我的 pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>com.icarat</groupId>
  <artifactId>vehicleplatform</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>war</packaging>

  <name>vehicleplatform</name>
  <url>http://maven.apache.org</url>


    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.0.RELEASE</version>
        <relativePath/> …
Run Code Online (Sandbox Code Playgroud)

mongodb spring-boot mongodb-atlas

6
推荐指数
1
解决办法
1万
查看次数

如何在java中对Date进行排序

我有List AttendedExamName对象

public class AttendedExamName {
    private String name;
    private String dateTime;

  //getters    
  //settrs    
}
Run Code Online (Sandbox Code Playgroud)

当尝试使用下面的代码对对象进行排序时,我尝试基于dateTime属性进行排序

Collections.sort(examNames, (n1,n2)-> {
            try {
                Date date1= new SimpleDateFormat("yyyy-MM-dd-hh.mm.ss").parse(n1.getDateTime());
                Date date2=new SimpleDateFormat("yyyy-MM-dd-hh.mm.ss").parse(n2.getDateTime());
                return date1.compareTo(date2);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
                return 0;
            }           
            });
Run Code Online (Sandbox Code Playgroud)

我得到这个结果:

[[name=SCJP, dateTime=2017-04-15-04.37.57],
 [name=SCJP, dateTime=2017-04-15-06.31.52], 
 [name=SCJP, dateTime=2017-04-24-02.17.37], 
 [name=SCJP, dateTime=2017-04-26-05.10.29],
 [name=SCJP, dateTime=2017-04-27-03.30.34],
 [name=SCJP, dateTime=2017-04-28-12.11.09],
 [name=SCJP, dateTime=2017-04-28-01.16.59],
 [name=SCJP, dateTime=2017-04-28-02.10.54],
 [name=SCJP, dateTime=2017-04-28-11.31.16],
 [name=SCJP, dateTime=2017-04-28-11.57.56]]
Run Code Online (Sandbox Code Playgroud)

预期:

[[name=SCJP, dateTime=2017-04-15-04.37.57],
 [name=SCJP, dateTime=2017-04-15-06.31.52], 
 [name=SCJP, dateTime=2017-04-24-02.17.37], 
 [name=SCJP, dateTime=2017-04-26-05.10.29],
 [name=SCJP, dateTime=2017-04-27-03.30.34],
 [name=SCJP, dateTime=2017-04-28-11.31.16],
 [name=SCJP, …
Run Code Online (Sandbox Code Playgroud)

java sorting datetime

1
推荐指数
1
解决办法
1401
查看次数

标签 统计

datetime ×1

java ×1

mongodb ×1

mongodb-atlas ×1

sorting ×1

spring-boot ×1