MyBaits 插入多方数据出错之keyProperty的运用

本文介绍使用MyBatis框架时遇到的外键约束失败问题及其解决方案。通过正确配置keyProperty和useGeneratedKeys属性,确保插入数据时能正确处理自增主键,避免外键冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天用Mybaits插入多方数据时报错如下:

org.apache.ibatis.exceptions.PersistenceException: 

### Error updating database.  Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Cannot add or update a child row: a foreign key constraint fails (`mybatis`.`t_order`, CONSTRAINT `t_order_ibfk_1` FOREIGN KEY (`customer_id`) REFERENCES `t_customer` (`id`))


从上述错误描述中可看出是外键冲突,在看控制台的插入语句:

发现:在插入Order时customer_id 竟然是0,后检查映射器配置文件发现未添加 keyProperty="userId" useGeneratedKeys="true"



在后面添加keyProperty="id" useGeneratedKeys="true"就可以插入成功了。


为什么要添加keyProperty="id" useGeneratedKeys="true"


因为,在默认情况下,insert操作返回的是一个int值,并且不是表示主键id,而是表示当前SQL语句影响的行数

在向数据库插入数据时,需要保留插入数据的主键id,以便进行后续的update操作或者将id存入其他表作为外键。

这时我们就需要将insert插入操作时将返回的主键id绑定到对象中。


<insert id="insertCustomer" parameterType="Customer"  keyProperty="id" useGeneratedKeys="true">

上面配置中,“keyProperty”表示返回的主键id要保存到对象的那个属性也就是名为id的属性中,“useGeneratedKeys”表示主键id为自增长模式。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值