旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

mysql逻辑删除怎样恢复【MySQL教程】,mysql

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:60评论:0


导读:在项目中,平常会碰到这类状况:逻辑删除以及多关联不删除逻辑删除(软删除):逻辑删除就是对要被删除的数据打上一个删除标记,一般运用一个is_deleted字段标示行纪录是不是...
在项目中,平常会碰到这类状况:逻辑删除以及多关联不删除

逻辑删除(软删除):逻辑删除就是对要被删除的数据打上一个删除标记,一般运用一个is_deleted字段标示行纪录是不是是被删除(或许运用一个status字段代表所谓的“删除”状况),在逻辑上是数据是被删除的,但数据自身是依旧存在的。

引荐课程:MySQL教程。

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

所以逻辑删除就是只是将一个名为status字段举行变动,来到达前端页面是不是显现的体式格局,其数据自身并没有被删除,想要恢复只需要改回status字段即可。

思绪:

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

SELECT * FROM md_drainage_basin
<where>
  <if test="basinName != null"> and  basin_name LIKE concat('%',#{basinName},'%')</if>
  <if test="state != null">AND state = #{state}</if>
</where>
ORDER BY sort_order

那我们给前端页面时刻的数据,就要本身在Java代码中举行默许操纵,由于前端是不会在查询的传一个状况码的,背景本身生成

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

默许把状况0启动set到实体类中,再举行查询,如许前端看到的只要状况为0的数据

逻辑删除是把状况码举行更新,更新成1,挪用update而不是delete,但考虑到多表关联,比方流域下面挂着水系,逻辑删除一条流域,那下面的水系也要举行逻辑删除不授与显现,这时候可依据推断,假如流域下面有响应水系,则不删除,不然删除

MdDrainageBasin mdDrainageBasin = mdDrainageBasinService.findById(id);
List<MdWaterSystem> 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逻辑删除怎样恢复的细致内容,更多请关注ki4网别的相干文章!

标签:mysql


欢迎 发表评论: