我正在使用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();}
%>
答案 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。
列表我还没有测试过这段代码。但它提供了我的想法。