Java 如何在jsp中迭代多重映射值

Java 如何在jsp中迭代多重映射值,java,jsp,servlets,foreach,multimap,Java,Jsp,Servlets,Foreach,Multimap,如何迭代或从多重映射接收值?我有一个键,它与某个数组值关联。我需要第一个键,然后是所有值,然后是第二个键,其他值,但我不知道如何在多重映射上迭代 这是我的密码: 这是我调用业务逻辑类方法的servlet public class Emp_Mapping extends HttpServlet { protected void processRequest(HttpServletRequest request, HttpServletResponse response)

如何迭代或从多重映射接收值?我有一个键,它与某个数组值关联。我需要第一个键,然后是所有值,然后是第二个键,其他值,但我不知道如何在多重映射上迭代

这是我的密码:

这是我调用业务逻辑类方法的servlet

    public class Emp_Mapping extends HttpServlet
    {
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
    HttpSession session = request.getSession(true); 
    Employee emp1 = (Employee)session.getAttribute("emp1");
    session.setAttribute("emp1",emp1);    
    EmployeeBean eb = new EmployeeBean();   
    List<Employee> detail2 = eb.emp_map_detail1(emp1);//here i am calling
         System.out.println(detail2);       
        request.setAttribute("detail2",detail2);
        request.getRequestDispatcher("/EmployeeMapping.jsp").forward(request, response);
    }}
这是我的Employee类的方法,我将其保留为业务逻辑类,在该类中,servlet之后的所有请求都通过方法调用传递给特定的方法。 在这里,它工作正常,并按照我的要求保持所需的值:

      public List<Employee> emp_map_detail1(Employee emp1) {
      Connection con = null;
      Statement stmt2,stmt3,stmt4 = null;  
      ResultSet rs2 =null;
      ResultSet rs3 =null;
      ResultSet rs4 =null;
      int e1=0, e2=0,e3=0,e4=0;
      String n2=null,n1=null,n4=null;
      List<Employee> detail2 = new ArrayList<Employee>();
      Multimap<String, String> multimap1 = ArrayListMultimap.create();
      Multimap<String, String> multimap2 = ArrayListMultimap.create();  

      List<String> myList2 = new ArrayList<String>();          
      try{
      con = ConnectionManager.getConnection();
      stmt2 = con.createStatement();
      String Query12 = "select empId, empName from empinfo where access_type='manager'";
      System.out.println("Query1 is" +Query12);
      rs2 = stmt2.executeQuery(Query12);
      while(rs2.next())
      {
      e1 =Integer.parseInt(rs2.getString("empId"));
      n1 = rs2.getString("empName");
      myList2.add(n1);        
      stmt3 = con.createStatement();
      String Query13 = "select empId, empName from empinfo where empId in 
      (select distinct   employee_teamleader from employeegroup 
      where employee_manager='"+e1+"')  and access_type ='teamleader' ";
      System.out.println("Query1 is" +Query13);
      rs3 = stmt3.executeQuery(Query13);
      while(rs3.next())
      {
      e3 =Integer.parseInt(rs3.getString("empId"));
      n2 = rs3.getString("empName");    
       multimap1.put(n1,n2);
          stmt4 = con.createStatement();
       String Query14 = "select empId, empName from empinfo where
       empId in (select distinct employee_name from employeegroup 
       where employee_teamleader='"+e3+"') and access_type ='employee'";
       System.out.println("Query1 is" +Query14);
       rs4 = stmt4.executeQuery(Query14);
       while(rs4.next())
      {
       e4 =Integer.parseInt(rs4.getString("empId"));
       n4 =rs4.getString("empName");
       multimap2.put(n2,n4);
       System.out.println("multimap1" +multimap1);
        System.out.println("multimap2" +multimap2);
       }}}
        emp1.setEmpname2(multimap2);
        emp1.setManname1(myList2);
        emp1.setTlname2(multimap1);
       detail2.add(emp1);
       emp1.setValid(true);
      }  
      catch (SQLException  ex) {

      } finally {
          try {
              if (stmt4 != null) {
                  stmt4.close();
              }
              if (con != null) {
                  con.close();
              }
          } catch (SQLException ex) {
              Logger.getLogger(EmployeeBean.class.getName()).log(Level.SEVERE, null, ex);
          }
      }
    return detail2;
    }
这里是employee bean类,在该类中我有所有与employee相关联的方法。在这里,我只提供了变量所需的setter和getter方法:

      public class Employee 
      {
      private Multimap<String, String> tlname2;

    public Multimap<String, String> getTlname2() {
    return tlname2;
     }
    public void setTlname2(Multimap<String, String> tlname2) {
    this.tlname2 = tlname2;
     }
     }
这里介绍如何在jsp中打印。我不知道它不是这样迭代的:

<c:forEach var="temp" items="${emp1.tlname2}">
 ${temp}
</c:forEach>
请尝试以下jsp:

<c:forEach var="myMap" items="${emp1.tlnameMap}">
  <c:out value=" key is ${myMap.key}" />
  <c:forEach var="mapValue" items="${myMap.value}" varStatus="count">
        <c:out value=" value ${count.index} is ${mapValue}" />
  </c:forEach>
</c:forEach
并创建一个新方法,该方法将返回multiMap的地图视图,如下所示:

public Map<String, Collection<String>> getTlnameMap() {
    return tlname2.asMap();
}
请尝试以下jsp:

<c:forEach var="myMap" items="${emp1.tlnameMap}">
  <c:out value=" key is ${myMap.key}" />
  <c:forEach var="mapValue" items="${myMap.value}" varStatus="count">
        <c:out value=" value ${count.index} is ${mapValue}" />
  </c:forEach>
</c:forEach
并创建一个新方法,该方法将返回multiMap的地图视图,如下所示:

public Map<String, Collection<String>> getTlnameMap() {
    return tlname2.asMap();
}

不,如果我使用detail2,那么也不起作用,先生,请正确检查为什么我使用tlname2而不是detail2,因为我有不同的值您看到了它,请尝试帮助我,它不是正常的一个它的多重映射这就是为什么给出问题您在哪里定义了tlname2?请只粘贴相关代码而不是整个项目代码。是guava multimap还是commons collections?在问任何问题之前,你应该先澄清一下。为什么不使用地图而不是多重地图呢?这不是multimap的意思吗?我的数组值是这样的{Sampath=[Thamil,A.K.karan],Kanan=[john]}因此,我必须显示No如果我使用detail2,那么也不起作用,先生,请正确检查为什么我使用tlname2而不是detail2,因为我有不同的值你看到了,请尝试帮助我,它不是正常的一个它的多重映射,这就是为什么给出问题你在哪里定义了tlname2?请只粘贴相关代码而不是整个项目代码。是guava multimap还是commons collections?在问任何问题之前,你应该先澄清一下。为什么不使用地图而不是多重地图呢?这不是multimap的意思,我的数组值是这样的{Sampath=[Thamil,A.K.karan],Kanan=[john]},所以我必须显示它