从struts中的数据库中检索数据

时间:2012-12-02 06:58:47

标签: java struts

我正在使用struts框架检索所有数据库数据,代码运行良好。

我只是把数据列表(数组列表)放在JSP的请求中(如上面的代码所示)。我知道我们可以用逻辑标签库获取数据,但我对此并不太了解。是否可以放请求中的数据?我们如何使用逻辑库或任何其他方式检索数据?

        HashMap hm =null;
        List list = new ArrayList();
        String uname="";
        int no=0;
        while(rs.next())
        {
            uname=rs.getString(1);
            no = Integer.parseInt(rs.getString(2));
            hm=new HashMap();
            hm.put("name", uname);
            hm.put("number", no);

            list.add(hm);

        }

        request.setAttribute("myList",list);

jsp页面。

                   <%
                        try
                        {
                            DataForm d= new DataForm();
                            HashMap hm;
                            List list = new ArrayList();
                            if(request.getAttribute("myList")!=null)
                                list=(List)request.getAttribute("myList");
                            else
                                out.print("No Data Found..");

                             for(int i=1;i<list.size();i++)
                             {
                                hm=(HashMap)list.get(i);

                                %><tr> <td><%out.println(hm.get("name"));%></td>
                                 <td><%out.println(hm.get("number"));%></td></tr><%
                            }
                        }
                        catch(Exception e){e.printStackTrace();}
                    %>

2 个答案:

答案 0 :(得分:0)

逻辑标记不用于检索数据:它们用于在JSP中实现某些逻辑而不使用scriptlet,这被认为是不好的做法。

这确实是控制器的工作(Struts动作),不是从数据库中检索数据,而是调用将要对象列表的对象,以便视图显示它们

然而,struts逻辑标记几乎都被弃用,有利于JSP EL和JSTL。您的scriptlet代码可以替换为以下行:

<c:choose>
    <c:when test="${myList == null}">
        No Data Found.
    </c:when>
    <c:otherwise>
        <c:forEach var="element" items="${myList}">
            <tr>
                <td><c:out value="${element.name}"/></td>
                <td><c:out value="${element.number}"/></td>
            </tr>
        </c:forEach>
    </c:otherwise>
</c:choose>

哪个更具可读性并正确地逃避数据。

我还会使用对象而不是HashMaps来保存您的数据。 Java是一种OO语言。使用对象和封装。

答案 1 :(得分:0)

如果我正确理解你要做的事情,我必须说你没有有效地使用HashMap。

Hashmap用于存储对,以便您可以使用快捷键~O(1)来检索值。键在散列映射中是唯一的。如果您尝试使用相同的密钥依次存储多个对,则数据将被覆盖,最后您将只看到最后一对。

在这个例子中,你使用HashMap作为容器来保存“name”和“number”,因此我根本看不到对hashMap的真正需求。

这是你可以做的:

定义一个包含姓名和号码的类:

class Data
{
    private String name;
    public int uNo;
    public Data(String name, int uNo)
    {
        this.name = name;
        this.uNo = uNo;
    }
    public getName()
    {
        return this.name;
    }
    public getUNo()
    {
        return this.uNo;
    }
}

您的Java代码:

List<Data> list = new ArrayList<Data>();
while(rs.next())
{
    String uname=rs.getString(1);
    int no = Integer.parseInt(rs.getString(2));
    list.add(new Data(uname, no));
}
request.setAttribute("myList",list);

您的Jsp代码:

<%
    try
    {
        DataForm d= new DataForm();
        List<Data> list = new ArrayList<Data>();
        if(request.getAttribute("myList")!=null)
        {
           list = (List<Data>)request.getAttribute("myList");
           for(Data data in list)
           {
               %><tr><td><%out.println(data.getName());%></td>
                     <td><%out.println(data.getUNo());%></td></tr><%
           }
        }
        else
        {
           out.print("No Data Found..");
        }
     }
     catch(Exception e){e.printStackTrace();}
%>

现在,来到逻辑标记库

您需要进行以下修改:

i)在你的jsp中,你可以这样做: 在jsp的开头添加这些行:

<%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean" %>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic"%>

使用这些来编写数据:

<logic:present name="myList">
  <logic:iterate name="myList" id="myListId">
     <tr>
          <td><bean:write name="myListId" property="name"/></td>
          <td><bean:write name="myListId" property="uNo"/></td>
     <tr>
  </logic:iterate>
</logic:present>
<logic:notPresent name="myList">
    No Data found.
</logic:notPresent>

理想情况下,我会使用JSTL来显示User / No。

列表

我还没有测试过这段代码。但它提供了我的想法。