function create_order_no() { $order_no = date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8).rand(1000,9999); return $order_no;}
function create_order_no() { $order_no = date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT).rand(1000,9999); return $order_no;}
第三个基本不会重复,精确到毫秒,每毫秒还会随机9999。经过这么处理,百分之99.99不会重复。
function create_order_no() { $order_no = date('Ymd').substr(time(), -5) . substr(microtime(), 2, 5) . sprintf('%02d', rand(1000, 9999)); return $order_no;}
测试
function create_order_no() { $order_no = date('Ymd').substr(time(), -5) . substr(microtime(), 2, 5) . sprintf('%02d', rand(1000, 9999)); return $order_no;}$arr = [];for ($i=0;$i<300000;$i++) { $arr[$i] = create_order_no();}print_r(array_unique($arr));
[0] => 2018052442766315014567 ... [299990] => 2018052442766316035660 [299991] => 2018052442766316036736 [299992] => 2018052442766316037720 [299993] => 2018052442766316036546 [299994] => 2018052442766316046898 [299995] => 2018052442766316042222 [299996] => 2018052442766316045190 [299997] => 2018052442766316044156 [299998] => 2018052442766316057563 [299999] => 2018052442766316053670
经测试,一次生成30000个也没有一个重复的。
再来一个简单的,基本不会重复,需要关联用户id
function create_order_no($uid) { $order_no = date('Ym').$uid.substr(time(),3).rand(1000,9999); return $order_no;}
但这个会让订单长度不固定。
基本上第三个就够用了。除非高并发,非常非常严重的时候,才会重复。