删除另一个模块中正在使用的数据
温馨提示:
本文最后更新于 2024年04月12日,已超过 37 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
我正在努力满足我的项目所需的要求。我需要,如果TipoCorreo(表A)中的数据在Correo(表B)中的数据中使用外键,则Correo中的数据将其外键设置为空。如果您确实想从 TipoCorreo 删除数据,我还需要在前面收到警告。
TipoCorreo控制器
@DeleteMapping("{id}")
public int remove(@PathVariable Long id) {
Optional<TiposCorreos> o = service.findById(id);
Object isUsed = service.isUsed(o.get().getIdTipoCorreo());
if(isUsed != null) {
o.get().setTipoFabrica(1);
}
else if(o.isPresent() && o.get().getTipoFabrica() == 0) {
service.remove(id);
return 0;
}
return o.get().getTipoFabrica();
}
TipoCorreo 存储库
@Query(value = "SELECT * FROM tipos_correos TB LEFT JOIN correos TA ON TB.id_tipo_correo = TA.id_tipo_correo WHERE TA.id_tipo_correo = :idTipo", nativeQuery = true)
Object isUsed(@Param("idTipo") int idTipo);
在控制器中,我尝试验证 DELETE 请求将 int 值传递给前面,其想法是,此时有人尝试删除另一个表中正在使用的数据,也将其数据删除。
正文到此结束
- 本文标签: 家庭宠物
- 本文链接: https://www.coder6.net/article/2140
- 版权声明: 本文由蚂蚁原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权