gpt4 book ai didi

java - 使用 Spring Data JPA 获取 NumberFormatException

转载 作者:行者123 更新时间:2023-12-05 08:40:10 26 4
gpt4 key购买 nike

我正在通过“Spring in action 5”学习 Spring 并遇到一些问题:当我在第 3 章中从 JDBC 切换到 Spring Data JPA(100% 正常工作)时,代码在我尝试打开时停止工作带有炸 Jade 米饼配料的主页。我做了一些日志来查看发生了什么,发现方法 findById(String id) 无法从 DB(或类似的东西)转换我的值。我正在使用 MySQL。

我尝试使用@Autowired 自己调用转换器的方法convert(String id),但我唯一发现的是,当key 错误时,会出现另一个错误。所以数据是可见的。我会尝试在这里提供一些代码,但我不确定什么有用什么没用。我在第一次尝试记录某些内容时遇到错误。 IDE 和浏览器中的错误是不同的。这是完整的项目 https://github.com/thedistantblue/taco-cloud-jpa .

这是我的转换器:

    public class IngredientByIdConverter implements Converter<String, 
Ingredient> {

private IngredientRepository ingredientRepo;

@Autowired
public IngredientByIdConverter(IngredientRepository ingredientRepo) {
this.ingredientRepo = ingredientRepo;

}
@Override
public Ingredient convert(String id) {
log.info("In converter.convert(): "
+ingredientRepo.findById(id).toString());
Optional<Ingredient> optionalIngredient =
ingredientRepo.findById(id);
return optionalIngredient.orElse(null);
}
}

和 Controller 类:

    @Slf4j
@Controller
@RequestMapping("/design")
@SessionAttributes("order")
public class DesignTacoController {

@ModelAttribute(name = "order")
public Order order() {
return new Order();
}

@ModelAttribute(name = "taco")
public Taco taco() {
return new Taco();
}

private final IngredientRepository ingredientRepository;
private TacoRepository designRepository;
private IngredientByIdConverter converter;

@Autowired
public DesignTacoController(IngredientRepository ingredientRepository,
TacoRepository designRepository,
IngredientByIdConverter converter) {
this.ingredientRepository = ingredientRepository;
this.designRepository = designRepository;
this.converter = converter;
}

@GetMapping
public String showDesignForm(Model model) {
List<Ingredient> ingredients = new ArrayList<>();



log.info(converter.convert("CARN").getName());
log.info("in DTC: " + ingredientRepository.findAll());

ingredientRepository.findAll().forEach(i -> ingredients.add(i));

在 IDE 中:

java.lang.NumberFormatException:对于输入字符串:“PROTEIN” 在 java.base/jdk.internal.math.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2054) ~[na:na] 在 java.base/jdk.internal.math.FloatingDecimal.parseDouble(FloatingDecimal.java:110)~[na:na] 在 java.base/java.lang.Double.parseDouble(Double.java:543) ~[na:na]

在浏览器中:

出现意外错误(类型=内部服务器错误,状态=500)。对于输入字符串:“PROTEIN”;嵌套异常是 java.lang.NumberFormatException: For input string: "PROTEIN"org.springframework.dao.InvalidDataAccessApiUsageException:对于输入字符串:“PROTEIN”;嵌套异常是 java.lang.NumberFormatException: For input string: "PROTEIN" 在 org.springframework.orm.jpa.EntityManagerFactoryUtils.convertJpaAccessExceptionIfPossible(EntityManagerFactoryUtils.java:373) 在 org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:255) 在 org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:527) 在 org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible (ChainedPersistenceExceptionTranslator.java:61) 在 org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:242) 在 org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:153) 在 org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)

最佳答案

对于 Ingredient.java 需要为字段 Type type 添加注解 @Enumerated(EnumType.STRING)

@Id
@NaturalId(mutable = false)
private final String id;
private final String name;
@Enumerated(EnumType.STRING)
private final Type type;

public static enum Type {
WRAP, PROTEIN, VEGGIES, CHEESE, SAUCE
}

关于java - 使用 Spring Data JPA 获取 NumberFormatException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56942170/

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