当前位置: 首页 > 知识库问答 >
问题:

找不到类组织的编解码器。json。杰索纳雷

井斌斌
2023-03-14
 private void getUsersWithin24Hours(String id, Map < String, Object > payload) throws JSONException {
  JSONObject json = new JSONObject(String.valueOf(payload.get("data")));
  Query query = new Query();

  query.addCriteria(Criteria.where("user_id").is(id).and("timezone").in(json.get("timezone")).and("gender").in(json.get("gender")).and("locale").in(json.get("language")).and("time").gt(getDate()));
  mongoTemplate.getCollection("user_log").distinct("user_id", query.getQueryObject());
 }

我打算从mongodb中进行查询并获得结果,我成功地使用了mongo terminal命令:

db.getCollection('user_log').find({"user_id" : "1", "timezone" : {$in: [5,6]}, "gender" : {$in : ["male", "female"]}, "locale" : {$in : ["en_US"]}, "time" : {$gt : new ISODate("2017-01-26T16:57:52.354Z")}}) 

但当我尝试java时,它给了我以下的错误。

组织。布森。编解码器。配置CodeConfigurationException:找不到类org的编解码器。json。杰索纳雷

理想的方法是什么?

提示:事实上,我认为在我的代码中,这部分json出现了错误。获取(“时区”)。因为它包含数组。当我使用硬代码字符串数组时,这段代码是有效的

共有2个答案

柳志专
2023-03-14

不必使用JSONObject/JSONArray进行转换。

如果payload.get("data")Map,请替换为以下行

BasicDBObject json = new BasicDBObject(payload.get("data"));

如果<代码>有效载荷为,则替换为下线。get(“data”)保存json字符串。

BasicDBObject json =(BasicDBObject) JSON.parse(payload.get("data"));
璩珂
2023-03-14

以下是MongoDB大学课程中的MongoDB示例,其中有一个名为“学生”的MongoDB数据库,集合名为“成绩”:

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.mongodb</groupId>
    <artifactId>test</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>

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

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>mongodb-driver</artifactId>
            <version>3.2.2</version>
        </dependency>
    </dependencies>
</project>

com/mongo/Main。JAVA

package com.mongo;

import com.mongodb.MongoClient;
import com.mongodb.client.*;
import org.bson.Document;
import org.bson.conversions.Bson;

import javax.print.Doc;

public class Main {

    public static void main(String[] args) {

        MongoClient client = new MongoClient();
        MongoDatabase database = client.getDatabase("students");
        final MongoCollection<Document> collection = database.getCollection("grades");

        Bson sort = new Document("student_id", 1).append("score", 1);
        MongoCursor<Document> cursor = collection.find().sort(sort).iterator();

        try {
            Integer student_id = -1;
            while (cursor.hasNext()) {
                Document document = cursor.next();
                // Doing more stuff
            }
        } finally {
            cursor.close();
        }
    }
}
 类似资料: