Struts2 crud功能实现+高级查询+分页查询

简介: 后台功能的实现:1.创建员工表:t_employee2.根据表结构创建实体类:Employee3.定义DAO接口:IEmployeeDAO4.定义DAO的实现类:EmployeeDAOImpl(暂不实现, 测试先行)5.

后台功能的实现:

1.创建员工表:t_employee
2.根据表结构创建实体类:Employee
3.定义DAO接口:IEmployeeDAO
4.定义DAO的实现类:EmployeeDAOImpl(暂不实现, 测试先行)
5.定义对应的测试类:EmployeeDAOTest(编写对每个dao方法的测试代码)
6:使用druid连接池抽取JdbcUtil和db.properties文件.
7:编写通用的DAO操作模板JdbcTemplate.
8:编写通用的结果集处理器:BeanHander/BeanListHandler.

前台功能的实现:

01.集成Struts2框架
02.编写EmployeeAction代码和JSP代码
03.网页基本的CRUD测试通过
04.完成高级查询操作(前台)
05.完成分页查询操作(前台)

高级查询+分页查询

1.查询对象的封装(EmployeeQueryObject,QueryObject)
该对象是用户提交的数据的封装,将高级查询和分页数据都封装到该对象中,方便数据的传递
在该对象中提供sql条件字符串的拼接,和sql参数的存放
2.分页结果对象的封装(PageResult)
该对象是对页面中需要显示数据的封装(结果集数据和分页条相关的数据)
3.高级查询+分页查询方法设计
思考用户需要什么数据(返回值的类型)和用户应该要提供什么数据(方法的参数列表的定义)

项目结构划分

img_d85cf8a291432b8d1d7bf95511619432.png

DAO暂时不进行叙述了我们把重点放在Struts2上

我们想对下面表格使用struts2进行CRUD+高级查询+分页查询

img_ece16ad70559b4ea24f13b8c66187ec6.png

先把struts2引入项目中

<filter>
<filter-name>Struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
  • 首先我们创建一个Action类

    public class EmployeeAction extends ActionSupport {
    private static final long serialVersionUID = 1L;
    private IEmployeeDAO dao = new EmployeeDAOImp();
    @Setter@Getter
    private Employee e;
    @Setter@Getter
    private EmployeeQueryObject qo =new EmployeeQueryObject();
     @Override
     public String execute() throws Exception {
     PageResult result = dao.pageQuery(qo);
     ActionContext.getContext().put("result", result);
    //跳转逻辑视图
     return "list";
     }
     //执行用户的删除操作
     public String delete(){
     dao.delete(e.getId());
     return SUCCESS;
     }
     //编辑页面的跳转操作
     public String input(){
     if(e!=null){
         e=dao.get(e.getId());
     }
     return "input";
     }
    //执行保存更新操作
     public String saveOrUpdate(){
     if(e.getId()!=null){
         dao.update(e);
     }else{
         dao.save(e);
     }
     return SUCCESS;
     }
     }
    

domain模型

img_5558b77ddf7944fa18965621659c8ed5.png

struts.xml

<struts>
<!--开发者模式 -->
<constant name="struts.devMode" value="true"></constant>
<constant name="struts.ui.theme" value="simple" />
<package name="empPkg" extends="struts-default" namespace="/">
    <action name="emp_*" class="com.jd.pss.web.action.EmployeeAction"
        method="{1}">
        <result name="list" type="dispatcher">
            /WEB-INF/views/employee/list.jsp
        </result>
        <result name="success" type="redirectAction">
            emp
        </result>
        <result name="input">
            /WEB-INF/views/employee/input.jsp
        </result>
    </action>
</package>
</struts>

list.jsp

<s:form class="form-inline" role="form">
            <s:hidden name="qo.currentPage" id="currentPage"></s:hidden>
            <div class="form-group">
                <label class="sr-only" for="exampleInputEmail2"></label>
                <s:textfield name="qo.username" class="form-control"
                    id="exampleInputEmail2" placeholder="姓名" />
            </div>
            <div class="form-group">
                <label class="sr-only" for="exampleInputEmail2"></label>
                <s:textfield name="qo.email" class="form-control"
                    id="exampleInputEmail2" placeholder="邮箱" />
            </div>

input.jsp

