事务所做的操作如下:
// 获取到自动生成的 id,假设为 1
insert into country (name)
values ('China');
// province.country_id 引用 country.id
insert into province (name, country_id)
values ('Guangdong', 1);
在执行insert into province (name, country_id) values ('Guangdong', 1);
时,代码出现java.sql.SQLIntegrityConstraintViolationException: Cannot add or update a child row: a foreign key constraint fails
异常。请问怎么解决这个问题呢?
🤐是我自己搞错了,执行完insert into province (name, country_id) values ('Guangdong', 1);
之后,我并没有获取到正确的id,相当于获取到了一个不存在的country的id,导致insert into province (name, country_id) values ('Guangdong', 1);
出现外键约束异常。
1
yeqizhang 2021-03-24 11:05:49 +08:00
额....你数据库添加外键约束的话,我觉得你得分开两个事务提交... 业务代码上进行关联就用一个事务....
|
2
yeqizhang 2021-03-24 11:17:33 +08:00
我以上的看法有问题,请忽略....是我技术不精
|