百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql逻辑删除怎样恢复
分享文章到:

mysql逻辑删除怎样恢复

发布时间:08/01 来源:未知 浏览: 关键词:
逻辑删除只是将一个名为status字段进行更改,来达到前端页面可否显示的方式,其数据自身并没有被删除,想要恢复只需要改回status字段即可。 在项目中,个别会碰到这种状况:逻辑删除以及多关联不删除

逻辑删除(软删除):逻辑删除就是对要被删除的数据打上一个删除标志,平常运用一个is_deleted字段标示行记载是不是被删除(或者运用一个status字段代表所谓的“删除”状态),在逻辑上是数据是被删除的,但数据自身是仍然存在的。

举荐课程:MySQL教程。

在前端页面中删除了,也不显示了,其实数据库中并没有删除,只是依据了一个状态字段,0启动,1停用的思绪来达成。

所以逻辑删除就是只是将一个名为status字段进行更改,来达到前端页面可否显示的方式,其数据自身并没有被删除,想要恢复只需要改回status字段即可。

思绪:

在XML中写查询SQL时,多加一个前提,库中的状态字段

SELECT * FROM md_drainage_basin

   and  basin_name LIKE concat('%',#{basinName},'%')
  AND state = #{state}

ORDER BY sort_order

那我们给前端页面时候的数据,就要本人在Java代码中进行默许操纵,由于前端是不会在查询的传一个状态码的,后台本人生成

mdDrainageBasin.setState(0);
List list = mdDrainageBasinMapper.findByQuery(mdDrainageBasin);

默许把状态0启动set到实体类中,再进行查询,这样前端看到的只要状态为0的数据

逻辑删除是把状态码进行更新,更新成1,调取update而不是delete,但考虑到多表关系,例如流域下面挂着水系,逻辑删除一条流域,那下面的水系也要进行逻辑删除不给与显示,这时可依据推断,要是流域下面有响应水系,则不删除,否则删除

MdDrainageBasin mdDrainageBasin = mdDrainageBasinService.findById(id);
List list = mdWaterSystemMapper.findByWater(mdDrainageBasin.getBasinCode());
if (list.size() > 0) {
    return ResponseMsgUtil.failure();
} else {
    mdDrainageBasin.setState(1);
    mdDrainageBasinService.update(mdDrainageBasin);
    return ResponseMsgUtil.success(mdDrainageBasin);
}

依据前端传入的Id进行查询哪一条流域,这条流域下面有多少水系,有水系,不删除,没水系,删除

以上就是mysql逻辑删除怎样恢复的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板