返回所有给定属性和值的记录
Returns all having the given attribute and value.
接口定义
@Query("select p from Product p where p.attributes[?1] = ?2")
List<User> findByAttributeAndValue(String attribute, String value);
接口调用
List<User> products = repository.findByAttributeAndValue("name", "azheng");
自定义(DTO/VO)返回,动态返回,返回泛型,动态投影
(spring-data-jpa自定义查询返回、spring-data-jpa自定义实体类返回)
Dynamic Projections(动态投影)
Repository查询接口定义
interface PersonRepository extends Repository<Person, UUID> {
<T> Collection<T> findByUsername(String username, Class<T> type);
}
spring-data-jpa默认支持 泛型 动态投影 ,投影的类型可以是接口也可以是类。
基于接口的投影,须提供字段对应的get方法接口。
interface NamesQueryDTO {
String getFirstname();
String getLastname();
}
基于类的投影,定义好所有查询字段,并且提供全参构造器。强烈推荐 使用Lombok的@Value注解 简化代码。
@Value
class NamesOnlyDTO {
String firstname, lastname;
}
使用SpEL表达式
Using SpEL Expressions
取数据库实体名称 #{#entityName}
@Query("select u from #{#entityName} u where u.lastname = ?1")
List<User> findByUsername(String username);
这样写的好处就是当你修改类名时 ,不需要单独去修改这个参数。
在方法签名中使用域类型
通过使用在JavaConfig配置类上配置@EnableSpringDataWebSupport 注释 来启用集成支持 。
@Configuration
@EnableSpringDataWebSupport
class WebConfiguration { }
实例可以解决通过让Spring MVC path变量转换成的id类型的域类,最终通过调用访问实例 findOne(…) 在存储库实例注册域类型。
@RestController
@RequestMapping("/users")
public class UserController {
@RequestMapping("/{id}")
public Object showUserForm(@PathVariable("id") User user) {
return user;
}
}
请加qq交流群(758629787) 免费获取更多教程和源码。