<s:form id="account_register" name="account_register" namespace="/"
                    action="emp_saveOrUpdate" class="form-horizontal">

                    <s:hidden name="e.id"></s:hidden>

                    <div class="form-group">
                        <label for="account_register_account_username"
                            class="col-sm-2 control-label">用户名</label>
                        <div class="col-sm-4">
                            <s:textfield name="e.username"
                                id="account_register_account_username" class="form-control"
                                placeholder="请输入用户名" />
                        </div>
                        <div class="col-sm-6"></div>
                    </div>
                    <div class="form-group">
                        <label for="account.password" class="col-sm-2 control-label">密码</label>
                        <div class="col-sm-4">
                            <s:password name="e.password" showPassword="true"
                                id="account_register_account_password" class="form-control"
                                placeholder="请输入密码" />
                        </div>

我们需要理解的是以下逻辑:

  • http://localhost:8080/emp发送请求时获取查询数据存储在值栈中,跳转到逻辑视图 在list.jsp中通过迭代获取所有数据显示到界面上

      <s:iterator value="#result.listData" var="emp">
                      <tr>
                          <td>
                              <s:property value="#emp.id" />
                          </td>
                          <td>
                              <s:property value="#emp.headImg" />
                          </td>
                          <td>
                              <s:property value="#emp.username" />
                          </td>
                          <td>
                              <s:property value="#emp.password" />
                          </td>
                          <td>
                              <s:property value="#emp.email" />
                          </td>
                          <td>
                              <s:date format="yyyy-MM-dd" name="#emp.hiredate" />
                          </td>
                          <td>
                              <s:property value="#emp.salary" />
                          </td>
                          <td>
                              <s:a namespace="/" action="emp_input">
                                  <s:param name="e.id" value="#emp.id"></s:param>
                              编辑</s:a>
                              |
                              <s:a namespace="/" action="emp_delete">
                                  <s:param name="e.id" value="#emp.id"></s:param>
                          删除</s:a>
                          </td>
                      </tr>
                  </s:iterator>
    

这就是我们需要现实的界面前提是DAO的crud正常

img_ece16ad70559b4ea24f13b8c66187ec6.png
  • 删除操作:先获取要删除的数据的id值 通过getter方法拿到对象e并且调用对象属性的setter方法将id值赋值给对象的id属性 再调用delete()方法把id传递进来调用dao的删除方法从数据库删除数据,返回SUCCESS跳转到主见面进行重新发送请求进行更新数据
img_b7104f0de22999744c835f1cec7dcbe2.png
第一步

img_a7bef80a4c2b2ed8c1242238d3166f8c.png
第二步
img_63b09c2f737011787aa4f4e26f5f9a4b.png
第三步
img_d5ea33759eb2294ffea513c87be7342e.png
第四部
img_467b05b4ae6530baa21c892c1370958c.png
第五步
img_d3a7e10fe2cc47a13ab9295eb9cdc79f.png
第六步
img_ff6188ebbb9e2620f5d53e05a58b7dd3.png
第七步
  • 添加操作:当点击注册时会调用input()方法这时id为空返回"input"进入input的罗技视图界面通过struts.xml配置文件进入input.jsp(username为例)这时通过getter方法找到e对象再调用e属性username的setter方法将表格数据赋值;此时e对象的属性就有值了,提交表单后执行saveOrUpdate()方法,此时会调用dao的save()方法把对象保存


    img_53934cbf7af8cf2fb7b3a02d1e9bb90d.png
    第一步
img_1f951aea34cb690795527b0de5ba9b86.png
第二步

到action类中找到对应的input()方法

img_08e5d7ecf6361b990b5fef8ed5cef729.png
第三步
img_321198bb50db6a64fcb18e6c0fc721fe.png
第四步

跳转到input.jsp界面

img_53731d90bf839ada3e02ec58fafc61bb.png
第五步

e.id做了那些事?这是我们必须要知道的
提交表单会操作action

img_4e72f620dba444a45c391e8c7bede2b1.png
第六步
img_e06122a5f4105b2291da97fa80664c04.png
第七步
img_5d875a9db601de0a82e1c1d992c6c617.png
第八步
img_865b477628bedb2bf31477dc82fda24f.png
第九步

更新数据请求转发跳转到list.jsp界面

  • 编辑操作:当点击编辑操作时会获取对象的id,通过getter方法获取对象,再通过对象属性的setter方法将表格的值赋值给对象的属性 然后调用input()方法,因为id有值.再调用dao的update()方法
