订单号的生成,看你如何考虑了。
简单的方式: orderId就是一个唯一识别,如果没有特别的含义。那么就是自增生成就行。至于说被猜到,那就看对业务的影响。是否允许任何人根据orderId查询订单,通过业务来判断。
复杂的方式: 由于系统订单数据越来越多,那么最终你需要做数据库的分布式存储。这样的话,订单号就可以有很多的含义在里面了。 例如:(如果使用关系数据库存储)分布式后,数据分表分库,那么通过订单号能找到订单的准确位置,这就很重要了。单纯的自增可能就不是很好的方案了。因此可以这样考虑: orderId=[yyyyMMDDhhmmss][商户id后4位][自增序列6位]
如果主要是通过商户分区,那么就能根据商户的id信息来找到数据的位置。如果数据越来越多,大量的历史数据需要迁移,例如3个月前的所有订单可以放到备份库中,那么就可以根据时间来定位数据的位置,因此联合起来就能知道orderId能在哪里查到数据
uuid 不适合做单号,建议把时间打上去,交易类型最好也有,有一段是用来做随机的,分布式一定要一台单独的服务保证唯一性。你可以使用一些数据库的特性保证唯一。比如redis的incry生成一个base。