基于spring data jpa @query返回map的踩坑记录

 更新时间:2021年11月22日 10:01:48   作者:Cumtvictor  
这篇文章主要介绍了基于spring data jpa @query返回map的踩坑记录,具有很好的参考价值,如有错误或未考虑完全的地方,望不吝赐教

spring data jpa @query返回map踩坑记录

最近用spring data jpa,网上看的一些教程,有的说是返回的Object[]数组,有的说是直接返回的对象,亲身验证了一下,发现主要看写法和返回结果。

用的版本是这样的:

dao代码如下:

public interface UserRepository extends JpaRepository<User, Integer> {
 
	/**
	 * 查询某些具体列,用Object[]数组接收
	 * @param realName
	 * @return
	 */
	@Query(value = "select u.userId,u.userName,u.realName from User u where u.realName = :realName")
	public Object[] getUserByRealName2(@Param("realName") String realName);
	
	/**
	 * 查询整个实体对象所有信息,可以直接用实体对象接收
	 * @param realName
	 * @return
	 */
	@Query(value = "select u from User u where u.realName = :realName")
	public User getUserByRealName3(@Param("realName") String realName);
	
	/**
	 * 返回List<Map>信息
	 * @param realName
	 * @return
	 */
	@Query(value = "select new map(u as user) from User u where u.realName = :realName")
	public List<Map<String, Object>> getUserByRealName(@Param("realName") String realName);
	
	/**
	 * 返回map对象
	 * @param realName
	 * @return
	 */
	@Query(value = "select new map(u.realName as userName,o.orgName as orgName) from User u, Org o where u.realName = :realName")
	public Map<String, Object> getUserByRealName1(@Param("realName") String realName);
}

测试的代码如下,完全没什么问题。

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:conf/root-context.xml"})
public class UserDaoTest {	
	@Autowired
	private UserRepository userRepository; 
	@Test
	public void test() {		
		Object[] u2 = userRepository.getUserByRealName2("admin");		
		User u3 = userRepository.getUserByRealName3("admin");		
		List<Map<String, Object>> u = userRepository.getUserByRealName("test");
		String userName = ((User) u.get(0).get("user")).getRealName();
		System.out.println(userName);
		
		Map<String, Object> u1 = userRepository.getUserByRealName1("admin");
		String name = ((User) u1.get("userName")).getRealName();
		System.out.println(name);	
		assert(userName.equals("admin"));
	}
}

设置JPA的Query返回Map对象

说明正常执行jpa查询的时候需要传一个对应实体进行映射返回的数据,这样有时候如果一个sql是复合sql关联很多表,就需要新建实体有点麻烦,通过下面方式就能将返回结果映射成map。

这样就能随意获取返回结果的内容

Query query = this.entityManager.createNativeQuery(sql);
  
  //设置JPA的Query返回Map对象
  query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP).setParameter("createuser", userInfo.getUsercode()).setParameter("type", type); 
  List<Map<String,String>> res =  query.getResultList();

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 全面了解Java中的CAS机制

    全面了解Java中的CAS机制

    下面小编就为大家带来一篇全面了解Java中的CAS机制。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • SpringBoot实现前后端、json数据交互以及Controller接收参数的几种常用方式

    SpringBoot实现前后端、json数据交互以及Controller接收参数的几种常用方式

    这篇文章主要给大家介绍了关于SpringBoot实现前后端、json数据交互以及Controller接收参数的几种常用方式,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03
  • 详解RestTemplate的三种使用方式

    详解RestTemplate的三种使用方式

    这篇文章主要介绍了详解RestTemplate的三种使用方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • Java this super代码实例及使用方法总结

    Java this super代码实例及使用方法总结

    这篇文章主要介绍了Java this super代码实例及使用方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • springMVC不扫描controller中的方法问题

    springMVC不扫描controller中的方法问题

    这篇文章主要介绍了springMVC不扫描controller中的方法问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • eclipse创建项目没有dynamic web的解决方法

    eclipse创建项目没有dynamic web的解决方法

    最近上课要用到eclipse,要用到Dynamic web project.但是我下载的版本上没有.接下来就带大家了解 eclipse创建项目没有dynamic web的解决方法,文中有非常详细的图文示例,需要的朋友可以参考下
    2021-06-06
  • Java中的HashMap内存泄漏问题详解

    Java中的HashMap内存泄漏问题详解

    这篇文章主要介绍了Java中的HashMap内存泄漏问题详解,WeakHashMap中的key是弱引用,如果再使用之后没有及时remove掉这个key,那么当GC时key就可能会被回收,导致key对应的value对象占用的内存无法回收进而导致内存泄漏,需要的朋友可以参考下
    2023-09-09
  • 分享java打印简单图形的实现代码

    分享java打印简单图形的实现代码

    这篇文章主要分享给大家运用java打印简单图形:三角形,菱形,四边形,需要的朋友可以参考下
    2015-07-07
  • java软引用在浏览器使用实例讲解

    java软引用在浏览器使用实例讲解

    在本篇文章里小编给大家整理的是一篇关于java软引用在浏览器使用实例讲解内容,有兴趣的朋友们可以学习下。
    2021-04-04
  • java string 转date方法如何实现

    java string 转date方法如何实现

    在开发应用中经常会使用到java string 转date这种不是很常见的做法,本文将以此问题提供详细解决方案,需要了解的朋友可以参考下
    2012-11-11

最新评论