专栏首页Java修行之道@ModelAttribute注解的详解

@ModelAttribute注解的详解

@ModelAttribute注解的详解

1.@ModelAttribute定义:

被该注解定义的方法,会在该方法所在的controller的任何目标方法执行之前执行

2.@ModelAttribute使用:

1)应用场景:

当我们需要修改一个user的信息时,我们希望只修改部分属性值,其他属性值保留。

这个时候我们就需要用@ModelAttribute定义一个方法,这个方法在目标方法执行之前执行。

先到数据库查询到需要修改的user,转到目标方法,将表单的数据赋值到这个user中,最后将user作为目标方法的入参传给目标方法处理。

由于我们先从数据库中查询到了user,并将表单中的数据(这些数据只是user实体中的部分属性)赋值给该user,这样我们就达到了我们的需求。

即:当我们需要修改一个user的信息时,我们希望只修改部分属性值,其他属性值保留。

2)代码:

    @ModelAttribute
    public void getUser(@RequestParam(value="id", required=false) Integer id, Map<String, Object> map){
        if(id!=null){
            User user = new User();  //模拟从数据库中取出user
            map.put("user", user);
        }
    }

注意:

1.@RequestParam注释中一定要添加required=false,为什么?我们想一想,被@RequestParam修饰的方法会在所有(有关的、无关的)目标方法执行之前执行,

  如果某个方法的请求没有请求参数id,那么将会抛出异常

2.将查询到的user保存到map中

    @RequestMapping(value="/userOption", method=RequestMethod.PUT)
    public String modifyUser(User user){
        System.out.println(user);
        return "success";
    }

注意:

1.在@ModelAttribute方法结束,目标方法开始之前,springmvc为我们做了一件事:从map中取出user,将表单数据赋值给user,将user传给目标方法的入参

2.这时,目标方法的入参user就是我们修改过后的user(包括修改过的数据和没被修改的数据),之后我们就可以将use保存到数据库了

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • mongodb命令(持续更新)

    1、分组求和 db.collection.aggregate([{$group : {_id : null, sum : {$sum : "$property"...

    用户2409797
  • SpringMVC中controller接收Json数据

    用户2409797
  • idea项目git版本回退

    我这里有两个测试的版本,我的当前版本是【二】,所以我选择【一】,右键,选择Copy Revision Number

    用户2409797
  • Java Web之SpringMVC 进行数据回显

    基本介绍 数据回显:模型数据导向视图(模型数据 ---> Controller ---> 视图) 说明:SpringMVC在调用方法前会创建一个隐含的模型对象...

    YungFan
  • 如何优雅地实现分页查询

    分页功能是很常见的功能,特别是当数据量越来越大的时候,分页查询是必不可少的。实现分页功能有很多种方式,如果使用的ORM框架是mybatis的话,有开源的分页插件...

    黄泽杰
  • 基于jsp+servlet图书管理系统之后台用户信息修改操作

    上一篇的博客写的是查询操作,且附有源码和数据库,这篇博客写的是修改操作,附有从头至尾写的代码(详细的注释)和数据库!  此次修改操作的源码和数据库:http:...

    别先生
  • Yii框架实现对数据库的CURD操作示例

    本文实例讲述了Yii框架实现对数据库的CURD操作。分享给大家供大家参考,具体如下:

    砸漏
  • NodeJS使用mssql连接SQLServer出现"Incorrect syntax near the keyword \'user\'."

    最近使用NodeJS的mssql模块连接SQLServer数据库出现了"Incorrect syntax near the keyword ‘user’."的错...

    ccf19881030
  • Spring Boot入门系列(二十)快速实现Restful API 接口

    随着互联网化等逐渐深入,应用系统也变得越来越复杂,系统架构正在朝着微服务化,中台化的方向发展。这就需要各个系统、各个厂家之间的数据频繁交互。所以,使用 Rest...

    架构师精进
  • 登录缓慢的诡异问题

    最近有套测试库,出现了很诡异的现象,通过PLSQL Developer登录这套数据库(用户名:user_a)的时候异常的慢,几分钟才能连上,从现象来看,可能有很...

    bisal

扫码关注云+社区

领取腾讯云代金券