首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用命名查询返回Map<key,value>?

如何使用命名查询返回Map<key,value>?
EN

Stack Overflow用户
提问于 2013-06-03 14:13:58
回答 2查看 4.1K关注 0票数 3

我使用命名查询来返回List<?>。但是现在我有一个要求,我必须返回一个Map<key,value>,这样我就可以使用密钥过滤重复项。

我有一个命名查询来返回产品名称的List<String>

代码语言:javascript
复制
<named-query name="FETCH_ACTIVE_PRODUCTS_NAME" >
    <query>SELECT product.name FROM Product product
           WHERE product.name LIKE :name
    </query>
</named-query>

另一个用于获取产品描述的List<String>的命名查询,

代码语言:javascript
复制
  <named-query name="FETCH_ACTIVE_PRODUCTS_DESC" >
    <query>SELECT product.desc FROM Product product
           WHERE product.desc LIKE :desc
    </query>
</named-query>

另一个按产品名称获取产品id的命名查询

代码语言:javascript
复制
 <named-query name="FETCH_ACTIVE_PRODUCTS_ID_BY_NAME" >
    <query>SELECT product.id FROM Product product
           WHERE product.name LIKE :name
    </query>
</named-query>

现在我必须返回一个包含key和value..key的Map<Long,String>,其中包含产品id,并且包含产品名称和description..the key的值不应包含重复值(即重复的产品id)。

现在我的问题是如何在命名查询中返回Map<Long,String>……我没有从谷歌得到任何帮助……任何人都有关于如何做到这一点的想法。

EN

回答 2

Stack Overflow用户

发布于 2013-06-03 14:28:10

您可以在代码(调用者方法)中执行此操作,方法是循环遍历列表并将值添加到映射中。

代码片段

代码语言:javascript
复制
List <Product> products = new ArrayList<Product>();
// update products list by fetching from db.
Map<Long, String> productDesc = new HashMap<Long, String>();
for(Product prod : products) {
    if(productDesc.get(prod.getId() == null){
        productDesc.put(prod.toString());
    }
}

如果必须在许多地方使用,还可以将遍历列表并返回映射的代码片段放在产品对象本身中。

票数 0
EN

Stack Overflow用户

发布于 2013-06-03 14:43:54

请看这篇文章。也许这会对你有所帮助。要删除重复项,可以在另一个命名查询中尝试嵌套查询。

how to return Map with HQL

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16890906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档