记一次mybatis<if>标签的问题

前言

到底还是没理解清楚的锅~~~~搞了好久。。。啊啊啊啊

错误

There is no getter for property named ‘name‘ in ‘class java.lang.Long‘

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘name‘ in ‘class java.lang.Long‘

xml

dao层

分析

传值的时候,mybatis不知道这个值时传给谁(id、name);索性就把这个id值给了id和name

解决方式

  保持sql不变,在dao层把参数换成map类型:


dao层

这样子,只要后台controller调用(service)方法时,只要params.put("id","xxx");params.put("name","xxx");

这样就分清传谁给谁。

参考文章:https://www.cnblogs.com/gmq-sh/p/5624781.html 写得很不错!

原文地址:https://www.cnblogs.com/yuanmaolin/p/10880760.html

时间: 2024-08-09 18:29:04

记一次mybatis<if>标签的问题的相关文章

记一笔MyBatis的坑

记一笔MyBatis的坑 1.sql查询concat()连接函数xml运行查询乱码 1 select concat(CONVERT(round(count(case when sq.LOANOVERDUE = 'Y' then 1 else null end) / count(1) * 100, 2), char)'%') bll 2 FROM fact_dkxx sq 由于连接的字符串中包含数字与百分比字符串,数据类型不一致,在xml中查询返回内容乱码,因此需要将数字使用CONVERT(num

mybatis resultmap标签type属性什么意思

mybatis resultmap标签type属性什么意思? :就表示被转换的对象啊,被转换成object的类型啊 <resultMap id="BaseResultMap" type="BaseObject"> <id property="id" column="id" /> <result property="appId" column="appid"

mybatis &lt;forEach&gt;标签的使用

MyBatis<forEach>标签的使用 你可以传递一个 List 实例或者数组作为参数对象传给 MyBatis.当你这么做的时候,MyBatis 会自动将它包装在一个 Map 中,用名称作为键.List 实例将会以"list"作为键,而数组实例将会以"array"作为键. foreach元素的属性主要有 item,index,collection,open,separator,close.  item表示集合中每一个元素进行迭代时的别名, index

mybatis include标签

使用mybatis 的include标签达到SQL片段达到代码复用的目的 示例: xml文件 <sql id="paysql"> payid,p.oid,p.bdate,p.lid,lname,p.uid,p.uids,username,p.fdate,p.ysprice,reprice,p.statues,p.flag,clockdate,p.remark,remethod </sql> <!-- 应收款项.未结清,当前用户 --> <sel

mybatis foreach标签

一.批量插入数据 示例:添加订单商品表 1.模型层的相应代码 /** * 添加订单商品表 * @param ordergoods * @return */ public boolean addOrdergood(List<Ordergood> ordergoods){ return session.insert(Ordergood.class.getName()+".addOrdergood", ordergoods)>0; } 2.xml文件 <!--添加订单

MyBatis &lt;if&gt;标签的一些问题

1.常见错误: There is no getter for property named 'parentId' in 'class java.lang.Long'(或者String) org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'paren

mybatis : trim标签, “等于==”经验, CDATA标签 ,模糊查询CONCAT,LIKE

一.My Batis trim标签有点类似于replace效果. trim 属性, prefix:前缀覆盖并增加其内容 suffix:后缀覆盖并增加其内容 prefixOverrides:前缀判断的条件 suffixOverrides:后缀判断的条件 比如:Java SQL语句如下, select b.* from sys_menu b where 1 = 1 <trim suffix="WHERE" suffixOverrides="AND | OR">

mybatis forEach标签item影响其他标签判断的问题

mapper.xml文件中,多个标签中存在属性中使用同名变量,若前边的标签修改了变量的值,则前边的标签可能会影响后边的标签(一般是forEache标签影响后边标签),示例: 1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org

Mybatis 常用标签

MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号.利用动态 SQL 这一特性可以彻底摆脱这种痛苦. 1.<if> 主要用于sql语句拼接(很简单)如示例 2.<choose,when,otherwise> 有些时候,我们不想用到所有的条件语句,而只想从中择其一二.针对这种情况,MyBatis 提供了 choose