
每个 company 可对应多个 shop 。 因为每个 company 可存在一个特殊店铺,早期历史代码设计的 shop_id=99 (应该是觉得不会有人会开通超过 99 家店吧),并且不记录在表中。 现在有一个客户的店铺超过了 99 家,导致代码中大量判断 shop_id=99 的逻辑执行异常。
不止后端代码,而且客户端代码中也存在这样的逻辑判断。
1 javalaw2010 1 月 30 日 先把店铺拆分到两个 company 中去,再想办法解决历史遗留问题 |
2 zhengfan2016 1 月 30 日 |
3 bootvue 1 月 30 日 shop_id 如何生成的 baseline 从 100 开启 |
4 liyanggyang 1 月 30 日 @zhengfan2016 我觉得这是最好的办法 |
5 shitcode OP @javalaw2010 变成两个 company 也会影响到业务,现在最低成本的方式确实是二楼的做法 |
6 shitcode OP @zhengfan2016 现在确实考虑这么干 |
7 zhhbstudio 1 月 30 日 @zhengfan2016 这就是天才吗?哈哈哈 还是说以前遇到过 |
8 xiaowoli 1 月 30 日 (应该是觉得不会有人会开通超过 99 家店吧) 你们公司怪励志的啊 |
10 Gilfoyle26 1 月 30 日 为啥一定要从代码的方向来解决呢?超过 99 给他开 2 个账号不就可以了 |
11 ghm2mail 1 月 30 日 shop = -1 ,-2,-3..... |
12 justseemore 1 月 30 日 |
13 justseemore 1 月 30 日 @justseemore #12 就怕不光= 还有>= |
14 javalaw2010 1 月 30 日 @shitcode #5 考虑到如果有代码逻辑是 if(shop_id >= 99) 就危险了。 |
15 montaro2017 1 月 30 日 |
16 dcdlove 1 月 30 日 shop 表的 种子升级到四位数 1000 ,然后历史所有 shop_id 加两个 00 |
17 shitcode OP @javalaw2010 这个确实是没有,都是判断 99 的,但是也说不好真存在在哪个角落 |
18 meteora0tkvo 1 月 30 日 本来应该加多一个字段去标识判断是否是特殊店铺,而后端偷懒搞一个特殊 id 去判断 |
19 leecqan 1 月 30 日 其实我没看懂,为啥会有异常,有大佬解释一下么 |
20 noahjsn 1 月 30 日 @meteora0tkvo 《论屎山代码的形成》《论后期偿还技术债的痛苦》 |
21 konakona 1 月 30 日 |
22 unused 1 月 30 日 特殊店铺 ID 为什么不用 0 或者 1 呢 |
23 YTNET PRO 所有的 99 改成 999 呢 把这个问题留个下一个人 |
24 ragnaroks 1 月 30 日 我靠,我也曾经遇到过这种问题,也是类商城系统,也是 99 是特殊值。是不是有哪个培训班的老师喜欢用 99 当特殊值啊,明明 Int32.MaxValue 或者 -1 之类的更合理 |
25 irockytan 1 月 31 日 via iPhone @xiaowoli 我 15 年干那家公司,也是电商,接手的代码里面订单号的逻辑是按月加上一个 6 位数字,也是递增,后面业务量起来,一个月超过 100 万订单,于是大量订单号重复 |
26 gongym 1 月 31 日 via Android @leecqan 店铺 id 是自增的,特殊店铺 id 是 99 ,特殊店铺有特殊逻辑,但是有一个公司创建了超过 99 家店,导致 id 为 99 的是正常店占了特殊店铺的 id ,特殊逻辑就有问题了(执行特殊逻辑的判断就是 id=99 ) |
28 skallz 1 月 31 日 这种特殊逻辑蛮多的,包括 2099 年或者 3000 年被视为永久一样,只是一般我们写这种逻辑不敢把数字写的特别小,哈哈 |
29 syboy 2 月 1 日 via Android @zhengfan2016 很显然他这个已经把 9 当成普通店铺了 |