QueryException: не удалось разрешить свойство: catId: com.my.myquiz.entity.Question

Я создал простую викторину, используя данные Spring, и сопоставил вопрос и категорию в отношении Многие к одному, используя аннотации. Я пытаюсь получить случайный вопрос в данной категории, но это дает указанную выше ошибку, и я пробовал несколько альтернатив. Но не работает похоже.

Категория.java

@Entity
@Table(name = "categories")
public class Category {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long catId;

    @Column(nullable = false , unique = true)
    private String description;

Вопрос.java

@Entity
@Table(name = "question")
public class Question {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long questionId;

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "catId", nullable = false, updatable = false)
    @JsonBackReference
    private Category category;

    @Lob
    @Column (nullable = false)
    private String question;

    @Column (nullable = false)
    private String medium;

ВопросРепозиторий.java

@Repository
@Transactional
public interface QuestionRepository extends JpaRepository<Question, Long> {

    @Query("select question from Question question where question.catId = :catId AND question.medium = :medium order by function('RAND')")
    List<Question> getQuestionsForAttempt(@Param("catId") Long catId , @Param("medium") String medium);

    @Query("select question from Question  question where question.catId = : catId")
    List<Question> getQuestionByCategory(@Param("catId") Long catId);
}
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Версия Java на основе версии загрузки
Версия Java на основе версии загрузки
Если вы зайдете на официальный сайт Spring Boot , там представлен start.spring.io , который упрощает создание проектов Spring Boot, как показано ниже.
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
0
0
227
1

Ответы 1

Это JPQL, а не SQL, поэтому вам нужно подумать о зависимостях в вашем запросе:

select question from Question  question where question.category.catId

или

select question from Question  question  inner join question.category c where c.catId

Другие вопросы по теме