JPA读取数据库离谱问题-No property ‘selectClassByName‘ found-Not a managed type

JPA读取数据库离谱问题

报错情况有以下两种:

  • No property 'selectClassByName' found for type 'Cinfo'
  • Caused by: java.lang.IllegalArgumentException: Not a managed type: class com.tang.backend.entity.Cinfo

第一种情况原因:在继承JPA并使用封装好的方法的时候,如果你要自己重新再写一个名字,那么必须和他的一致,如果不一致,你就需要自己重新写@Query注解的内容。

java 复制代码
// 错误写法
Cinfo selectClassById(String class_id);

// 正确写法
@Query(value="select * from class_info where class_id=?1",nativeQuery = true)
Cinfo selectClassById(String class_id);

并且请注意,在写Query里面的SQL语句的时候,如果用到了*号,那么请记得加上后面的nativeQuery = true

第二种情况原因: 继承JPA的时候,后面的泛型需要注意。

java 复制代码
public interface ClassInfoRepository extends JpaRepository<Cinfo, String> {}
// JAP的第一个泛型是你的表格类,第二个泛型是你的表格中主键的类型。
// 因为一般很多项目都是int自增的主键,所以这里很少遇到,但是我的项目是手动设置的String主键,
// 所以这里需要改成String。

当然,我不确定是否还有别的原因导致的,我这里把配置文件中关于JPA的配置贴在下面,希望对各位有帮助。

properties 复制代码
# JPA
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL8Dialect
spring.jpa.properties.hibernate.format_sql=true

# HikariCP
spring.datasource.hikari.connection-timeout=30000
spring.datasource.hikari.maximum-pool-size=10
spring.datasource.hikari.minimum-idle=5
spring.datasource.hikari.idle-timeout=600000
spring.datasource.hikari.max-lifetime=1800000
spring.datasource.hikari.register-mbeans=true

# SQL
spring.jpa.properties.hibernate.show_sql=true
spring.jpa.properties.hibernate.use_sql_comments=true
相关推荐
SimonKing1 分钟前
你还在靠重启来调线程池?别人已经做到了实时调控,3分钟接入
java·后端·程序员
前端与小赵3 分钟前
数据库交互全链路实战:通用封装、批量优化与动态查询三大核心模块
数据库·python·sql
小张小张爱学习4 分钟前
Java并发编程面试题
java·开发语言
六月雨滴5 分钟前
SQL 优化
sql·oracle·dba
码不停蹄的玄黓7 分钟前
JDK 自带四大命令行工具:jstat、jstack、jmap、jhat 详解
java·开发语言
ch.ju9 分钟前
Java程序设计(第3版)第四章——set方法为属性赋值
java·开发语言
AI人工智能+电脑小能手21 分钟前
【大白话说Java面试题 第94题】【Mysql篇】第24题:什么是单路排序?什么是双路排序??
java·开发语言·数据库·mysql·面试·排序算法
我是一颗柠檬21 分钟前
【Java项目技术亮点】多级缓存一致性方案:Canal+MQ实现数据库与缓存的最终一致
java·数据库·spring·缓存·kafka·rocketmq
于先生吖21 分钟前
Java分账体系设计,网约车行程计费与到店线下结账一体化后端开发实战
java·开发语言
Solis程序员23 分钟前
拿捏登录安全:RS256 + 双令牌,把非法请求拦在 Redis 白名单门外
java·安全·缓存·面试·bootstrap·html