`
xiaofan_0204
  • 浏览: 126950 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JPA本地查询(Native Query)(一)

    博客分类:
  • JPA
阅读更多
JPA支持本地查询,所谓本地查询,就是使用原生的sql语句(根据数据库的不同,在sql的语法或结构方面可能有所区别)进行查询数据库的操作。
public interface EntityManager {
public void persist(Object entity);
public <T> T find(Class <T> entityClass, Object primaryKey);
public <T> T getReference(Class <T> entityClass, Object primaryKey);
public <T> T merge(T entity);
public void remove(Object entity);
public void lock(Object entity, LockModeType lockMode);

public void refresh(Object entity);
public boolean contains(Object entity);
public void clear( );

public void joinTransaction( );
public void flush( );
public FlushModeType getFlushMode( );
public void setFlushMode(FlushModeType type);

public Query createQuery(String queryString);
public Query createNamedQuery(String name);
   public Query createNativeQuery(String sqlString);
public Query createNativeQuery(String sqlString, String resultSetMapping);
public Query createNativeQuery(String sqlString, Class resultClass);

   public Object getDelegate( );

public void close( );
public boolean isOpen( );
}


即 createNativeQuery方法的三种形式,但用这个方法的缺点是,要将查询的sql语句及返回结果集类型传递进去。还有一种方法是使用createNamedQuery,这样就可以避免在这里直接写入sql语句以及返回的结果集类型等参数,而可以在相关的Entity类里对这些信息进行配置。
@SqlResultSetMappings(

{

    @SqlResultSetMapping

    (

       name="ReturnOrderListWithFullScalarType",

       entities={},

       columns=

       {

           @ColumnResult(name="order_id"),

           @ColumnResult(name="order_creation_date"),

           @ColumnResult(name="order_description"),

           @ColumnResult(name="order_sum_total"),

           @ColumnResult(name="customer_id"),

           @ColumnResult(name="customer_name")

       }

    ),

      // 。。。。。。。。。。。。。可能还有更多的结果集映射设置

})


针对每一个本地查询的返回值,都有一个结果集和它映射。它可以返回

1. 实体(包括不同类型的实体,即多个实体) Entity

2. 标量值 Scalar

3. 实体与标量值的组合 Entity+Scalar

默认情况下,JPA假设原生sql查询中select语句将会:

1.      返回一个实体类型

2.      包含与返回的实体的所有字段或属性相对应的所有列,即列名和实体属性/字段名一样

3.      查询中没有用列名别名,column alias,即没有用 AS 指定别名

@SqlResultSetMappings,如果在一个实体类中有多个@NamedNativeQuery的话,必然就有多个结果集映射@SqlResultSetMapping。在这种情况下,必须使用该批注,并且将单个的SqlResultSetMapping都作为SqlResultSetMappings数组中的一个元素。

@SqlResultSetMapping,关于结果集映射的详细信息。

name 表示该结果集映射的名字,与@NamedNativeQuery中的resultSetMapping="ReturnOrderListWithFullScalarType"的值相对应。

entities表示查询结果集会被映射进实体,如果有就要将所有返回的实体一一列出(这里我们将结果集全部映射进标量,所以entities属性是个空数组)。

columns表示将被映射进标量的结果集中的各个列。

这里要说一下标量(Scalar)这个概念。在物理学上,标量与矢量(Vector)是相互对应的,矢量是既有方向又有大小的量,而标量是只有大小的量。在此处,Scalar的含义与物理学上的定义差不多,Scalar可以认为是一个没有属性/方法的单纯的常量(可以想象为java数据类型的primitive type),而与它相对的则是有方法/属性的对象(object type)。那么采用这种映射机制,我们从数据库取来的每一条记录的每一个字段,仅仅是被单纯的作为一个常量,保存在每一个columnResult中。

@ ColumnResult,就是指在sql语句中,将哪些查询的列保存进来。每一个@ColumnResult对应一个列,name="order_id" ,注意,如果在select的时候,用AS 制定了列的别名,“order_id” 则表示的是别名。

这种映射方式比较简单,我们可以推测,得到的结果集List中,数据会是这样:

[  {“列1”, “列2”, “列3”,  …},  {“列1”, “列2”, “列3”,  …}, ……  ]

经过运行测试程序,得到了我们的推论

*****ReturnOrderListWithFullScalarType*****

52  2009-05-27 00:00:00.0    This is an order creation example. 36817.0    39  John Smith

55  2009-05-27 00:00:00.0    This is an order creation example. 3347.0 39  John Smith

……

将结果集全部映射进标量,是比较简单的一种做法,在SqlResultSetMapping的写法上也没有太多需要注意的地方。
分享到:
评论

相关推荐

    SpringDataJpa 动态复杂查询NativeQuery

    SpringDataJpa 动态复杂查询NativeQuery emm挺长时间没更新了,最近在忙项目,外加搬家,后续会继续更新 遇到一个复杂的sql查询,在不通过外键关联的情况下,只能选择使用原生sql的方式查询,但是遇到一个极其XX的...

    让JPA的Query查询接口返回Map对象的方法

    让JPA的Query查询接口返回Map对象的方法 JPA(Java Persistence API)是一种java持久层标准,提供了统一的数据访问机制。其中的Query查询接口是我们常用的数据查询方式。然而,在JPA 2.0中,使用entityManager....

    在JPA的@Query注解中使用limit条件(详解)

    在 JPA 中,我们可以使用 @Query 注解来定义查询语句。在查询语句中,我们可以使用 Limit 条件来限制查询结果的数量。例如,我们可以使用以下方式来定义查询语句: ```java @Query("SELECT m FROM Misaka m WHERE m...

    使用JPA中@Query 注解实现update 操作方法(必看)

    在Java Persistence API (JPA)中,`@Query`注解是用于自定义查询的一种方式,它可以让我们在Repository接口中直接编写SQL或者HQL(Hibernate Query Language)来执行数据库操作。在本例中,我们将详细探讨如何使用`@...

    Java工作笔记-JPA中使用@query注解(分页查询实例)

    在这个例子中,`nativeQuery = true`表明我们要使用原生的SQL查询而非HQL。`findCustomizedPage`方法接收`offset`和`size`作为参数,这两个值由Pageable对象计算得出。`Pageable`接口包含了分页所需的所有信息,包括...

    Spring Data JPA入门项目02

    6. 原生查询:对于JPA无法处理的复杂查询,Spring Data JPA还提供了`@Query nativeQuery = true`选项,允许我们编写原生的SQL查询。 在"Spring Data JPA入门项目02"中,你将学习如何在实际项目中应用这些概念,创建...

    详解Spring Data JPA使用@Query注解(Using @Query)

    value 参数指定查询语句,而 nativeQuery 参数指定是否使用原生 SQL 语句。 使用 @Query 注解的优点: * 可以使用 JPQL 语句或原生 SQL 语句来定义查询语句 * 可以使用参数来定义查询语句 * 可以使用 @Param 注解...

    使用JPA时@Query中的insert语句之对象传参

    `@Query`是Spring Data JPA提供的一种特性,允许开发者在Repository接口的方法上直接书写定制的SQL或HQL查询,从而执行数据库操作。这样可以避免创建复杂的SQL映射文件或者过多的DAO层代码。 当我们需要插入一个新...

    spring boot query查询

    4. **原生SQL**:`@Query`还支持执行原生SQL查询,只需在HQL查询前添加`nativeQuery = true`。 总的来说,Spring Boot提供了多种查询方式,`@Query`注解是其中一种强大的工具,它允许开发者灵活地定制查询逻辑,以...

    使用SpringBoot-JPA进行自定义保存及批量保存功能

    @Query(value = "INSERT INTO t_student(seq, name, sex) VALUES (getseq('student_seq'), :#{#student.name}, :#{#student.sex})", nativeQuery = true) int insert(@Param("student") StudentDO student); ``` ...

    SpringData@Query的注释的代码实现

    除了HQL,`@Query`也支持原生的SQL查询,只需要在查询字符串前加上`nativeQuery = true`即可: ```java @Query(value = "SELECT * FROM users WHERE id = ?1", nativeQuery = true) User findUserById(Long id); ``...

    Spring Data JPA.zip

    通过 `@Query` 注解可以在 Repository 方法上添加自定义的 JPQL 或 Native SQL 查询。 **9. 分页与排序** Spring Data JPA 提供了分页和排序的支持,可以通过 `Pageable` 参数实现。 **10. 异常处理** 在使用 ...

    JPA2.0高级教程

    - **JPQL**:Java Persistence Query Language,一种面向对象的查询语言,类似于SQL但更加面向对象。 - **Criteria API**:提供了一种类型安全的方式构建查询,适用于复杂的查询场景。 - **Native SQL**:直接执行...

    Open JPA2 employee 简单例子

    OpenJPA2还提供了查询语言JPA QL(Java Persistence Query Language),可以用来执行更复杂的查询。此外,OpenJPA2支持懒加载、级联操作、缓存策略等高级特性,这些在实际项目中都是很实用的功能。 通过这个简单的...

    Spring Data Jpa – 获得实体类部分字段(单表或多表)

    @Query(value = select username from user,nativeQuery = true) // 注意返回值用String类型接收,也可以使用Object String findOneUserName(); 二、单表查询的一个字段、多条数据 @Query(value = select distinct ...

    Spring Data JPA从入门到精通

    更复杂的查询可以通过@Query注解,直接编写JPQL(Java Persistence Query Language)或native SQL。 7. **事务管理**:Spring Data JPA利用Spring的声明式事务管理,只需在方法上添加@Transactional注解,即可实现...

    Spring Data JPA分页复合查询原理解析

    例如,使用@Query(value="select * from C_Article where type=:type \n--#pageable\n",countQuery="select count(*) from C_Article where type=:type",nativeQuery=true)可以实现分页查询。但是,需要注意的是,在...

    spring data jpa 最新文档 2012

    此外,`@NativeQuery`可以用来执行SQL原生查询。 **6. 抽象Repository** 为了减少重复的Repository接口定义,Spring Data JPA提供了基类,如`PagingAndSortingRepository`,它增加了分页和排序的功能。开发者可以...

    Native-SQL查询 (1).ppt

    本节主要探讨的是如何在Hibernate框架中使用Native SQL查询,它允许开发者直接执行原生的SQL语句,绕过HQL(Hibernate Query Language)进行更灵活的数据操作。 Hibernate是一个流行的Java对象关系映射(ORM)框架...

    IBM最新spring2.0+JPA教程加源代码

    JPA 2.0 版本引入了更多的功能,如 Criteria 查询、 NamedQuery 和 Native Query,以及支持多态性、延迟加载等高级特性。 在Spring 2.0中集成JPA,可以利用Spring的数据访问抽象层,如JdbcTemplate和...

Global site tag (gtag.js) - Google Analytics