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.

目录
相关文章
|
6月前
|
SQL 关系型数据库 MySQL
阿里云RDS云数据库全解析:产品功能、收费标准与活动参考
与云服务器ECS一样,关系型数据库RDS也是很多用户上云必买的热门云产品之一,阿里云的云数据库RDS主要包含RDS MySQL、RDS SQL Server、RDS PostgreSQL、RDS MariaDB等几个关系型数据库,并且提供了容灾、备份、恢复、监控、迁移等方面的全套解决方案,帮助您解决数据库运维的烦恼。本文为大家介绍阿里云的云数据库 RDS主要产品及计费方式、收费标准以及活动等相关情况,以供参考。
|
10月前
|
人工智能 安全 机器人
无代码革命:10分钟打造企业专属数据库查询AI机器人
随着数字化转型加速,企业对高效智能交互解决方案的需求日益增长。阿里云AppFlow推出的AI助手产品,借助创新网页集成技术,助力企业打造专业数据库查询助手。本文详细介绍通过三步流程将AI助手转化为数据库交互工具的核心优势与操作指南,包括全场景适配、智能渲染引擎及零代码配置等三大技术突破。同时提供Web集成与企业微信集成方案,帮助企业实现便捷部署与安全管理,提升内外部用户体验。
942 12
无代码革命:10分钟打造企业专属数据库查询AI机器人
|
Cloud Native 关系型数据库 分布式数据库
|
并行计算 关系型数据库 MySQL
如何用 esProc 将数据库表转储提速查询
当数据库查询因数据量大或繁忙变慢时,可借助 esProc 将数据导出为文件进行计算,大幅提升性能。以 MySQL 的 3000 万行订单数据为例,两个典型查询分别耗时 17.69s 和 63.22s。使用 esProc 转储为二进制行存文件 (btx) 或列存文件 (ctx),结合游标过滤与并行计算,性能显著提升。例如,ctx 并行计算将原查询时间缩短至 0.566s,TopN 运算提速达 30 倍。esProc 的简洁语法和高效文件格式,特别适合历史数据的复杂分析场景。
|
9月前
|
SQL 存储 关系型数据库
MySQL功能模块探秘:数据库世界的奇妙之旅
]带你轻松愉快地探索MySQL 8.4.5的核心功能模块,从SQL引擎到存储引擎,从复制机制到插件系统,让你在欢声笑语中掌握数据库的精髓!
292 26
|
11月前
|
存储 缓存 自然语言处理
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
345 8
评论功能开发全解析:从数据库设计到多语言实现-优雅草卓伊凡
|
SQL Linux 数据库
【YashanDB知识库】崖山数据库Outline功能验证
本文来自YashanDB官网,主要测试了数据库优化器在不同场景下优先使用outline计划的功能。测试环境包括相同版本新增数据、绑定参数执行、单机主备架构以及数据库版本升级等场景。通过创建表、插入数据、收集统计信息和创建outline等步骤,验证了在各种情况下优化器均能优先采用存储的outline计划。测试结果表明,即使统计信息失效或数据库版本升级,outline功能依然稳定有效,确保查询计划的一致性和性能优化。详情可见[原文链接](https://www.yashandb.com/newsinfo/7488286.html?templateId=1718516)。
【YashanDB知识库】崖山数据库Outline功能验证
|
SQL 关系型数据库 MySQL
如何优化SQL查询以提高数据库性能?
这篇文章以生动的比喻介绍了优化SQL查询的重要性及方法。它首先将未优化的SQL查询比作在自助餐厅贪多嚼不烂的行为,强调了只获取必要数据的必要性。接着,文章详细讲解了四种优化策略:**精简选择**(避免使用`SELECT *`)、**专业筛选**(利用`WHERE`缩小范围)、**高效联接**(索引和限制数据量)以及**使用索引**(加速搜索)。此外,还探讨了如何避免N+1查询问题、使用分页限制结果、理解执行计划以及定期维护数据库健康。通过这些技巧,可以显著提升数据库性能,让查询更高效流畅。
|
NoSQL 关系型数据库 MongoDB
Apifox与Apipost数据库连接功能详细对比,让接口管理更高效!
在现代软件开发中,数据库是应用运行的核心组件,接口管理工具则是连接和调试数据库的重要桥梁。本文对比了 Apifox 和 Apipost 两款工具的数据库连接功能。Apipost 支持全面的关系型与非关系型数据库(如 MySQL、Redis、MongoDB),功能强大且免费,适合复杂项目;而 Apifox 在关系型数据库支持上表现良好,但非关系型数据库(尤其是 Redis)功能有限且收费,更适合中小项目以关系型数据库为主的需求。根据项目需求选择合适的工具,可显著提升开发效率和稳定性。