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系列的操控盘采用了轻薄的设计,使得用户界面...
以下是常见的C++笔试面试题及其核心知识点解析,帮助您系统复习
计算机短期培训教案.pdf
计算机二级Access笔试题库.pdf
下是一份关于C++毕业答辩的心得总结,内容涵盖技术准备、答辩技巧和注意事项,供参考
内容概要:本文档详细介绍了英特尔为苹果公司构建的基于智能处理单元(IPU)的Cassandra集群的技术验证(PoC)。主要内容涵盖IPU存储用例、已建存储PoC、MEV到MMG400的过渡、苹果构建IPU-Cassandra集群的动机以及PoC开发进展。文档还探讨了硬件配置、软件环境设置、性能调优措施及其成果,特别是针对延迟和吞吐量的优化。此外,文档展示了六节点Cassandra集群的具体架构和测试结果,强调了成本和复杂性的降低。 适合人群:对分布式数据库系统、NoSQL数据库、IPU技术感兴趣的IT专业人员和技术管理人员。 使用场景及目标:适用于希望了解如何利用IPU提升Cassandra集群性能的企业技术人员。主要目标是展示如何通过IPU减少服务器部署的成本和功耗,同时提高数据处理效率。 其他说明:文档中涉及的内容属于机密级别,仅供特定授权人员查阅。文中提到的技术细节和测试结果对于评估IPU在大规模数据中心的应用潜力至关重要。
计算机二级考试C语言题.pdf
计算机发展史.pdf
计算机仿真技术系统的分析方法.pdf
yolo编程相关资源,python编程与YOLO算法组成的坐姿检测系统,功能介绍: 一:实时检测学生错误坐姿人数 二:通过前端阿里云平台显示上传数据,实现数据可视化
办公室网安全监控uptime-kuma,docker镜像离线压缩包
计算机课程设计-网络编程项目源码.zip
将该dll包放入项目并引用,可以操作打印机
杰奇2.3内核淡绿唯美小说网站源码 PC+手机版 自动采集 全站伪静态,送10.1版本关关采集器
计算机辅助教学.pdf
内容概要:本文详细介绍了如何利用天文相机和其他相关硬件设备搭建一套高画质、高帧率的流星监控系统,以及针对红色精灵闪电这一特殊自然现象的捕捉方法。文中不仅涵盖了硬件的选择标准如CMOS靶面尺寸、量子效率等重要参数,还提供了基于Python和OpenCV实现的基本监控代码示例,包括亮度突变检测、运动检测算法等关键技术点。此外,对于安装位置的选择、供电方式、成本控制等方面也有具体的指导建议。 适用人群:对天文摄影感兴趣的爱好者,尤其是希望捕捉流星和红色精灵闪电等瞬时天文现象的专业人士或业余玩家。 使用场景及目标:适用于希望搭建个人天文观测站,用于科学研究或个人兴趣爱好的场景。目标是能够稳定可靠地捕捉到流星和红色精灵闪电等难以捉摸的天文现象,为研究提供高质量的数据资料。 其他说明:文中提到的一些技术和方法虽然较为复杂,但对于有一定编程基础和技术动手能力的人来说是非常实用的参考资料。同时,文中提供的省钱技巧也为预算有限的用户提供了一些有价值的建议。