ecshop地区数据表region中部分地区重复的bug

更新时间:2016-03-04 点击量:626

修复ecshop部分地区重复的问题

1、发现bug

偶然的情况下,发现ecshop在选择地址时,四川id:26->成都id:322—> 都江堰市到新津县(id:2733-2752)这部分区县出现重复的情况。如下图:


blob.png



数据库中找到这部分如图


blob.png



有可能是在使用过程出现的问题,进一步找到ecshop原始的安装源码,发现sql数据的这一段,也是重复的 。

blob.png



2、更多重复信息

现在只发现四川省id:26成都id:322下的区县有重复,还有可能地区也有重复,写了个sql语句查询下:

blob.png

结果:

region_idparent_idregion_nameregion_typeagency_id
62364安定区30
62464安定区30
2733322都江堰市30
2734322彭州市30
2735322邛崃市30
2736322崇州市30
2737322金堂县30
2738322双流县30
2739322郫县30
2740322大邑县30
2741322蒲江县30
2742322新津县30
2743322都江堰市30
2744322彭州市30
2745322邛崃市30
2746322崇州市30
2747322金堂县30
2748322双流县30
2749322郫县30
2750322大邑县30
2751322蒲江县30
2752322新津县30

查询结果显示除了四川省id:26成都id:322下的区县重复,还有一个是 甘肃id:5定西id:64下的 安定区id:623-624


3、bug修复


删除重复的行

// 前缀不是默认的 ecs_ 请自行修改    DELETE FROM `ecs_region` WHERE `region_id` = 624 OR (`region_id` > 2742 AND  `region_id`<2753) LIMIT 11;

修改 ecs_order_info 和ecs_user_address 中的地区信息

// 前缀不是默认的 ecs_ 请自行修改
UPDATE `ecs_order_info` SET district = district - 10 WHERE district > 2742 AND district < 2753;
UPDATE `ecs_user_address` SET district = district - 10 WHERE district > 2742 AND district < 2753;UPDATE `ecs_order_info` SET district = 623 WHERE district =624;
UPDATE `ecs_user_address` SET district = 623 WHERE district=624;

注意: 执行SQL语句前,请注意备份


支付宝扫码打赏 微信打赏

如果文章对您有帮助,就打赏一个吧

在线客服

客户服务

热线电话:

0755-36656507 15889489919 服务时间:

周一到周六:9:00-18:00

在线QQ客服

在线微信客服

关于我们 常见问题

支付方式 加盟合作

提交需求
优惠红包 购物车0 反馈留言 返回顶部