gpt4 book ai didi

spring - MongoDB 找不到能够从类型 org.bson.types.ObjectId 转换为类型 java.lang.Long 的转换器

转载 作者:行者123 更新时间:2023-12-04 12:06:39 25 4
gpt4 key购买 nike

我有以下供 Postgres 和 MongoDB 使用的客户模型。它适用于 Postgres,但当我想列出 MongoDB 中的所有客户时出现此错误:

org.springframework.core.convert.ConverterNotFoundException: No converter found capable of converting from type org.bson.types.ObjectId to type java.lang.Long



这是我的模型类:
package com.example.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlRootElement;

import org.apache.commons.lang.builder.ToStringBuilder;

@Entity
@XmlRootElement(name = "customer")
@Table(name = "customer")
public class Customer implements java.io.Serializable {

private static final long serialVersionUID = 1L;
private Long id;
private String firstName;
private String lastName;

public Customer() {
}

public Customer(String fn, String ln) {
this.firstName = fn;
this.lastName = ln;
}

public Customer(Long id, String firstName, String lastName) {
this.id = id;
this.firstName = firstName;
this.lastName = lastName;
}

@XmlAttribute(name = "id", required = false)
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id", unique = true, nullable = false)
public Long getId() {
return this.id;
}

public void setId(Long id) {
this.id = id;
}

@XmlAttribute(name = "first-name", required = false)
@Column(name = "first_name", nullable = false)
public String getFirstName() {
return this.firstName;
}

public void setFirstName(String firstName) {
this.firstName = firstName;
}


@XmlAttribute(name = "last-name", required = false)
@Column(name = "last_name", nullable = false)
public String getLastName() {
return this.lastName;
}

public void setLastName(String lastName) {
this.lastName = lastName;
}

@Override
public String toString() {
return ToStringBuilder.reflectionToString(this);
}
}

这是我的 CustomerService 来检索所有客户:
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;

import javax.inject.Inject;

import org.springframework.context.annotation.Import;
import org.springframework.data.domain.Sort;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.stereotype.Service;

import com.example.model.Customer;
import com.example.service.CustomerService;

@Service
@Import({ MongoConfiguration.class })
public class MongoCustomerService implements CustomerService{

@Inject MongoTemplate mongoTemplate;

Class<Customer> entityClass = Customer.class;

@Override
public Collection<Customer> getAllCustomers() {
try {
List<Customer> allCustomers = mongoTemplate.findAll(entityClass);
return allCustomers;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}

我的 pom.xml:
          </dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-mongodb</artifactId>
<version>1.3.3.RELEASE</version>
</dependency>

最佳答案

我将 id 从 Long 更改为 BigInteger 并且它按照文档工作。

关于spring - MongoDB 找不到能够从类型 org.bson.types.ObjectId 转换为类型 java.lang.Long 的转换器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21036335/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com