>>分享孙卫琴的Java技术专稿和著作 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 16126 个阅读者 刷新本主题
 * 贴子主题:  【Spring专题】@Query注解设定查询语句 回复文章 点赞(0)  收藏  
作者:sunweiqin    发表时间:2021-10-09 11:24:51     消息  查看  搜索  好友  邮件  复制  引用

本文参考《精通Spring:JavaWeb开发技术详解》,作者:孙卫琴,清华大学出版社出版

如果用@Query注解来设定查询条件,方法名字不需要符合特定的规则。例如以下CustomerDao接口通过@Query注解标识了两个查询方法:
……
import org.springframework.data.jpa.repository.Query;

@Repository
public interface CustomerDao extendsJpaRepository<Customer,Long>{
  @Query("from Customer where name = ?1")
  List<Customer> queryByName(String name);

  @Query("from Customer where name like?1  and age>= ?2")
  List<Customer> queryByNameAge(String name,int age);
}

以下程序代码调用上述查询方法:

List<Customer>result1=customerDao.queryByName("Tom");

List<Customer>result2=customerDao.queryByNameAge("Tom",18);

运行以上程序代码时,底层的Hibernate依次执行以下SQL查询语句:

select * from CUSTOMERS where NAME="Tom";
select * from CUSTOMERS where NAME like "Tom"and AGE>=18;

默认情况下,向@Query注解提供的是面向对象的JPQL(JPA Query Language)查询语句。JPQL查询语句中引用的是类以及类的属性,例如:

@Query("from Customer where name like?1  and age>= ?2")

以上JPQL查询语句中引用了Customer类名以及name和age属性名。

此外,把@Query注解的nativeQuery属性设为true,就可以向Query注解直接提供SQL查询语句。nativeQuery属性的默认值为false。
例如以下CustomerDao接口中的@Query注解采用了SQL查询语句:

@Repository
public interface CustomerDao  extends JpaRepository<Customer,Long>{

  @Query(value="select * from CUSTOMERSwhere NAME = ?1 ",
          nativeQuery=true)
  List<Customer> queryByNameNative(String name);

  @Query(
    value="select * from CUSTOMERS whereNAME like ?1 and AGE>=?2",
    nativeQuery=true)
  List<Customer> queryByNameAgeNative(String name,int age);
}

以上SQL查询语句引用的是数据库中的表和字段的名字,而不是类名以及类的属性名,这是和JPQL查询语句的显著区别。




程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->Java语言中的修饰符
  JavaWeb开发-->面向对象开发方法概述之开发思想(上)
  JSP与Hibernate开发-->Servlet技术详解(Ⅲ)
  Java网络编程-->使用Session(Ⅰ)
  精通Spring-->映射一对多关联关系
  Vue3开发-->Java对象持久化技术概述
  【Vue.js技术专题】Vue组件的数据监听
  【Vue.js技术专题】Vue组件的单向数据流
  【Vue.js技术专题】CSS中DOM元素的过渡模式
  【Vue.js技术专题】分割setup()函数
  【Vue.js技术专题】在Vue项目中使用Axios
  【Spring Cloud Alibaba专题】按照集群模式搭建Redis集群
  【Java基础编程专题】使用和创建JavaDoc文档
  【持久化专题】为什么JPA和Hibernate的持久化方法都抛出运行...
  【Spring专题】用Spring框架进行文件下载
  【Spring专题】@ControllerAdvice注解的用法
  视频:我的Java课堂总动员,带领小白们走马观花看Java江湖
  从《精通Spring》和《精通Vue.js》的写作分享学习新技术的经...
  【持久化专题】JPA API的级联操作
  【持久化专题】JPA的事件处理API的用法
  IT培训课、视频教程和书本之PK
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。