Spring Boot JPA存储库自定义查询

时间:2017-07-05 12:09:29

标签: spring-boot repository spring-data-jpa

http://spring.io/guides/gs/accessing-data-jpa/

引用上述链接来定义自定义查询。

我们开发了一个Spring启动Web服务CRUD应用程序,但是当我们添加自定义查询时,我们面临以下异常。

 org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'EmployeeController': Unsatisfied dependency expressed through field 'EmployeeService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'EmployeeServiceImpl': Unsatisfied dependency expressed through field 'EmployeeRepository'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'EmployeeRepository': Invocation of init method failed; nested exception is org.springframework.data.mapping.PropertyReferenceException: No property name found for type Employee!
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:588) ~[spring-beans-4.3.9.RELEASE.jar:4.3.9.RELEASE]
Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'EmployeeServiceImpl': Unsatisfied dependency expressed through field 'EmployeeRepository'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'EmployeeRepository': Invocation of init method failed; nested exception is org.springframework.data.mapping.PropertyReferenceException: No property name found for type Employee!
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:588) ~[spring-beans-4.3.9.RELEASE.jar:4.3.9.RELEASE]
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'EmployeeRepository': Invocation of init method failed; nested exception is org.springframework.data.mapping.PropertyReferenceException: No property name found for type Employee!
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1628) ~[spring-beans-4.3.9.RELEASE.jar:4.3.9.RELEASE]
Caused by: org.springframework.data.mapping.PropertyReferenceException: No property name found for type Employee!
at org.springframework.data.mapping.PropertyPath.<init>(PropertyPath.java:77) ~[spring-data-commons-1.13.4.RELEASE.jar:naat org.springframework.data.mapping.PropertyPath.create(PropertyPath.java:309) ~[spring-data-commons-1.13.4.RELEASE.jar:na]
at org.springframework.data.mapping.PropertyPath.from(PropertyPath.java:272) ~[spring-data-commons-1.13.4.RELEASE.jar:na]

这是我定义的存储库接口。定义了自定义查询。

package com.example.rest.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
import com.example.rest.model.Employee;
@Repository
public interface EmployeeRepository extends JpaRepository<Employee, Long> {
Employee findByName(String employeeName);}

这是我的服务界面

package com.example.rest.service;
import java.util.List;
import com.example.rest.model.Employee;
public interface EmployeeService {

Employee save(Employee employee);
Employee getById(Long employeeId);
void delete(Long employeeId);
List<Employee> findAll();
Employee findByName(String employeeName); }

这是我的服务实现类

package com.example.rest.service;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.example.rest.model.Employee;
import com.example.rest.repository.EmployeeRepository;

@Service
public class EmployeeServiceImpl implements EmployeeService {

@Autowired
EmployeeRepository employeeRepository;

@Override
public Employee save(Employee employee) {
    // TODO Auto-generated method stub
    return employeeRepository.save(employee);
}

@Override
public Employee getById(Long employeeId) {
    // TODO Auto-generated method stub
    return employeeRepository.getOne(employeeId);
}

@Override
public void delete(Long employeeId) {
    // TODO Auto-generated method stub
    employeeRepository.delete(employeeId);
}

@Override
public List<Employee> findAll() {
    // TODO Auto-generated method stub
    return employeeRepository.findAll();
}

@Override
public Employee findByName(String employeeName) {
    // TODO Auto-generated method stub
    return employeeRepository.findByName(employeeName);
}}

没有自定义查询我的应用程序工作正常。 让我知道我犯了什么错误。

我添加了模型类

package com.example.rest.model;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="testF")
public class Employee implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Column(nullable=false, unique=true)
private Long employeeId;

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

@Column(nullable=false)
private String emailId;

@Column(nullable=false)
private Long salary;

public Employee() {
}

public Employee(Long employeeId, String employeeName, String emailId, Long salary) {
this.employeeId = employeeId;
this.employeeName = employeeName;
this.emailId = emailId;
this.salary = salary;
}

public Long getEmployeeId() {
return employeeId;
}

public void setEmployeeId(Long employeeId) {
this.employeeId = employeeId;
}

public String getEmployeeName() {
return employeeName;
}

public void setEmployeeName(String employeeName) {
this.employeeName = employeeName;
}

public String getEmailId() {
return emailId;
}

public void setEmailId(String emailId) {
this.emailId = emailId;
}

public Long getSalary() {
return salary;
}

public void setSalary(Long salary) {
this.salary = salary;
}

@Override
public String toString() {
return "Employee [employeeId=" + employeeId + ", employeeName=" + employeeName + ", emailId=" + emailId
+ ", salary=" + salary + "]";
}

@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((employeeId == null) ? 0 : employeeId.hashCode());
return result;
}

@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Employee other = (Employee) obj;
if (employeeId == null) {
if (other.employeeId != null)
return false;
} else if (!employeeId.equals(other.employeeId))
return false;
return true;
}}

3 个答案:

答案 0 :(得分:1)

您在班级员工中没有字段'name'。

spring data尝试为搜索Employee创建查询字段名称。

Employee findByName(String employeeName);}

答案 1 :(得分:1)

您的模型没有name属性,您有employeeName,因此您的查询应如下所示:

Employee findByEmployeeName(String employeeName);

有关如何构建Spring Data查询的更多信息,请参阅reference。简而言之,当您要创建查询时,您必须指定完整字段名称在实体中的写入方式。

答案 2 :(得分:0)

你不能在你的自定义查询中写 findByName 因为你没有名字字段但是你可以写 EmployeeName