einerrr 2021-11-26 08:52 采纳率: 50%
浏览 569
已结题

一个关于前端参数传参很奇怪的问题

前端代码就是一个


  <input type="text" name="userage"/>

Controller层代码

@Controller
@RequestMapping("/user")
public class UsersController {
    @Autowired
    private UsersService usersService;
    @RequestMapping("/addUser")
    public String addUser(Users users){
        this.usersService.addUser(users);
            return "redirect:/ok";
    }


mapper配置文件

    <insert id="addUser" parameterType="Users">
        insert into users values(null,#{username},#{userage});
    </insert>

img


现在我在前端表单里元素是“userage” 就会存到数据库姓名里
填“username” 就会存到年龄里
实在是搞不明白了

  • 写回答

12条回答 默认 最新

  • 大鹏cool Java领域优质创作者 2021-11-26 08:57
    关注

    原因在于表结构中的字段顺序和 mybatis xml 文件中的 sql values 中指定的字段顺序不一致,有两种解决方案。

    1. 修改 SQL 为:insert into users values(null,#{userage},#{username}); 调换了 sql 中 username,userage 的顺序,将 SQL 中的字段顺序和数据库保持一致,因此需要关注数据库表字段的顺序,不太推荐。
    2. 修改 SQL 为:insert into users(userid,username,userage) values(null,#{username},#{userage}); 这种方式将参数自动匹配到手动指定的字段顺序,推荐使用这个。

    如有帮助,请采纳。

    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月4日
  • 创建了问题 11月26日

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