mybatis+mysql下批量插入一些问题,在这里记录一下,如下错误信息:
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter '__frch_item_0' not found. Available parameters are [list]
前来说一下我遇到这个错误的两种情况:
要说明情况下,前说一下项目上是怎么使用的.我们一般都在 DAO 里定义一个接口方法,然后在对应的接口 mapper.xml文件中实现相应的 SQL 功能.然后在 services的实现类注入 DAO 再使用.
第一种情况:
在 DAO 中定义了一个批量插入的方法:
int delBatchPasswor(List<String> pwdl);
在 mapper.xml 中的实现:
<delete id="delBatchPasswor" parameterType="java.util.List">
delete from t_gateway_password where gateway_password in
<foreach collection="list" item="item" open="(" separator="," close=")">
#{item.gatewayPassword,jdbcType=VARCHAR}
</foreach>
</delete>
上面红色"item.gatewayPassword"写法是错误滴,有时候我们写着写着就就与混还以为传入的是一个对象,当我们定义传入的 List 集合中是 String,Integer等时mapper.xml 中的实现:
<delete id="delBatchPasswor" parameterType="java.util.List"> delete from t_gateway_password where gateway_password in <foreach collection="list" item="item" open="(" separator="," close=")"> #{item,jdbcType=VARCHAR} </foreach> </delete>
第二种情况:
我们在 DAO 中定义方法
int batchInsert(List<GatewayBusinessAh> list);
这里传入的对象是自定义的实体对象,一般是通过表自动生成,再看看在 mapper.xml 中的实现:
INSERT INTO t_gateway_business_ah ( id, gateway_uuid, business_code, business_code_boss, business_name, parameter_list, business_status, area_code, bandwidth, create_time, business_type, gateway_password, adsl_password, adsl_account, order_no, update_time, fail_count ) VALUES <foreach collection="list" index="index" item="item" separator=","> ( #{item.id,jdbcType=VARCHAR}, #{item.gatewayUuid,jdbcType=VARCHAR}, #{item.businessCode,jdbcType=VARCHAR}, #{item.businessCodeBoss,jdbcType=VARCHAR}, #{item.businessName,jdbcType=VARCHAR}, #{item.parameterList,jdbcType=VARCHAR}, #{item.businessStatus,jdbcType=VARCHAR}, #{item.areaCode,jdbcType=VARCHAR}, #{item.bandwidth,jdbcType=INTEGER}, #{item.createTime,jdbcType=INTEGER}, #{item.businessType,jdbcType=VARCHAR}, #{item.gatewayPassword,jdbcType=VARCHAR}, #{item.adslPassword,jdbcType=VARCHAR}, #{item.adslAccount,jdbcType=VARCHAR}, #{item.orderNo,jdbcType=VARCHAR}, #{item.updateTime,jdbcType=INTEGER}, #{item.failCount,jdbcType=INTEGER} ) </foreach> </insert>
上面的错我找了很久都没有找到问题,我找问题步骤如下:
(1)查看parameterType的类型是不是java.util.List类型,如果是的话,看foreach 的collection属性是不是list.
(2)看一下foreach里面的"属性"是否写错或有没有传递进来,这里说一下"属性"好比上面"orderNo"是你实体对象中无此属性,我在网上看到有的说是"值"为空,感觉有些歧义.
上面排出错误的步骤都试了,可是还是没有找出问题.最后我对应表查看了字段:
字段中并没有"businessName"属性,因为是开发环境,所以这些问题是坑,不知道什么时候被删除了.
所以我们还要对应看foreach里面的"属性"是否表中字段对应得上.
相关推荐
然而,当你遇到“_frch_item_0 not found”这样的错误时,通常是由于在使用`<foreach>`时出现了配置或编码上的问题。下面我们将深入探讨这个问题及其解决方法。 首先,我们要理解这个错误通常表示MyBatis在尝试访问...
mybatis批量添加的时候报错总结报错 parameter'_frch_item_0 not found
PageHelper插件就是为了解决这一问题而设计的,它不仅实现了简单的物理分页,还支持动态SQL,使得在查询过程中可以根据不同的条件灵活调整分页策略。 标题中提到的“支持条件查询”是指PageHelper能够与Mybatis的...
充电器的重量减轻至210 kg,厚度仅为480 mm,相比之前的FRCH系列(700 kg,700 mm)实现了显著的减重和瘦身,有利于设备的安装和空间节省。 2. 操控盘功能与设计 FRCM系列的操控盘采用了轻薄的设计,使得用户界面...
ta_lib-0.5.1-cp312-cp312-win32.whl
课程设计 在线实时的斗兽棋游戏,时间赶,粗暴的使用jQuery + websoket 实现实时H5对战游戏 + java.zip课程设计
ta_lib-0.5.1-cp310-cp310-win_amd64.whl
基于springboot+vue物流系统源码数据库文档.zip
GEE训练教程——Landsat5、8和Sentinel-2、DEM和各2哦想指数下载
知识图谱
333498005787635解决keil下载失败的文件.zip
【微信机器人原理与实现】 微信机器人是通过模拟微信客户端的行为,自动处理消息、发送消息的程序。在Python中实现微信机器人的主要库是WeChatBot,它提供了丰富的接口,允许开发者方便地进行微信消息的接收与发送。这个项目标题中的"基于python实现的微信机器人源码"指的是使用Python编程语言编写的微信机器人程序。 1. **Python基础**:Python是一种高级编程语言,以其简洁的语法和强大的功能深受开发者喜爱。在实现微信机器人时,你需要熟悉Python的基本语法、数据类型、函数、类以及异常处理等概念。 2. **微信API与WeChatBot库**:微信为开发者提供了微信公共平台和微信开放平台,可以获取到必要的API来实现机器人功能。WeChatBot库是Python中一个用于微信开发的第三方库,它封装了微信的API,简化了消息处理的流程。使用WeChatBot,开发者可以快速搭建起一个微信机器人。 3. **微信OAuth2.0授权**:为了能够接入微信,首先需要通过OAuth2.0协议获取用户的授权。用户授权后,机器人可以获取到微信用户的身份信息,从而进行
基于springboot实验室研究生信息管理系统源码数据库文档.zip
张力控制,色标跟踪,多轴同步,电子凸轮,横切等工艺控制案例。
在Python编程环境中,处理Microsoft Word文档是一项常见的任务。Python提供了几个库来实现这一目标,如`python-docx`,它可以让我们创建、修改和操作.docx文件。本教程将重点介绍如何利用Python进行Word文档的合并、格式转换以及转换为PDF。 1. **合并Word文档(merge4docx)** 合并多个Word文档是一项实用的功能,特别是在处理大量报告或文档集合时。在Python中,可以使用`python-docx`库实现。我们需要导入`docx`模块,然后读取每个文档并将其内容插入到主文档中。以下是一个基本示例: ```python from docx import Document def merge4docx(file_list, output_file): main_doc = Document() for file in file_list: doc = Document(file) for paragraph in doc.paragraphs: main_doc.add_paragraph(paragraph.text) m
基于springboot+Javaweb的二手图书交易系统源码数据库文档.zip
基于springboot餐品美食论坛源码数据库文档.zip
基于springboot亚运会志愿者管理系统源码数据库文档.zip
使用WPF的数据样式绑定,切换对象数据值来完成控件动态切换背景渐变动画效果。 使用动画样式渲染比线程修改性能消耗更低更稳定
基于SpringBoot的企业客源关系管理系统源码数据库文档.zip