Почему я получаю NoResultException в спящем режиме, когда в базе данных есть данные? - PullRequest
0 голосов
/ 02 января 2019

Я пытаюсь получить объект из базы данных MySql в спящем режиме с помощью HQL по электронной почте.Тем не менее, я получаю javax.persistence.NoResultException: No entity found for query, хотя он существует в базе данных.Я пытаюсь получить его по электронной почте с помощью getSingleResults (), и электронные письма являются уникальными в базе данных, поэтому я уверен, что будет только один результат.

Пожалуйста, используйте код ниже:

@Override
    public UserDetails getUser(String email) {

        Session currentSession = sessionFactory.getCurrentSession();

        Query query = currentSession.createQuery("from UserDetails u where u.email = :email ");
        query.setParameter("email", email);
        return (UserDetails) query.getSingleResult();
    }

Пожалуйста, используйте следующий код для класса сущности:

package com.travelplanner.rest.entity;

import java.util.ArrayList;
import java.util.List;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.OneToOne;
import javax.persistence.Table;
import javax.persistence.Transient;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonManagedReference;

@Entity
@Table(name = "users_details")
public class UserDetails {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    private int id;

    @Column(name = "first_name")
    private String firstName;

    @Column(name = "last_name")
    private String lastName;

    @Column(name = "email")
    private String email;

    @Transient
    private String password;

    @OneToMany(mappedBy = "userDetails", cascade = CascadeType.ALL)
    @JsonIgnore
    @JsonManagedReference
    private List<TravelPlans> travelPlans;

    public UserDetails() {
    }

    public UserDetails(int id, String firstName, String lastName, String email) {
        this.id = id;
        this.firstName = firstName;
        this.lastName = lastName;
        this.email = email;
    }

    public int getId() {
        return id;
    }

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

    public String getFirstName() {
        return firstName;
    }

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

    public String getLastName() {
        return lastName;
    }

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

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public List<TravelPlans> getTravelPlans() {
        return travelPlans;
    }

    public void setTravelPlans(List<TravelPlans> travelPlans) {
        this.travelPlans = travelPlans;
    }

    @Override
    public String toString() {
        return "User [id=" + id + ", firstName=" + firstName + ", lastName=" + lastName + ", email=" + email + "]";
    }

    public void add(TravelPlans travelPlan) {
        if (travelPlans == null) {
            travelPlans = new ArrayList<>();
        }

        travelPlans.add(travelPlan);

        travelPlan.setUserDetails(this);
    }

}

Код в контроллере, если он помогает:

@GetMapping("/users/{email}")
    public UserDetails authUser(@PathVariable String email) {
        return userService.getUser(email);
    }

URL запроса: http://localhost:8080/api/users/xlz@wwe.com

Пожалуйста, помогите!Заранее спасибо.

1 Ответ

0 голосов
/ 02 января 2019

Попробуйте определить имя переменной пути. Пожалуйста, замените @PathVariable String email на @PathVariable(value="email") String email .

В соответствии с вышеуказанным комментарием Вы должны закодировать письмо в запросе xlz%40wwe.com но нет необходимости декодировать его в коде Java. Должно работать без декодирования.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...