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

后台功能的实现:

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.高级查询+分页查询方法设计
思考用户需要什么数据(返回值的类型)和用户应该要提供什么数据(方法的参数列表的定义)

项目结构划分

Struts2 crud功能实现+高级查询+分页查询_第1张图片

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

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

Struts2 crud功能实现+高级查询+分页查询_第2张图片

先把struts2引入项目中


Struts2
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter


Struts2
/*

  • 首先我们创建一个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模型

Struts2 crud功能实现+高级查询+分页查询_第3张图片

struts.xml






    
        
            /WEB-INF/views/employee/list.jsp
        
        
            emp
        
        
            /WEB-INF/views/employee/input.jsp
        
    


list.jsp


            
            

input.jsp



                    

                    

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

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

      
                      
                          
                              
                          
                          
                              
                          
                          
                              
                          
                          
                              
                          
                          
                              
                          
                          
                              
                          
                          
                              
                          
                          
                              
                                  
                              编辑
                              |
                              
                                  
                          删除
                          
                      
                  
    

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

Struts2 crud功能实现+高级查询+分页查询_第4张图片
  • 删除操作:先获取要删除的数据的id值 通过getter方法拿到对象e并且调用对象属性的setter方法将id值赋值给对象的id属性 再调用delete()方法把id传递进来调用dao的删除方法从数据库删除数据,返回SUCCESS跳转到主见面进行重新发送请求进行更新数据
Struts2 crud功能实现+高级查询+分页查询_第5张图片
第一步

Struts2 crud功能实现+高级查询+分页查询_第6张图片
第二步
Struts2 crud功能实现+高级查询+分页查询_第7张图片
第三步
第四部
第五步
Struts2 crud功能实现+高级查询+分页查询_第8张图片
第六步
第七步
  • 添加操作:当点击注册时会调用input()方法这时id为空返回"input"进入input的罗技视图界面通过struts.xml配置文件进入input.jsp(username为例)这时通过getter方法找到e对象再调用e属性username的setter方法将表格数据赋值;此时e对象的属性就有值了,提交表单后执行saveOrUpdate()方法,此时会调用dao的save()方法把对象保存


    第一步
第二步

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

Struts2 crud功能实现+高级查询+分页查询_第9张图片
第三步
第四步

跳转到input.jsp界面

Struts2 crud功能实现+高级查询+分页查询_第10张图片
第五步

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

Struts2 crud功能实现+高级查询+分页查询_第11张图片
第六步
第七步
Struts2 crud功能实现+高级查询+分页查询_第12张图片
第八步
第九步

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

  • 编辑操作:当点击编辑操作时会获取对象的id,通过getter方法获取对象,再通过对象属性的setter方法将表格的值赋值给对象的属性 然后调用input()方法,因为id有值.再调用dao的update()方法
第一步
第二步
Struts2 crud功能实现+高级查询+分页查询_第13张图片
第三步
Struts2 crud功能实现+高级查询+分页查询_第14张图片
第四部
第五步
Struts2 crud功能实现+高级查询+分页查询_第15张图片
第六步

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

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


    Struts2 crud功能实现+高级查询+分页查询_第16张图片
Struts2 crud功能实现+高级查询+分页查询_第17张图片

查询结果

Struts2 crud功能实现+高级查询+分页查询_第18张图片
查询结果

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

你可能感兴趣的:(Struts2 crud功能实现+高级查询+分页查询)