1

这是我的桌子的样本

CREATE TABLE elements (
 elementname,
 displaytext
)  

我如何使用 jpa 并填充 hashmap 以便我可以将其传递给控制器​​查看

HashMap<String, String> hm = new HashMap<String, String>();

render(hm);

在视图中我想遍历并根据元素名称获取显示文本

不是 100% 确定这是否是一种矫枉过正或是否存在更简单的方法。看到这篇文章

UPDATE1:播放框架工作 1.2.4

4

1 回答 1

8

我不认为你需要一个 Map ,而只是一个元素列表。如果我错了,请更清楚地解释您要达到的目标。


第一个解决方案

您的型号:

@Entity
public class Element extends Model {
   public String name;
   public String text;
}

在您的控制器中:

public static void findElements(){
   List<Element> elements = Element.findAll();
   render(elements);
}

在您看来:

<ul>
#{list items:elements, as:element}
   <li>Name: ${element.name}, Text: ${element.text}</li>
#{/list}
</ul>

第二个解决方案

否则,如果您需要实际地图,您可以使用上面的模型并在控制器中填充地图:

public static void findElements(){
   List<Element> elements = Element.findAll();
   HashMap<String,String> hm= new HashMap<String,String>();
   for(Element el: elements){
      hm.put(el.name, el.text);
   }
   render(hm);
}

看法:

<ul>
#{list items:hm.KeySet(), as:name}
   <li>Name: ${name}, Text: ${elements.get(name)}</li>
#{/list}
</ul>

第三种解决方案 为您的地图创建一个容器:

@Entity
public class ElementContainer extends Model {
    @ElementCollection(fetch = FetchType.EAGER)
    @MapKeyColumn(name = "name_key", nullable = false)
    public Map<String, String> hm;
}

控制器:

public static void findElements(){
   ElementContainer ec = ElementContainer.find().first();
   Map<String,String> hm = null;
   if(ec!=null)
      hm = ec.hm;
   render(hm);
}
于 2012-09-12T06:37:47.157 回答