2020_10_19_113042_create_logistic_timings_table.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  1. <?php
  2. use App\City;
  3. use App\Logistic;
  4. use App\LogisticTiming;
  5. use App\Province;
  6. use Illuminate\Database\Migrations\Migration;
  7. use Illuminate\Database\Schema\Blueprint;
  8. use Illuminate\Support\Facades\Schema;
  9. class CreateLogisticTimingsTable extends Migration
  10. {
  11. /**
  12. * Run the migrations.
  13. *
  14. * @return void
  15. */
  16. public function up()
  17. {
  18. Schema::create('logistic_timings', function (Blueprint $table) {
  19. $table->id();
  20. $table->integer('logistic_id')->index()->comment('承运商');
  21. $table->integer('to_province_id')->index()->comment('目的省');
  22. $table->integer('to_city_id')->index()->nullable()->comment('目的市');
  23. $table->integer('days_at_working')->nullable()->comment('工作日用日');
  24. $table->timestamps();
  25. });
  26. $this->addLogisticTiming();
  27. }
  28. /**
  29. * Reverse the migrations.
  30. *
  31. * @return void
  32. */
  33. public function down()
  34. {
  35. Schema::dropIfExists('logistic_timings');
  36. }
  37. public function addLogisticTiming()
  38. {
  39. $create_array = [];
  40. $map = $this->getMap();
  41. $logistic=Logistic::firstOrCreate(['name'=>'顺丰特惠']);
  42. // $logistic = Logistic::query()->where('name','顺丰特惠')->first();
  43. $time = \Carbon\Carbon::now()->format('Y-m-d H:i:s');
  44. foreach ($map as $item) {
  45. $provinceName = $item[0];
  46. $cityName = $item[1];
  47. $days_at_working = $item[2];
  48. $province = Province::query()->firstOrCreate(['name'=>$provinceName]);
  49. $city = City::query()->where('name',$cityName)->first();
  50. if($city){
  51. $city->province_id = $province->id;
  52. $city->save();
  53. }else{
  54. $city = City::query()->firstOrCreate(['province_id'=>$province->id,'name'=>$cityName] );
  55. }
  56. $logisticTiming = LogisticTiming::query()->where('to_province_id',$province->id)->where('to_city_id',$city->id)->count();
  57. if($logisticTiming>0){continue;}
  58. $create_array[] = [
  59. 'logistic_id' => $logistic->id,
  60. 'to_province_id' => $province->id,
  61. 'to_city_id' => $city->id,
  62. 'days_at_working' => $days_at_working,
  63. 'created_at' => $time,
  64. 'updated_at' => $time
  65. ];
  66. }
  67. $inner_param = array_chunk($create_array,100);
  68. foreach ($inner_param as $item) {
  69. LogisticTiming::query()->insert($item);
  70. }
  71. }
  72. public function getMap()
  73. {
  74. return [['北京','北京','4','5'],
  75. ['广东','广州','4','5'],
  76. ['上海','上海','2','3'],
  77. ['天津','天津','4','5'],
  78. ['重庆','重庆','4','5'],
  79. ['辽宁','沈阳','4','5'],
  80. ['江苏','南京','2','3'],
  81. ['湖北','武汉','4','5'],
  82. ['四川','成都','5','6'],
  83. ['陕西','西安','4','5'],
  84. ['贵州','遵义','5','6'],
  85. ['贵州','安顺','5','6'],
  86. ['云南','泸水','5','6'],
  87. ['云南','丽江','5','6'],
  88. ['河北','邯郸','4','5'],
  89. ['河北','石家庄','4','5'],
  90. ['河北','保定','4','5'],
  91. ['河北','张家口','4','5'],
  92. ['河北','承德','4','5'],
  93. ['河北','唐山','4','5'],
  94. ['河北','廊坊','4','5'],
  95. ['河北','沧州','4','5'],
  96. ['河北','衡水','5','6'],
  97. ['河北','邢台','4','5'],
  98. ['河北','秦皇岛','4','5'],
  99. ['山西','朔州','5','6'],
  100. ['山西','忻州','4','5'],
  101. ['山西','太原','4','5'],
  102. ['山西','大同','4','5'],
  103. ['山西','阳泉','4','5'],
  104. ['山西','晋中','4','5'],
  105. ['山西','长治','4','5'],
  106. ['山西','晋城','4','5'],
  107. ['山西','临汾','5','6'],
  108. ['山西','吕梁','4','5'],
  109. ['山西','运城','4','5'],
  110. ['河南','商丘','3','4'],
  111. ['河南','郑州','4','5'],
  112. ['河南','安阳','4','5'],
  113. ['河南','新乡','4','5'],
  114. ['河南','许昌','4','5'],
  115. ['河南','平顶山','4','5'],
  116. ['河南','信阳','3','4'],
  117. ['河南','南阳','4','5'],
  118. ['河南','开封','4','5'],
  119. ['河南','洛阳','4','5'],
  120. ['河南','焦作','4','5'],
  121. ['河南','鹤壁','4','5'],
  122. ['河南','濮阳','4','5'],
  123. ['河南','周口','3','4'],
  124. ['河南','漯河','4','5'],
  125. ['河南','驻马店','4','5'],
  126. ['河南','三门峡','4','5'],
  127. ['辽宁','大连','4','5'],
  128. ['辽宁','鞍山','5','6'],
  129. ['辽宁','本溪','5','6'],
  130. ['辽宁','丹东','5','6'],
  131. ['辽宁','锦州','4','5'],
  132. ['辽宁','营口','5','6'],
  133. ['辽宁','阜新','6','7'],
  134. ['辽宁','辽阳','4','5'],
  135. ['辽宁','朝阳','5','6'],
  136. ['辽宁','盘锦','5','6'],
  137. ['辽宁','葫芦岛','4','5'],
  138. ['吉林','长春','4','5'],
  139. ['吉林','吉林','5','6'],
  140. ['吉林','延吉','5','6'],
  141. ['吉林','四平','5','6'],
  142. ['吉林','通化','5','6'],
  143. ['吉林','白城','5','6'],
  144. ['吉林','辽源','5','6'],
  145. ['吉林','松原','5','6'],
  146. ['吉林','白山','5','6'],
  147. ['黑龙江','哈尔滨','5','6'],
  148. ['黑龙江','齐齐哈尔','5','6'],
  149. ['黑龙江','牡丹江','5','6'],
  150. ['黑龙江','佳木斯','5','6'],
  151. ['黑龙江','绥化','5','6'],
  152. ['黑龙江','黑河','6','7'],
  153. ['黑龙江','大兴安岭','6','7'],
  154. ['黑龙江','伊春','5','6'],
  155. ['黑龙江','大庆','5','6'],
  156. ['黑龙江','七台河','5','6'],
  157. ['黑龙江','鸡西','6','7'],
  158. ['黑龙江','鹤岗','6','7'],
  159. ['黑龙江','双鸭山','6','7'],
  160. ['内蒙古','呼伦贝尔','6','7'],
  161. ['内蒙古','呼和浩特','5','6'],
  162. ['内蒙古','包头','5','6'],
  163. ['内蒙古','乌海','5','6'],
  164. ['内蒙古','乌兰察布','5','6'],
  165. ['内蒙古','通辽','5','6'],
  166. ['内蒙古','赤峰','4','5'],
  167. ['内蒙古','鄂尔多斯','5','6'],
  168. ['内蒙古','巴彦淖尔','5','6'],
  169. ['内蒙古','锡林浩特','5','6'],
  170. ['内蒙古','乌兰浩特','5','6'],
  171. ['内蒙古','阿拉善','4','5'],
  172. ['江苏','无锡','2','3'],
  173. ['江苏','镇江','2','3'],
  174. ['江苏','苏州','2','3'],
  175. ['江苏','南通','2','3'],
  176. ['江苏','扬州','2','3'],
  177. ['江苏','盐城','2','3'],
  178. ['江苏','徐州','2','3'],
  179. ['江苏','淮安','2','3'],
  180. ['江苏','连云港','2','3'],
  181. ['江苏','常州','2','3'],
  182. ['江苏','泰州','2','3'],
  183. ['江苏','宿迁','2','3'],
  184. ['山东','菏泽','4','5'],
  185. ['山东','济南','4','5'],
  186. ['山东','青岛','3','4'],
  187. ['山东','淄博','4','5'],
  188. ['山东','德州','4','5'],
  189. ['山东','烟台','4','5'],
  190. ['山东','潍坊','4','5'],
  191. ['山东','济宁','3','4'],
  192. ['山东','泰安','3','4'],
  193. ['山东','临沂','3','4'],
  194. ['山东','滨州','4','5'],
  195. ['山东','东营','4','5'],
  196. ['安徽','滁州','3','4'],
  197. ['安徽','合肥','3','4'],
  198. ['安徽','蚌埠','3','4'],
  199. ['安徽','芜湖','3','4'],
  200. ['安徽','淮南','3','4'],
  201. ['安徽','马鞍山','3','4'],
  202. ['安徽','安庆','3','4'],
  203. ['安徽','宿州','3','4'],
  204. ['安徽','阜阳','3','4'],
  205. ['安徽','黄山','3','4'],
  206. ['安徽','淮北','3','4'],
  207. ['安徽','铜陵','3','4'],
  208. ['安徽','宣城','3','4'],
  209. ['安徽','六安','3','4'],
  210. ['安徽','池州','3','4'],
  211. ['浙江','衢州','2','3'],
  212. ['浙江','杭州','2','3'],
  213. ['浙江','湖州','2','3'],
  214. ['浙江','嘉兴','2','3'],
  215. ['浙江','宁波','2','3'],
  216. ['浙江','绍兴','2','3'],
  217. ['浙江','台州','2','3'],
  218. ['浙江','温州','2','3'],
  219. ['浙江','丽水','2','3'],
  220. ['浙江','金华','2','3'],
  221. ['浙江','舟山','2','3'],
  222. ['福建','福州','3','4'],
  223. ['福建','厦门','4','5'],
  224. ['福建','宁德','3','4'],
  225. ['福建','莆田','4','5'],
  226. ['福建','泉州','4','5'],
  227. ['福建','漳州','4','5'],
  228. ['福建','龙岩','4','5'],
  229. ['福建','三明','4','5'],
  230. ['福建','南平','3','4'],
  231. ['山东','威海','4','5'],
  232. ['山东','枣庄','3','4'],
  233. ['山东','日照','3','4'],
  234. ['山东','聊城','4','5'],
  235. ['广东','汕尾','4','5'],
  236. ['广东','阳江','4','5'],
  237. ['广东','揭阳','4','5'],
  238. ['广东','茂名','6','7'],
  239. ['云南','景洪','5','6'],
  240. ['云南','瑞丽','6','7'],
  241. ['江西','鹰潭','3','4'],
  242. ['湖北','襄阳','4','5'],
  243. ['湖北','鄂州','3','4'],
  244. ['湖北','孝感','4','5'],
  245. ['湖北','黄冈','3','4'],
  246. ['湖北','黄石','3','4'],
  247. ['湖北','咸宁','4','5'],
  248. ['湖北','荆州','4','5'],
  249. ['湖北','宜昌','4','5'],
  250. ['湖北','恩施','4','5'],
  251. ['湖北','十堰','4','5'],
  252. ['湖北','随州','4','5'],
  253. ['湖北','荆门','4','5'],
  254. ['湖北','仙桃','4','5'],
  255. ['湖南','岳阳','4','5'],
  256. ['湖南','长沙','4','5'],
  257. ['湖南','湘潭','4','5'],
  258. ['湖南','株洲','4','5'],
  259. ['湖南','衡阳','4','5'],
  260. ['湖南','郴州','4','5'],
  261. ['湖南','常德','4','5'],
  262. ['湖南','益阳','4','5'],
  263. ['湖南','娄底','4','5'],
  264. ['湖南','邵阳','4','5'],
  265. ['湖南','吉首','4','5'],
  266. ['湖南','张家界','4','5'],
  267. ['湖南','怀化','4','5'],
  268. ['湖南','永州','4','5'],
  269. ['广东','江门','4','5'],
  270. ['广东','韶关','4','5'],
  271. ['广东','惠州','4','5'],
  272. ['广东','梅州','5','6'],
  273. ['广东','汕头/汕尾','4','5'],
  274. ['广东','深圳','4','5'],
  275. ['广东','珠海','4','5'],
  276. ['广东','佛山','4','5'],
  277. ['广东','肇庆','4','5'],
  278. ['广东','湛江','5','6'],
  279. ['广东','中山','4','5'],
  280. ['广东','河源','4','5'],
  281. ['广东','清远','4','5'],
  282. ['广东','云浮','4','5'],
  283. ['广东','潮州','4','5'],
  284. ['广东','东莞','4','5'],
  285. ['广西','防城港','5','6'],
  286. ['广西','南宁','5','6'],
  287. ['广西','来宾','5','6'],
  288. ['广西','桂林','5','6'],
  289. ['广西','贺州','5','6'],
  290. ['广西','贵港','5','6'],
  291. ['广西','百色','5','6'],
  292. ['广西','钦州','5','6'],
  293. ['广西','河池','4','5'],
  294. ['广西','北海','5','6'],
  295. ['江西','新余','4','5'],
  296. ['江西','南昌','3','4'],
  297. ['江西','九江','3','4'],
  298. ['江西','上饶','3','4'],
  299. ['江西','抚州','3','4'],
  300. ['江西','宜春','4','5'],
  301. ['江西','吉安','4','5'],
  302. ['江西','赣州','4','5'],
  303. ['江西','景德镇','3','4'],
  304. ['江西','萍乡','4','5'],
  305. ['四川','攀枝花','5','6'],
  306. ['四川','自贡','5','6'],
  307. ['四川','绵阳','5','6'],
  308. ['四川','南充','5','6'],
  309. ['四川','达州','4','5'],
  310. ['四川','遂宁','5','6'],
  311. ['四川','广安','5','6'],
  312. ['四川','巴中','5','6'],
  313. ['四川','泸州','5','6'],
  314. ['四川','宜宾','5','6'],
  315. ['四川','内江','5','6'],
  316. ['四川','乐山','5','6'],
  317. ['四川','西昌','5','6'],
  318. ['四川','雅安','5','6'],
  319. ['四川','康定','4','5'],
  320. ['四川','阿坝藏族羌族州','5','6'],
  321. ['四川','德阳','5','6'],
  322. ['四川','广元','5','6'],
  323. ['贵州','贵阳','4','5'],
  324. ['贵州','都匀','4','5'],
  325. ['贵州','凯里','4','5'],
  326. ['贵州','铜仁','5','6'],
  327. ['贵州','毕节','5','6'],
  328. ['贵州','六盘水','5','6'],
  329. ['贵州','兴义','5','6'],
  330. ['云南','昭通','5','6'],
  331. ['云南','昆明','5','6'],
  332. ['云南','大理','5','6'],
  333. ['云南','红河哈尼族彝族州','5','6'],
  334. ['云南','曲靖','5','6'],
  335. ['云南','保山','5','6'],
  336. ['云南','文山','5','6'],
  337. ['云南','玉溪','5','6'],
  338. ['云南','楚雄','5','6'],
  339. ['云南','普洱','5','6'],
  340. ['云南','临沧','5','6'],
  341. ['云南','香格里拉','5','6'],
  342. ['海南','海口','5','6'],
  343. ['新疆','乌苏','6','7'],
  344. ['新疆','哈密','6','7'],
  345. ['新疆','和田市','6','7'],
  346. ['新疆','阿勒泰市','6','7'],
  347. ['新疆','阿图什市','6','7'],
  348. ['新疆','博尔塔拉蒙古州','6','7'],
  349. ['陕西','延安','4','5'],
  350. ['陕西','榆林','4','5'],
  351. ['陕西','渭南','4','5'],
  352. ['陕西','商洛','4','5'],
  353. ['陕西','安康','4','5'],
  354. ['陕西','汉中','4','5'],
  355. ['陕西','宝鸡','4','5'],
  356. ['陕西','铜川','4','5'],
  357. ['甘肃','临夏','4','5'],
  358. ['甘肃','兰州','5','6'],
  359. ['甘肃','定西','5','6'],
  360. ['甘肃','平凉','5','6'],
  361. ['甘肃','庆阳','4','5'],
  362. ['甘肃','武威','5','6'],
  363. ['甘肃','张掖','5','6'],
  364. ['甘肃','酒泉','5','6'],
  365. ['甘肃','天水','4','5'],
  366. ['甘肃','陇南','5','6'],
  367. ['甘肃','合作','5','6'],
  368. ['甘肃','白银','5','6'],
  369. ['宁夏','银川','5','6'],
  370. ['宁夏','石嘴山','5','6'],
  371. ['宁夏','吴忠','5','6'],
  372. ['宁夏','固原','5','6'],
  373. ['宁夏','中卫','5','6'],
  374. ['青海','海北藏族自治州','5','6'],
  375. ['青海','西宁','5','6'],
  376. ['青海','海东','5','6'],
  377. ['青海','同仁县','5','6'],
  378. ['青海','共和县','5','6'],
  379. ['青海','玛訫县','5','6'],
  380. ['青海','德令哈','5','6'],
  381. ['青海','格尔木','5','6'],
  382. ['新疆','克拉玛依','6','7'],
  383. ['新疆','乌鲁木齐','6','7'],
  384. ['新疆','奎屯','6','7'],
  385. ['新疆','石河子','6','7'],
  386. ['新疆','昌吉州','6','7'],
  387. ['新疆','吐鲁番','6','7'],
  388. ['新疆','库尔勒','6','7'],
  389. ['新疆','阿克苏市','6','7'],
  390. ['新疆','喀什市','6','7'],
  391. ['新疆','伊犁哈萨克州','6','7']];
  392. }
  393. }