使用Spring Data Jpa遇到问题汇总

使用Spring Data Jpa遇到问题汇总


用于记录我在使用spring data jpa时遇到的各种问题及其解决方案

  • 使用Spring Data Jpa遇到问题汇总
    • 自定义查询语句(@Query 与 nativeQuery)
    • 返回自定义查询对象(如”select new Map(xx,xx,xx)”)
    • 字段映射相关问题
      • 字段命名解析
      • 字段类型解析
      • @Transient
    • 分页

自定义查询语句(@Query 与 nativeQuery)

只需要在方法上加上注解@Query即可,默认使用HQL如下:
NetworkInfo是对应的实体类

@Query("SELECT count(n.network) FROM NetworkInfo n where network=?1")
 Long countDeviceNumByNetwork(String network);

如需要使用数据库的SQL语句,则需要在@Query注解内加上 nativeQuery=true如 @Query(value=”xxx”,nativeQuery=true)
如下:

@Query(value = "SELECT network_type,count(network_type) as count FROM network_manage WHERE network = ?1 " +
            "and TIMESTAMPDIFF(YEAR,(CASE WHEN DATE(in_net_date) is NULL THEN " +
            "CONCAT(in_net_date,'/01/01') ELSE in_net_date END),NOW())>=?2 GROUP BY network_type", nativeQuery = true)
    List countDeviceNumInNetDateMoreThanYEARSIntGroupByNetworkType(String network, int years);

返回自定义查询对象(如”select new Map(xx,xx,xx)”)

可以在注解里使用HQL来返回自定义对象 例子如: @Query(“select new XXX(XX)”)
默认返回的Map是以序号为key(如0,1,2)
样例:

@Query("SELECT new Map(manufacturer,networkType,count(manufacturer)) FROM NetworkInfo WHERE network = ?1 " +
            "GROUP BY manufacturer,networkType")
    List> countDeviceNumGroupByManufacturerAndNetworkType(String network);

若是使用nativeQuery默认返回一条记录为Object[] 样例见上面自定义查询语句

字段映射相关问题

字段命名解析

我使用spring boot + spring data jpa时,默认的表名映射规则是遇到大写(比如aAaAa),则将大写字母替换为下划线+小写字母(a_aa_aa).
一般JAVA中的变量命名规范都符合驼峰式,此时数据库遇到一个字段”portDesc”,而我的实体类的变量名也为portDesc,此时就会将这个portDesc解析为”port_desc”然后就会报错.
我查了两种解决方法
1.最方便的解决方案是给字段加上@Column(name=”portdesc”) (前提是你的数据库大小写不敏感?)
2.还有更改解析策略的方式(spring boot配置):

spring.jpa.hibernate.naming.physical-strategy = org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

但是使用了这种方式会让默认的驼峰解析成下划线的规则失效.

字段类型解析

使用映射时,我遇到了text,longtext,set等字段类型,使用默认的映射规则时报了错,无法直接使用String获取.
解决方案@Column(columnDefinition=”XXX”).

@Transient

当我们在实体类中加上一个不与数据库表一一对应的成员变量的时候,此时我们只要在这个成员变量上加上注解@Transient

分页

通过Pageable来分页查询
https://blog.csdn.net/u011848397/article/details/52151673
多种方法实现分页(包括HQL或本地sql)
https://www.cnblogs.com/hdwang/p/7843405.html
Spring Data JPA: 分页和排序
https://blog.csdn.net/u011848397/article/details/52151673

你可能感兴趣的:(spring,持久层,spring,data,jpa,java,问题集)