img_9a3f54e803ae6a204c598bc2479ca259.png
第一步
img_77da1b14e75f7c53c21971f3403d7792.png
第二步
img_5b1b960ba76e0122ad44bc198242e2f2.png
第三步
img_e6d25bd4eccc8cd8ffc5a10b90243f98.png
第四部
img_355dd4158842f3e39a27938c6aa705c6.png
第五步
img_39b4f68e5a32957215ded97dd516f922.png
第六步

最后更新数据请求转发跳转到list.jsp界面

img_36d25b2601182cb085a6871ab183247c.png
第七步
  • 高级查询:查询请求发送时会调用getter方法拿到qo对象,再将请求的值通过setter方法赋值给qo对象的属性.封装成对象
    同时在表单中设置一个隐藏域currentPage属性,提交表单跳转到当前界面执行execute()方法, 通过dao.pageQuery(qo); 获取结果集,将结果集保存到值栈中,跳转到"list"的逻辑视图


    img_e5a47e72c73fb97d3611d65d7de22745.png
img_3bcaea74239951d41fafb2ff7a0149b6.png

查询结果

img_175be990d330d7045fff8fcf69cb5d52.png
查询结果

常见的type值(结果类型):
dispatcher: 表示从Action请求转发到页面(JSP).缺省值
redirect: 表示从Action重定向到页面(JSP).
chain: 表示从Action请求转发到另一个Action.
redirectAction: 表示从Action重定向到另一个Action.

目录
相关文章
|
22天前
|
SQL 数据库 微服务
微服务03,最简单的Demo,我们每个服务不能重复开发相同业务,微服务数据独立,不要访问其他微服务的数据库,微服务的特点之一是提供不能功能的数据库互相分割,微服务需要根据业务模块拆分,做到单一职责,
微服务03,最简单的Demo,我们每个服务不能重复开发相同业务,微服务数据独立,不要访问其他微服务的数据库,微服务的特点之一是提供不能功能的数据库互相分割,微服务需要根据业务模块拆分,做到单一职责,
|
1月前
|
存储 数据库
Union All:数据库查询的得力助手
Union All:数据库查询的得力助手
|
5天前
|
存储 缓存 监控
优化数据库查询的关键
【7月更文挑战第22天】优化数据库查询的关键
18 7
|
8天前
|
分布式计算 大数据 关系型数据库
MaxCompute产品使用合集之如何实现类似mysql实例中的数据库功能
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
18天前
|
SQL 数据库 Python
Django框架数据库ORM查询操作(6)
【7月更文挑战第6天】```markdown Django ORM常用数据库操作:1) 查询所有数据2) 根据ID查询 3) 精确查询 4) 分页排序
25 1
|
22天前
|
SQL 自然语言处理 网络协议
【Linux开发实战指南】基于TCP、进程数据结构与SQL数据库:构建在线云词典系统(含注册、登录、查询、历史记录管理功能及源码分享)
TCP(Transmission Control Protocol)连接是互联网上最常用的一种面向连接、可靠的、基于字节流的传输层通信协议。建立TCP连接需要经过著名的“三次握手”过程: 1. SYN(同步序列编号):客户端发送一个SYN包给服务器,并进入SYN_SEND状态,等待服务器确认。 2. SYN-ACK:服务器收到SYN包后,回应一个SYN-ACK(SYN+ACKnowledgment)包,告诉客户端其接收到了请求,并同意建立连接,此时服务器进入SYN_RECV状态。 3. ACK(确认字符):客户端收到服务器的SYN-ACK包后,发送一个ACK包给服务器,确认收到了服务器的确
147 1
|
25天前
|
存储 缓存 关系型数据库
如何优化数据库查询?
【7月更文挑战第2天】如何优化数据库查询?
20 1
|
26天前
|
SQL 关系型数据库 MySQL
MySQL数据库—DQL查询语句(一篇教会你快速找到想要的数据)
MySQL数据库—DQL查询语句(一篇教会你快速找到想要的数据)
|
28天前
|
存储 NoSQL MongoDB
mongdb如何查询数据库表的创建时间
【6月更文挑战第29天】mongdb如何查询数据库表的创建时间
24 2
|
20天前
|
SQL 存储 数据库
MSSQL数据库性能调优实战:索引、查询与并发控制的深度剖析
在数据库管理领域,Microsoft SQL Server(MSSQL)的性能调优是保障业务高效运行的核心任务