JSP页面数据展示:分组数据展示
一、描述:
页面上要展示的数据只要写好sql从数据库查出来即可,但是展示有时候不是太好处理。比如工作中遇到的这种情况:有一个问题处理的流程,其中需要选择下一处理人,这些处理人要以部门的形式分组展示,实现如下图所示的效果:

二、思路
因为是小项目,项目只使用了strut框架,数据库使用普通的JDBC通过C3P0连接数据库;
a)首先按角色分组查询出所有用户,每个角色的用户存到List里面;
b)然后把每组角色放到一个Map里面去,这样可以通过角色获取到对应角色用户的List;
c)JSP页面上通过JSTL标签的foreach标签将结果显示出来;
三、程序实现
java查询数据:
public String sendQuestion(){
HttpServletRequest request = ServletActionContext.getRequest();
//查询问题相关角色SQL;客服、测试、技术
String sql_role = "select id,name from role where isvalid = true and c_id in (7,8,9)";
Connection conn = null;
Statement st = null;
ResultSet rs = null;
try {
conn = BaseDao.getConnection();
st = conn.createStatement();
rs = st.executeQuery(sql_role);
//查询角色表,保存角色id和角色名称
List<Map<String,Object>> list_role = new ArrayList<Map<String,Object>>();
while(rs.next()){
Map<String,Object> data = new HashMap<String, Object>();
data.put("id", rs.getInt("id"));
data.put("name", rs.getString("name"));
list_role.add(data);
}
//声明按角色分组存放用户的map<角色信息,该角色的用户> ;这里似乎应该用TreeMap,但HashMap好像也可以,这个先放一边
Map<Map<String,Object>,List<Map<String,Object>>> map = new HashMap<Map<String,Object>,List<Map<String,Object>>>();
for(int i=0;i<list_role.size();i++){ //遍历角色,并查询每个角色的所有用户
int roleId = (Integer)list_role.get(i).get("c_id");
String sql = "select u.id ,u.name from user u where u.isvalid = true and u.roleid = "+roleId ;
rs = st.executeQuery(sql);
List<Map<String,Object>> users = new ArrayList<Map<String,Object>>();
while(rs.next()){
Map<String,Object> user = new HashMap<String,Object>();
user.put("user_id", rs.getInt("id"));
user.put("user_name", rs.getString("name"));
users.add(user);
}
//分组保存用户
map.put(list_role.get(i), users);
}
request.setAttribute("ulist", map);
} catch (SQLException e) {
e.printStackTrace();
}finally{
BaseDao.closeResources(st, rs);
}
return "selectUsers" ;
}
JSP页面展示处理:
<a class="wsy_f14 wsy_nomarginright"><span>选择下一节处理人: </span><button type="button" onclick="return queryUsers();" >展开/缩回</button></a>
<div class="wsy_standard_box" id="userDiv" style="display: none;">
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<c:forEach items="${ulist }" var="ulist">
<tr>
<th width="8%" align="left" valign="baseline" scope="col">${ulist.key.c_name }</th>
<td width="92%" align="left" valign="baseline" scope="col">
<c:forEach items="${ulist.value }" var="v1">
<span>
<input type="radio" name="quesLogs.next_roleName" onclick="sonCheck('${v1.user_id }')" id="nextUserId"
value="${v1.user_id }_${ulist.key.c_id}" />${v1.user_name }
</span>
</c:forEach>
</td>
</tr>
</c:forEach> </table>
</div>
JS:
function queryUsers(){
//展开、隐藏选人DIV
$("#userDiv").fadeToggle("slow");
return false ;
}
//提交表单时验证数据JS
function saveMediaMap() {
//获取单选框的值
var dealUser = $("input[name='quesLogs.next_roleName']:checked").val() ;
if(dealUser==null || dealUser==''){
alert('请选择下一处理人!');
return false;
}
document.getElementById("saveForm").submit();
}
结束语:
以上实现方式可能不是最好的一种,主要是为页面分组展示数据提供了一种方法,另外也对Map,List集合的使用加深练习,记以笔记,以供温故查询。
JSP页面数据展示:分组数据展示的更多相关文章
- jsp页面用struts2标签展示List<Object>类型的数据
今天遇到一个问题,一个List<Object>类型的数据,是直接从sql查出来的数据,要在前端展示,原来的方法不知道为什么不能展示,后来找了好久,找到了一个靠谱的方法,记录一下 <s ...
- jsp页面数据分页模仿百度分页效果
<%@page import="web09.shop.DBUtil"%> <%@page import="java.sql.ResultSet" ...
- jsp页面数据回显(select下拉选择框)
1.静态变量方式: <!-- 实现select标签回显 --> 1.<select name="curStatus" value="${curStatu ...
- ofbiz保存jsp页面数据
1.前台js保存 <script type="text/javascript" src="/ecloud/js/js/jquery.min.js"> ...
- 通用分页jsp页面显示
注:本章内容都是在上一篇文章 通用分页后台显示:https://www.cnblogs.com/ly-0919/p/11058942.html 的基础上进行改进,所以有许多的类都在上一篇, 带来不便 ...
- SpringMVC:前台jsp页面和后台传值
前台jsp页面和后台传值的几种方式: 不用SpringMVC自带的标签 前台---->后台,通过表单传递数据(): 1.jsp页面代码如下, modelattribute 有没有都行 < ...
- jsp页面通过ajax取值/展示数据及分页显示
jsp页面通过ajax从后台获取数据,在页面展示,并实现分页效果代码: [JavaScript部分代码] 1 <script> function getComposition(pageno ...
- JSTL标签+El表达式把list集合数据展示到 JSP页面
JSP页面 <%@ page import="cn.itcast.domain.User" %><%@ page import="java.util.L ...
- MySQL+Service+Servlet+Jsp实现Table表格分页展示数据
下面以一个示例讲解如何使用MySQL+Service+Servlet+Jsp实现Table表格分页展示数据: eg:请假管理系统 要求如下: 一.打开首页页面, 访问查询请假记录的 servlet , ...
随机推荐
- 【转载】Hadoop机架感知
转载自http://www.cnblogs.com/ggjucheng/archive/2013/01/03/2843015.html 背景 分布式的集群通常包含非常多的机器,由于受到机架槽位和交换机 ...
- Windows 10 x64 安装 Visual Basic 6.0 SP6
原文是E文,E文好的可以直接看这里:http://www.fortypoundhead.com/showcontent.asp?artid=23993 原则上Windows 7 x64, Window ...
- 为什么学习Ruby On Rails:
简单总结了一下自己为什么喜欢ruby on rails: 语法简单,写代码很愉快,比较接近伪代码: 喜欢其强大的正则表达式和字符串操作. ruby中面向对象更自由,更动态: ruby给人信任,相信你了 ...
- MSSQL 判断临时表是否存在
方法一: if exists (select * from tempdb.dbo.sysobjects where id = object_id(N'tempdb..#tempcitys') and ...
- 字符串--java中判断字符串是否为数字的方法的几种方法?
ava中判断字符串是否为数字的方法: 1.用JAVA自带的函数 public static boolean isNumeric(String str){ for (int i = 0; i < ...
- a+=b 是什么意思?
a+=b或者-=,*=等等就是相当于a=a+b;简写而已,没什么特殊含义此外还有a++/a--相当于a=a+1/a=a-1
- 关于@Html.Action()的异常“控制器或该控制器未实现 IController。”
解决之前: @Html.Action("BottomHelp", "Articles", new { num = 5}) 解决之后: @Html.Action( ...
- Visual Studio 2015里面汇编工具Asm Dude的配置!
最近开始学习汇编,也开始使用Visual Studio 2015写汇编程序,比较了半天,最后觉得Asm Dude应该是目前Visual Studio 2015非常好的汇编开发插件了,但是如果默认安装上 ...
- Hihocoder 1035 [树形dp]
/* 题意: 不要低头,不要放弃,不要气馁,不要慌张. PS:人生第一道自己独立做出来的树形dp... 给一棵树,标号1到n,每条边有两个权值,步行时间和驾车时间.车在1号点. 给m个必须访问的关键点 ...
- [转] 解决HttpServletResponse输出的中文乱码问题
首先,response返回有两种,一种是字节流outputstream,一种是字符流printwrite. 申明:这里为了方便起见,所有输出都统一用UTF-8编码. 先说字节流,要输出“中国" ...