Browse Source

初始化

15954078560 2 years ago
commit
a009d48959
100 changed files with 18160 additions and 0 deletions
  1. 11 0
      .bowerrc
  2. 11 0
      .env.sample
  3. 17 0
      .gitignore
  4. 191 0
      LICENSE
  5. 97 0
      README.md
  6. 1 0
      addons/.gitkeep
  7. 1 0
      addons/.htaccess
  8. 1 0
      addons/command/.addonrc
  9. 69 0
      addons/command/Command.php
  10. 4 0
      addons/command/config.php
  11. 15 0
      addons/command/controller/Index.php
  12. 10 0
      addons/command/info.ini
  13. 12 0
      addons/command/install.sql
  14. 28 0
      addons/command/library/Output.php
  15. 0 0
      addons/example/.addonrc
  16. 183 0
      addons/example/Example.php
  17. 12 0
      addons/example/bootstrap.js
  18. 70 0
      addons/example/config.php
  19. 32 0
      addons/example/controller/Demo.php
  20. 17 0
      addons/example/controller/Index.php
  21. 10 0
      addons/example/info.ini
  22. 3795 0
      addons/example/install.sql
  23. 33 0
      addons/example/view/demo/demo1.html
  24. 31 0
      addons/example/view/demo/demo2.html
  25. 67 0
      addons/example/view/demo/index.html
  26. 236 0
      addons/example/view/index/index.html
  27. 124 0
      addons/example/view/layout/default.html
  28. 0 0
      addons/umeditor/.addonrc
  29. 40 0
      addons/umeditor/Umeditor.php
  30. 131 0
      addons/umeditor/bootstrap.js
  31. 16 0
      addons/umeditor/config.php
  32. 10 0
      addons/umeditor/info.ini
  33. 1 0
      application/.htaccess
  34. 14 0
      application/admin/behavior/AdminLog.php
  35. 344 0
      application/admin/command/Addon.php
  36. 54 0
      application/admin/command/Addon/stubs/addon.stub
  37. 44 0
      application/admin/command/Addon/stubs/config.stub
  38. 15 0
      application/admin/command/Addon/stubs/controller.stub
  39. 7 0
      application/admin/command/Addon/stubs/info.stub
  40. 195 0
      application/admin/command/Api.php
  41. 25 0
      application/admin/command/Api/lang/zh-cn.php
  42. 253 0
      application/admin/command/Api/library/Builder.php
  43. 544 0
      application/admin/command/Api/library/Extractor.php
  44. 654 0
      application/admin/command/Api/template/index.html
  45. 1770 0
      application/admin/command/Crud.php
  46. 11 0
      application/admin/command/Crud/stubs/add.stub
  47. 37 0
      application/admin/command/Crud/stubs/controller.stub
  48. 34 0
      application/admin/command/Crud/stubs/controllerindex.stub
  49. 11 0
      application/admin/command/Crud/stubs/edit.stub
  50. 6 0
      application/admin/command/Crud/stubs/html/checkbox.stub
  51. 20 0
      application/admin/command/Crud/stubs/html/fieldlist-template.stub
  52. 10 0
      application/admin/command/Crud/stubs/html/fieldlist.stub
  53. 10 0
      application/admin/command/Crud/stubs/html/heading-html.stub
  54. 6 0
      application/admin/command/Crud/stubs/html/radio.stub
  55. 1 0
      application/admin/command/Crud/stubs/html/recyclebin-html.stub
  56. 6 0
      application/admin/command/Crud/stubs/html/select.stub
  57. 5 0
      application/admin/command/Crud/stubs/html/switch.stub
  58. 35 0
      application/admin/command/Crud/stubs/index.stub
  59. 48 0
      application/admin/command/Crud/stubs/javascript.stub
  60. 5 0
      application/admin/command/Crud/stubs/lang.stub
  61. 8 0
      application/admin/command/Crud/stubs/mixins/checkbox.stub
  62. 6 0
      application/admin/command/Crud/stubs/mixins/datetime.stub
  63. 1 0
      application/admin/command/Crud/stubs/mixins/enum.stub
  64. 4 0
      application/admin/command/Crud/stubs/mixins/import.stub
  65. 8 0
      application/admin/command/Crud/stubs/mixins/modelinit.stub
  66. 5 0
      application/admin/command/Crud/stubs/mixins/modelrelationmethod-hasmany.stub
  67. 5 0
      application/admin/command/Crud/stubs/mixins/modelrelationmethod.stub
  68. 8 0
      application/admin/command/Crud/stubs/mixins/multiple.stub
  69. 7 0
      application/admin/command/Crud/stubs/mixins/radio.stub
  70. 60 0
      application/admin/command/Crud/stubs/mixins/recyclebinjs.stub
  71. 7 0
      application/admin/command/Crud/stubs/mixins/select.stub
  72. 40 0
      application/admin/command/Crud/stubs/model.stub
  73. 25 0
      application/admin/command/Crud/stubs/recyclebin.stub
  74. 12 0
      application/admin/command/Crud/stubs/relationmodel.stub
  75. 27 0
      application/admin/command/Crud/stubs/validate.stub
  76. 319 0
      application/admin/command/Install.php
  77. 604 0
      application/admin/command/Install/fastadmin.sql
  78. 316 0
      application/admin/command/Install/install.html
  79. 35 0
      application/admin/command/Install/zh-cn.php
  80. 327 0
      application/admin/command/Menu.php
  81. 162 0
      application/admin/command/Min.php
  82. 4699 0
      application/admin/command/Min/r.js
  83. 6 0
      application/admin/command/Min/stubs/css.stub
  84. 11 0
      application/admin/command/Min/stubs/js.stub
  85. 196 0
      application/admin/common.php
  86. 8 0
      application/admin/config.php
  87. 453 0
      application/admin/controller/Addon.php
  88. 313 0
      application/admin/controller/Ajax.php
  89. 158 0
      application/admin/controller/Category.php
  90. 236 0
      application/admin/controller/Command.php
  91. 71 0
      application/admin/controller/Company.php
  92. 37 0
      application/admin/controller/Companytype.php
  93. 84 0
      application/admin/controller/Dashboard.php
  94. 138 0
      application/admin/controller/Index.php
  95. 71 0
      application/admin/controller/Industry.php
  96. 37 0
      application/admin/controller/Industrytype.php
  97. 71 0
      application/admin/controller/News.php
  98. 37 0
      application/admin/controller/Newstype.php
  99. 71 0
      application/admin/controller/Product.php
  100. 37 0
      application/admin/controller/Productmod.php

+ 11 - 0
.bowerrc

@@ -0,0 +1,11 @@
+{
+  "directory": "public/assets/libs",
+  "ignoredDependencies": [
+    "es6-promise",
+    "file-saver",
+    "html2canvas",
+    "jspdf",
+    "jspdf-autotable",
+    "pdfmake"
+  ]
+}

+ 11 - 0
.env.sample

@@ -0,0 +1,11 @@
+[app]
+debug = false
+trace = false
+
+[database]
+hostname = 127.0.0.1
+database = fastadmin
+username = root
+password = root
+hostport = 3306
+prefix = fa_

+ 17 - 0
.gitignore

@@ -0,0 +1,17 @@
+/nbproject/
+/runtime/*
+/application/admin/command/Install/*.lock
+/public/uploads/*
+.idea
+composer.lock
+*.log
+*.css.map
+!.gitkeep
+.env
+.svn
+.vscode
+node_modules
+public/download/
+/application/database.php
+/public/.htaccess
+/public/nginx.htaccess

+ 191 - 0
LICENSE

@@ -0,0 +1,191 @@
+Apache License
+Version 2.0, January 2004
+http://www.apache.org/licenses/
+
+TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+1. Definitions.
+
+"License" shall mean the terms and conditions for use, reproduction, and
+distribution as defined by Sections 1 through 9 of this document.
+
+"Licensor" shall mean the copyright owner or entity authorized by the copyright
+owner that is granting the License.
+
+"Legal Entity" shall mean the union of the acting entity and all other entities
+that control, are controlled by, or are under common control with that entity.
+For the purposes of this definition, "control" means (i) the power, direct or
+indirect, to cause the direction or management of such entity, whether by
+contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the
+outstanding shares, or (iii) beneficial ownership of such entity.
+
+"You" (or "Your") shall mean an individual or Legal Entity exercising
+permissions granted by this License.
+
+"Source" form shall mean the preferred form for making modifications, including
+but not limited to software source code, documentation source, and configuration
+files.
+
+"Object" form shall mean any form resulting from mechanical transformation or
+translation of a Source form, including but not limited to compiled object code,
+generated documentation, and conversions to other media types.
+
+"Work" shall mean the work of authorship, whether in Source or Object form, made
+available under the License, as indicated by a copyright notice that is included
+in or attached to the work (an example is provided in the Appendix below).
+
+"Derivative Works" shall mean any work, whether in Source or Object form, that
+is based on (or derived from) the Work and for which the editorial revisions,
+annotations, elaborations, or other modifications represent, as a whole, an
+original work of authorship. For the purposes of this License, Derivative Works
+shall not include works that remain separable from, or merely link (or bind by
+name) to the interfaces of, the Work and Derivative Works thereof.
+
+"Contribution" shall mean any work of authorship, including the original version
+of the Work and any modifications or additions to that Work or Derivative Works
+thereof, that is intentionally submitted to Licensor for inclusion in the Work
+by the copyright owner or by an individual or Legal Entity authorized to submit
+on behalf of the copyright owner. For the purposes of this definition,
+"submitted" means any form of electronic, verbal, or written communication sent
+to the Licensor or its representatives, including but not limited to
+communication on electronic mailing lists, source code control systems, and
+issue tracking systems that are managed by, or on behalf of, the Licensor for
+the purpose of discussing and improving the Work, but excluding communication
+that is conspicuously marked or otherwise designated in writing by the copyright
+owner as "Not a Contribution."
+
+"Contributor" shall mean Licensor and any individual or Legal Entity on behalf
+of whom a Contribution has been received by Licensor and subsequently
+incorporated within the Work.
+
+2. Grant of Copyright License.
+
+Subject to the terms and conditions of this License, each Contributor hereby
+grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
+irrevocable copyright license to reproduce, prepare Derivative Works of,
+publicly display, publicly perform, sublicense, and distribute the Work and such
+Derivative Works in Source or Object form.
+
+3. Grant of Patent License.
+
+Subject to the terms and conditions of this License, each Contributor hereby
+grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
+irrevocable (except as stated in this section) patent license to make, have
+made, use, offer to sell, sell, import, and otherwise transfer the Work, where
+such license applies only to those patent claims licensable by such Contributor
+that are necessarily infringed by their Contribution(s) alone or by combination
+of their Contribution(s) with the Work to which such Contribution(s) was
+submitted. If You institute patent litigation against any entity (including a
+cross-claim or counterclaim in a lawsuit) alleging that the Work or a
+Contribution incorporated within the Work constitutes direct or contributory
+patent infringement, then any patent licenses granted to You under this License
+for that Work shall terminate as of the date such litigation is filed.
+
+4. Redistribution.
+
+You may reproduce and distribute copies of the Work or Derivative Works thereof
+in any medium, with or without modifications, and in Source or Object form,
+provided that You meet the following conditions:
+
+You must give any other recipients of the Work or Derivative Works a copy of
+this License; and
+You must cause any modified files to carry prominent notices stating that You
+changed the files; and
+You must retain, in the Source form of any Derivative Works that You distribute,
+all copyright, patent, trademark, and attribution notices from the Source form
+of the Work, excluding those notices that do not pertain to any part of the
+Derivative Works; and
+If the Work includes a "NOTICE" text file as part of its distribution, then any
+Derivative Works that You distribute must include a readable copy of the
+attribution notices contained within such NOTICE file, excluding those notices
+that do not pertain to any part of the Derivative Works, in at least one of the
+following places: within a NOTICE text file distributed as part of the
+Derivative Works; within the Source form or documentation, if provided along
+with the Derivative Works; or, within a display generated by the Derivative
+Works, if and wherever such third-party notices normally appear. The contents of
+the NOTICE file are for informational purposes only and do not modify the
+License. You may add Your own attribution notices within Derivative Works that
+You distribute, alongside or as an addendum to the NOTICE text from the Work,
+provided that such additional attribution notices cannot be construed as
+modifying the License.
+You may add Your own copyright statement to Your modifications and may provide
+additional or different license terms and conditions for use, reproduction, or
+distribution of Your modifications, or for any such Derivative Works as a whole,
+provided Your use, reproduction, and distribution of the Work otherwise complies
+with the conditions stated in this License.
+
+5. Submission of Contributions.
+
+Unless You explicitly state otherwise, any Contribution intentionally submitted
+for inclusion in the Work by You to the Licensor shall be under the terms and
+conditions of this License, without any additional terms or conditions.
+Notwithstanding the above, nothing herein shall supersede or modify the terms of
+any separate license agreement you may have executed with Licensor regarding
+such Contributions.
+
+6. Trademarks.
+
+This License does not grant permission to use the trade names, trademarks,
+service marks, or product names of the Licensor, except as required for
+reasonable and customary use in describing the origin of the Work and
+reproducing the content of the NOTICE file.
+
+7. Disclaimer of Warranty.
+
+Unless required by applicable law or agreed to in writing, Licensor provides the
+Work (and each Contributor provides its Contributions) on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied,
+including, without limitation, any warranties or conditions of TITLE,
+NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are
+solely responsible for determining the appropriateness of using or
+redistributing the Work and assume any risks associated with Your exercise of
+permissions under this License.
+
+8. Limitation of Liability.
+
+In no event and under no legal theory, whether in tort (including negligence),
+contract, or otherwise, unless required by applicable law (such as deliberate
+and grossly negligent acts) or agreed to in writing, shall any Contributor be
+liable to You for damages, including any direct, indirect, special, incidental,
+or consequential damages of any character arising as a result of this License or
+out of the use or inability to use the Work (including but not limited to
+damages for loss of goodwill, work stoppage, computer failure or malfunction, or
+any and all other commercial damages or losses), even if such Contributor has
+been advised of the possibility of such damages.
+
+9. Accepting Warranty or Additional Liability.
+
+While redistributing the Work or Derivative Works thereof, You may choose to
+offer, and charge a fee for, acceptance of support, warranty, indemnity, or
+other liability obligations and/or rights consistent with this License. However,
+in accepting such obligations, You may act only on Your own behalf and on Your
+sole responsibility, not on behalf of any other Contributor, and only if You
+agree to indemnify, defend, and hold each Contributor harmless for any liability
+incurred by, or claims asserted against, such Contributor by reason of your
+accepting any such warranty or additional liability.
+
+END OF TERMS AND CONDITIONS
+
+APPENDIX: How to apply the Apache License to your work
+
+To apply the Apache License to your work, attach the following boilerplate
+notice, with the fields enclosed by brackets "{}" replaced with your own
+identifying information. (Don't include the brackets!) The text should be
+enclosed in the appropriate comment syntax for the file format. We also
+recommend that a file or class name and description of purpose be included on
+the same "printed page" as the copyright notice for easier identification within
+third-party archives.
+
+   Copyright 2017 Karson
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+     http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software
+   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   See the License for the specific language governing permissions and
+   limitations under the License.

+ 97 - 0
README.md

@@ -0,0 +1,97 @@
+FastAdmin是一款基于ThinkPHP+Bootstrap的极速后台开发框架。
+
+
+## 主要特性
+
+* 基于`Auth`验证的权限管理系统
+    * 支持无限级父子级权限继承,父级的管理员可任意增删改子级管理员及权限设置
+    * 支持单管理员多角色
+    * 支持管理子级数据或个人数据
+* 强大的一键生成功能
+    * 一键生成CRUD,包括控制器、模型、视图、JS、语言包、菜单、回收站等
+    * 一键压缩打包JS和CSS文件,一键CDN静态资源部署
+    * 一键生成控制器菜单和规则
+    * 一键生成API接口文档
+* 完善的前端功能组件开发
+    * 基于`AdminLTE`二次开发
+    * 基于`Bootstrap`开发,自适应手机、平板、PC
+    * 基于`RequireJS`进行JS模块管理,按需加载
+    * 基于`Less`进行样式开发
+* 强大的插件扩展功能,在线安装卸载升级插件
+* 通用的会员模块和API模块
+* 共用同一账号体系的Web端会员中心权限验证和API接口会员权限验证
+* 二级域名部署支持,同时域名支持绑定到应用插件
+* 多语言支持,服务端及客户端支持
+* 支持大文件分片上传、剪切板粘贴上传、拖拽上传,进度条显示,图片上传前压缩
+* 支持表格固定列、固定表头、跨页选择、Excel导出、模板渲染等功能
+* 强大的第三方应用模块支持([CMS](https://www.fastadmin.net/store/cms.html)、[博客](https://www.fastadmin.net/store/blog.html)、[知识付费问答](https://www.fastadmin.net/store/ask.html)、[在线投票系统](https://www.fastadmin.net/store/vote.html)、[B2C商城](https://www.fastadmin.net/store/shopro.html)、[B2B2C商城](https://www.fastadmin.net/store/wanlshop.html))
+* 支持CMS、博客、知识付费问答无缝整合[Xunsearch全文搜索](https://www.fastadmin.net/store/xunsearch.html)
+* 第三方小程序支持([CMS小程序](https://www.fastadmin.net/store/cms.html)、[预订小程序](https://www.fastadmin.net/store/ball.html)、[问答小程序](https://www.fastadmin.net/store/ask.html)、[点餐小程序](https://www.fastadmin.net/store/unidrink.html)、[B2C小程序](https://www.fastadmin.net/store/shopro.html)、[B2B2C小程序](https://www.fastadmin.net/store/wanlshop.html)、[博客小程序](https://www.fastadmin.net/store/blog.html))
+* 整合第三方短信接口(阿里云、腾讯云短信)
+* 无缝整合第三方云存储(七牛云、阿里云OSS、又拍云)功能,支持云储存分片上传
+* 第三方富文本编辑器支持(Summernote、Kindeditor、百度编辑器)
+* 第三方登录(QQ、微信、微博)整合
+* 第三方支付(微信、支付宝)无缝整合,微信支持PC端扫码支付
+* 丰富的插件应用市场
+
+## 安装使用
+
+https://doc.fastadmin.net
+
+## 在线演示
+
+https://demo.fastadmin.net
+
+用户名:admin
+
+密 码:123456
+
+提 示:演示站数据无法进行修改,请下载源码安装体验全部功能
+
+## 界面截图
+![控制台](https://images.gitee.com/uploads/images/2020/0929/202947_8db2d281_10933.gif "控制台")
+
+## 问题反馈
+
+在使用中有任何问题,请使用以下联系方式联系我们
+
+交流社区: https://ask.fastadmin.net
+
+QQ群: [636393962](https://jq.qq.com/?_wv=1027&k=487PNBb)(满) [708784003](https://jq.qq.com/?_wv=1027&k=5ObjtwM)(满) [964776039](https://jq.qq.com/?_wv=1027&k=59qjU2P)(3群) [749803490](https://jq.qq.com/?_wv=1027&k=5tczi88)(满) [767103006](https://jq.qq.com/?_wv=1027&k=5Z1U751)(满) [675115483](https://jq.qq.com/?_wv=1027&k=54I6mts)(6群)
+
+Github: https://github.com/karsonzhang/fastadmin
+
+Gitee: https://gitee.com/karson/fastadmin
+
+## 特别鸣谢
+
+感谢以下的项目,排名不分先后
+
+ThinkPHP:http://www.thinkphp.cn
+
+AdminLTE:https://adminlte.io
+
+Bootstrap:http://getbootstrap.com
+
+jQuery:http://jquery.com
+
+Bootstrap-table:https://github.com/wenzhixin/bootstrap-table
+
+Nice-validator: https://validator.niceue.com
+
+SelectPage: https://github.com/TerryZ/SelectPage
+
+Layer: https://layer.layui.com
+
+DropzoneJS: https://www.dropzonejs.com
+
+
+## 版权信息
+
+FastAdmin遵循Apache2开源协议发布,并提供免费使用。
+
+本项目包含的第三方源码和二进制文件之版权信息另行标注。
+
+版权所有Copyright © 2017-2022 by FastAdmin (https://www.fastadmin.net)
+
+All rights reserved。

+ 1 - 0
addons/.gitkeep

@@ -0,0 +1 @@
+

+ 1 - 0
addons/.htaccess

@@ -0,0 +1 @@
+deny from all

+ 1 - 0
addons/command/.addonrc

@@ -0,0 +1 @@
+{"files":["application\\admin\\controller\\Command.php","application\\admin\\lang\\zh-cn\\command.php","application\\admin\\model\\Command.php","application\\admin\\validate\\Command.php","application\\admin\\view\\command\\add.html","application\\admin\\view\\command\\detail.html","application\\admin\\view\\command\\index.html","public\\assets\\js\\backend\\command.js"],"license":"regular","licenseto":"55688","licensekey":"GivmorK3gh7bAtOC d+dLWoE0kivGdjRu6z9h5g==","domains":["shengzhu.com"],"licensecodes":[],"validations":["23ef55dc6af365d0cc9c6283e3000449"],"menus":["command","command\/index","command\/add","command\/detail","command\/execute","command\/del","command\/multi"]}

+ 69 - 0
addons/command/Command.php

@@ -0,0 +1,69 @@
+<?php
+
+namespace addons\command;
+
+use app\common\library\Menu;
+use think\Addons;
+
+/**
+ * 在线命令插件
+ */
+class Command extends Addons
+{
+
+    /**
+     * 插件安装方法
+     * @return bool
+     */
+    public function install()
+    {
+        $menu = [
+            [
+                'name'    => 'command',
+                'title'   => '在线命令管理',
+                'icon'    => 'fa fa-terminal',
+                'sublist' => [
+                    ['name' => 'command/index', 'title' => '查看'],
+                    ['name' => 'command/add', 'title' => '添加'],
+                    ['name' => 'command/detail', 'title' => '详情'],
+                    ['name' => 'command/execute', 'title' => '运行'],
+                    ['name' => 'command/del', 'title' => '删除'],
+                    ['name' => 'command/multi', 'title' => '批量更新'],
+                ]
+            ]
+        ];
+        Menu::create($menu);
+        return true;
+    }
+
+    /**
+     * 插件卸载方法
+     * @return bool
+     */
+    public function uninstall()
+    {
+        Menu::delete('command');
+        return true;
+    }
+
+    /**
+     * 插件启用方法
+     * @return bool
+     */
+    public function enable()
+    {
+        Menu::enable('command');
+        return true;
+    }
+
+    /**
+     * 插件禁用方法
+     * @return bool
+     */
+    public function disable()
+    {
+        Menu::disable('command');
+        return true;
+    }
+
+}

+ 4 - 0
addons/command/config.php

@@ -0,0 +1,4 @@
+<?php
+
+return [
+];

+ 15 - 0
addons/command/controller/Index.php

@@ -0,0 +1,15 @@
+<?php
+
+namespace addons\command\controller;
+
+use think\addons\Controller;
+
+class Index extends Controller
+{
+
+    public function index()
+    {
+        $this->error("当前插件暂无前台页面");
+    }
+
+}

+ 10 - 0
addons/command/info.ini

@@ -0,0 +1,10 @@
+name = command
+title = 在线命令
+intro = 可在线执行FastAdmin的命令行相关命令
+author = Karson
+website = https://www.fastadmin.net
+version = 1.0.6
+state = 1
+url = /addons/command
+license = regular
+licenseto = 55688

+ 12 - 0
addons/command/install.sql

@@ -0,0 +1,12 @@
+CREATE TABLE IF NOT EXISTS `__PREFIX__command`  (
+  `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `type` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '类型',
+  `params` varchar(1500) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '参数',
+  `command` varchar(1500) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '命令',
+  `content` text COMMENT '返回结果',
+  `executetime` int(10) UNSIGNED DEFAULT NULL COMMENT '执行时间',
+  `createtime` int(10) UNSIGNED DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) UNSIGNED DEFAULT NULL COMMENT '更新时间',
+  `status` enum('successed','failured') CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT 'failured' COMMENT '状态',
+  PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '在线命令表';

+ 28 - 0
addons/command/library/Output.php

@@ -0,0 +1,28 @@
+<?php
+
+namespace addons\command\library;
+
+/**
+ * Class Output
+ */
+class Output extends \think\console\Output
+{
+
+    protected $message = [];
+
+    public function __construct($driver = 'console')
+    {
+        parent::__construct($driver);
+    }
+
+    protected function block($style, $message)
+    {
+        $this->message[] = $message;
+    }
+
+    public function getMessage()
+    {
+        return $this->message;
+    }
+
+}

File diff suppressed because it is too large
+ 0 - 0
addons/example/.addonrc


+ 183 - 0
addons/example/Example.php

@@ -0,0 +1,183 @@
+<?php
+
+namespace addons\example;
+
+use app\common\library\Menu;
+use think\Addons;
+
+/**
+ * Example
+ */
+class Example extends Addons
+{
+
+    /**
+     * 插件安装方法
+     * @return bool
+     */
+    public function install()
+    {
+        $menu = [
+            [
+                'name'    => 'example',
+                'title'   => '开发示例管理',
+                'icon'    => 'fa fa-magic',
+                'sublist' => [
+                    [
+                        'name'    => 'example/bootstraptable',
+                        'title'   => '表格完整示例',
+                        'icon'    => 'fa fa-table',
+                        'sublist' => [
+                            ['name' => 'example/bootstraptable/index', 'title' => '查看'],
+                            ['name' => 'example/bootstraptable/detail', 'title' => '详情'],
+                            ['name' => 'example/bootstraptable/change', 'title' => '变更'],
+                            ['name' => 'example/bootstraptable/del', 'title' => '删除'],
+                            ['name' => 'example/bootstraptable/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/customsearch',
+                        'title'   => '自定义搜索',
+                        'icon'    => 'fa fa-table',
+                        'sublist' => [
+                            ['name' => 'example/customsearch/index', 'title' => '查看'],
+                            ['name' => 'example/customsearch/del', 'title' => '删除'],
+                            ['name' => 'example/customsearch/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/customform',
+                        'title'   => '自定义表单示例',
+                        'icon'    => 'fa fa-edit',
+                        'sublist' => [
+                            ['name' => 'example/customform/index', 'title' => '查看'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/tablelink',
+                        'title'   => '表格联动示例',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '点击左侧日志列表,右侧的表格数据会显示指定管理员的日志列表',
+                        'sublist' => [
+                            ['name' => 'example/tablelink/index', 'title' => '查看'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/colorbadge',
+                        'title'   => '彩色角标',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '左侧彩色的角标会根据当前数据量的大小进行更新',
+                        'sublist' => [
+                            ['name' => 'example/colorbadge/index', 'title' => '查看'],
+                            ['name' => 'example/colorbadge/del', 'title' => '删除'],
+                            ['name' => 'example/colorbadge/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/controllerjump',
+                        'title'   => '控制器间跳转',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '点击IP地址可以跳转到新的选项卡中查看指定IP的数据',
+                        'sublist' => [
+                            ['name' => 'example/controllerjump/index', 'title' => '查看'],
+                            ['name' => 'example/controllerjump/del', 'title' => '删除'],
+                            ['name' => 'example/controllerjump/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/cxselect',
+                        'title'   => '多级联动',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '基于jquery.cxselect实现的多级联动',
+                        'sublist' => [
+                            ['name' => 'example/cxselect/index', 'title' => '查看'],
+                            ['name' => 'example/cxselect/del', 'title' => '删除'],
+                            ['name' => 'example/cxselect/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/multitable',
+                        'title'   => '多表格示例',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '展示在一个页面显示多个Bootstrap-table表格',
+                        'sublist' => [
+                            ['name' => 'example/multitable/index', 'title' => '查看'],
+                            ['name' => 'example/multitable/del', 'title' => '删除'],
+                            ['name' => 'example/multitable/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/relationmodel',
+                        'title'   => '关联模型示例',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '列表中的头像、用户名和昵称字段均从关联表中取出',
+                        'sublist' => [
+                            ['name' => 'example/relationmodel/index', 'title' => '查看'],
+                            ['name' => 'example/relationmodel/del', 'title' => '删除'],
+                            ['name' => 'example/relationmodel/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/tabletemplate',
+                        'title'   => '表格模板示例',
+                        'icon'    => 'fa fa-table',
+                        'remark'  => '',
+                        'sublist' => [
+                            ['name' => 'example/tabletemplate/index', 'title' => '查看'],
+                            ['name' => 'example/tabletemplate/detail', 'title' => '详情'],
+                            ['name' => 'example/tabletemplate/del', 'title' => '删除'],
+                            ['name' => 'example/tabletemplate/multi', 'title' => '批量更新'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/baidumap',
+                        'title'   => '百度地图示例',
+                        'icon'    => 'fa fa-map-pin',
+                        'sublist' => [
+                            ['name' => 'example/baidumap/index', 'title' => '查看'],
+                            ['name' => 'example/baidumap/map', 'title' => '详情'],
+                            ['name' => 'example/baidumap/del', 'title' => '删除'],
+                        ]
+                    ],
+                    [
+                        'name'    => 'example/echarts',
+                        'title'   => '统计图表示例',
+                        'icon'    => 'fa fa-bar-chart',
+                        'sublist' => [
+                            ['name' => 'example/echarts/index', 'title' => '查看'],
+                        ]
+                    ],
+                ]
+            ]
+        ];
+        Menu::create($menu);
+        return true;
+    }
+
+    /**
+     * 插件卸载方法
+     * @return bool
+     */
+    public function uninstall()
+    {
+        Menu::delete('example');
+        return true;
+    }
+
+    /**
+     * 插件启用方法
+     */
+    public function enable()
+    {
+        Menu::enable('example');
+    }
+
+    /**
+     * 插件禁用方法
+     */
+    public function disable()
+    {
+        Menu::disable('example');
+    }
+
+}

+ 12 - 0
addons/example/bootstrap.js

@@ -0,0 +1,12 @@
+require.config({
+    paths: {
+        'async': '../addons/example/js/async',
+        'BMap': ['//api.map.baidu.com/api?v=2.0&ak=mXijumfojHnAaN2VxpBGoqHM'],
+    },
+    shim: {
+        'BMap': {
+            deps: ['jquery'],
+            exports: 'BMap'
+        }
+    }
+});

+ 70 - 0
addons/example/config.php

@@ -0,0 +1,70 @@
+<?php
+
+return [
+    [
+        'name'    => 'title',
+        'title'   => '标题',
+        'type'    => 'string',
+        'content' => [
+        ],
+        'value'   => '示例标题',
+        'rule'    => 'required',
+        'msg'     => '',
+        'tip'     => '',
+        'ok'      => '',
+        'extend'  => ''
+    ],
+    [
+        //配置唯一标识
+        'name'    => 'theme',
+        //显示的标题
+        'title'   => '皮肤',
+        //类型
+        'type'    => 'string',
+        //数据字典
+        'content' => [
+        ],
+        //值
+        'value'   => 'default',
+        //验证规则 
+        'rule'    => 'required',
+        //错误消息
+        'msg'     => '',
+        //提示消息
+        'tip'     => '',
+        //成功消息
+        'ok'      => '',
+        //扩展信息
+        'extend'  => ''
+    ],
+    [
+        'name'    => 'domain',
+        'title'   => '绑定二级域名前缀',
+        'type'    => 'string',
+        'content' => [
+        ],
+        'value'   => '',
+        'rule'    => '',
+        'msg'     => '',
+        'tip'     => '',
+        'ok'      => '',
+        'extend'  => ''
+    ],
+    [
+        'name'    => 'rewrite',
+        'title'   => '伪静态',
+        'type'    => 'array',
+        'content' => [],
+        'value'   => [
+            'index/index' => '/example$',
+            'demo/index'  => '/example/d/[:name]',
+            'demo/demo1'  => '/example/d1/[:name]',
+            'demo/demo2'  => '/example/d2/[:name]',
+        ],
+        'rule'    => 'required',
+        'msg'     => '',
+        'tip'     => '',
+        'ok'      => '',
+        'extend'  => ''
+    ],
+];

+ 32 - 0
addons/example/controller/Demo.php

@@ -0,0 +1,32 @@
+<?php
+
+namespace addons\example\controller;
+
+use think\addons\Controller;
+
+/**
+ * 测试控制器
+ */
+class Demo extends Controller
+{
+
+    protected $layout = 'default';
+    protected $noNeedLogin = ['index', 'demo1'];
+    protected $noNeedRight = ['*'];
+
+    public function index()
+    {
+        return $this->view->fetch();
+    }
+
+    public function demo1()
+    {
+        return $this->view->fetch();
+    }
+
+    public function demo2()
+    {
+        return $this->view->fetch();
+    }
+
+}

+ 17 - 0
addons/example/controller/Index.php

@@ -0,0 +1,17 @@
+<?php
+
+namespace addons\example\controller;
+
+use think\addons\Controller;
+
+class Index extends Controller
+{
+
+    protected $layout = 'default';
+
+    public function index()
+    {
+        return $this->view->fetch();
+    }
+
+}

+ 10 - 0
addons/example/info.ini

@@ -0,0 +1,10 @@
+name = example
+title = 开发示例
+intro = FastAdmin多个开发示例
+author = FastAdmin
+website = https://www.fastadmin.net
+version = 1.1.0
+state = 1
+url = /addons/example
+license = regular
+licenseto = 55688

+ 3795 - 0
addons/example/install.sql

@@ -0,0 +1,3795 @@
+CREATE TABLE IF NOT EXISTS `__PREFIX__area` (
+  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `pid` int(10) DEFAULT NULL COMMENT '父id',
+  `shortname` varchar(100) DEFAULT NULL COMMENT '简称',
+  `name` varchar(100) DEFAULT NULL COMMENT '名称',
+  `mergename` varchar(255) DEFAULT NULL COMMENT '全称',
+  `level` tinyint(4) DEFAULT NULL COMMENT '层级 0 1 2 省市区县',
+  `pinyin` varchar(100) DEFAULT NULL COMMENT '拼音',
+  `code` varchar(100) DEFAULT NULL COMMENT '长途区号',
+  `zip` varchar(100) DEFAULT NULL COMMENT '邮编',
+  `first` varchar(50) DEFAULT NULL COMMENT '首字母',
+  `lng` varchar(100) DEFAULT NULL COMMENT '经度',
+  `lat` varchar(100) DEFAULT NULL COMMENT '纬度',
+  PRIMARY KEY (`id`),
+  KEY `pid` (`pid`)
+) ENGINE=InnoDB AUTO_INCREMENT=3750 DEFAULT CHARSET=utf8 COMMENT='地区表';
+
+BEGIN;
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(1, 0, '北京', '北京', '中国,北京', 1, 'beijing', '', '', 'B', '116.405285', '39.904989'),
+(2, 1, '北京', '北京市', '中国,北京,北京市', 2, 'beijing', '010', '100000', 'B', '116.405285', '39.904989'),
+(3, 2, '东城', '东城区', '中国,北京,北京市,东城区', 3, 'dongcheng', '010', '100010', 'D', '116.41005', '39.93157'),
+(4, 2, '西城', '西城区', '中国,北京,北京市,西城区', 3, 'xicheng', '010', '100032', 'X', '116.36003', '39.9305'),
+(5, 2, '朝阳', '朝阳区', '中国,北京,北京市,朝阳区', 3, 'chaoyang', '010', '100020', 'C', '116.48548', '39.9484'),
+(6, 2, '丰台', '丰台区', '中国,北京,北京市,丰台区', 3, 'fengtai', '010', '100071', 'F', '116.28625', '39.8585'),
+(7, 2, '石景山', '石景山区', '中国,北京,北京市,石景山区', 3, 'shijingshan', '010', '100043', 'S', '116.2229', '39.90564'),
+(8, 2, '海淀', '海淀区', '中国,北京,北京市,海淀区', 3, 'haidian', '010', '100089', 'H', '116.29812', '39.95931'),
+(9, 2, '门头沟', '门头沟区', '中国,北京,北京市,门头沟区', 3, 'mentougou', '010', '102300', 'M', '116.10137', '39.94043'),
+(10, 2, '房山', '房山区', '中国,北京,北京市,房山区', 3, 'fangshan', '010', '102488', 'F', '116.14257', '39.74786'),
+(11, 2, '通州', '通州区', '中国,北京,北京市,通州区', 3, 'tongzhou', '010', '101149', 'T', '116.65716', '39.90966'),
+(12, 2, '顺义', '顺义区', '中国,北京,北京市,顺义区', 3, 'shunyi', '010', '101300', 'S', '116.65417', '40.1302'),
+(13, 2, '昌平', '昌平区', '中国,北京,北京市,昌平区', 3, 'changping', '010', '102200', 'C', '116.2312', '40.22072'),
+(14, 2, '大兴', '大兴区', '中国,北京,北京市,大兴区', 3, 'daxing', '010', '102600', 'D', '116.34149', '39.72668'),
+(15, 2, '怀柔', '怀柔区', '中国,北京,北京市,怀柔区', 3, 'huairou', '010', '101400', 'H', '116.63168', '40.31602'),
+(16, 2, '平谷', '平谷区', '中国,北京,北京市,平谷区', 3, 'pinggu', '010', '101200', 'P', '117.12133', '40.14056'),
+(17, 2, '密云', '密云县', '中国,北京,北京市,密云县', 3, 'miyun', '010', '101500', 'M', '116.84295', '40.37618'),
+(18, 2, '延庆', '延庆县', '中国,北京,北京市,延庆县', 3, 'yanqing', '010', '102100', 'Y', '115.97494', '40.45672'),
+(19, 0, '天津', '天津', '中国,天津', 1, 'tianjin', '', '', 'T', '117.190182', '39.125596'),
+(20, 19, '天津', '天津市', '中国,天津,天津市', 2, 'tianjin', '022', '300000', 'T', '117.190182', '39.125596'),
+(21, 20, '和平', '和平区', '中国,天津,天津市,和平区', 3, 'heping', '022', '300041', 'H', '117.21456', '39.11718'),
+(22, 20, '河东', '河东区', '中国,天津,天津市,河东区', 3, 'hedong', '022', '300171', 'H', '117.22562', '39.12318'),
+(23, 20, '河西', '河西区', '中国,天津,天津市,河西区', 3, 'hexi', '022', '300202', 'H', '117.22327', '39.10959'),
+(24, 20, '南开', '南开区', '中国,天津,天津市,南开区', 3, 'nankai', '022', '300110', 'N', '117.15074', '39.13821'),
+(25, 20, '河北', '河北区', '中国,天津,天津市,河北区', 3, 'hebei', '022', '300143', 'H', '117.19697', '39.14816'),
+(26, 20, '红桥', '红桥区', '中国,天津,天津市,红桥区', 3, 'hongqiao', '022', '300131', 'H', '117.15145', '39.16715'),
+(27, 20, '东丽', '东丽区', '中国,天津,天津市,东丽区', 3, 'dongli', '022', '300300', 'D', '117.31436', '39.0863'),
+(28, 20, '西青', '西青区', '中国,天津,天津市,西青区', 3, 'xiqing', '022', '300380', 'X', '117.00927', '39.14123'),
+(29, 20, '津南', '津南区', '中国,天津,天津市,津南区', 3, 'jinnan', '022', '300350', 'J', '117.38537', '38.99139'),
+(30, 20, '北辰', '北辰区', '中国,天津,天津市,北辰区', 3, 'beichen', '022', '300400', 'B', '117.13217', '39.22131'),
+(31, 20, '武清', '武清区', '中国,天津,天津市,武清区', 3, 'wuqing', '022', '301700', 'W', '117.04443', '39.38415'),
+(32, 20, '宝坻', '宝坻区', '中国,天津,天津市,宝坻区', 3, 'baodi', '022', '301800', 'B', '117.3103', '39.71761'),
+(33, 20, '滨海新区', '滨海新区', '中国,天津,天津市,滨海新区', 3, 'binhaixinqu', '022', '300451', 'B', '117.70162', '39.02668'),
+(34, 20, '宁河', '宁河县', '中国,天津,天津市,宁河县', 3, 'ninghe', '022', '301500', 'N', '117.8255', '39.33048'),
+(35, 20, '静海', '静海县', '中国,天津,天津市,静海县', 3, 'jinghai', '022', '301600', 'J', '116.97436', '38.94582'),
+(36, 20, '蓟县', '蓟县', '中国,天津,天津市,蓟县', 3, 'jixian', '022', '301900', 'J', '117.40799', '40.04567'),
+(37, 0, '河北', '河北省', '中国,河北省', 1, 'hebei', '', '', 'H', '114.502461', '38.045474'),
+(38, 37, '石家庄', '石家庄市', '中国,河北省,石家庄市', 2, 'shijiazhuang', '0311', '050011', 'S', '114.502461', '38.045474'),
+(39, 38, '长安', '长安区', '中国,河北省,石家庄市,长安区', 3, 'chang''an', '0311', '050011', 'C', '114.53906', '38.03665'),
+(40, 38, '桥西', '桥西区', '中国,河北省,石家庄市,桥西区', 3, 'qiaoxi', '0311', '050091', 'Q', '114.46977', '38.03221'),
+(41, 38, '新华', '新华区', '中国,河北省,石家庄市,新华区', 3, 'xinhua', '0311', '050051', 'X', '114.46326', '38.05088'),
+(42, 38, '井陉矿区', '井陉矿区', '中国,河北省,石家庄市,井陉矿区', 3, 'jingxingkuangqu', '0311', '050100', 'J', '114.06518', '38.06705'),
+(43, 38, '裕华', '裕华区', '中国,河北省,石家庄市,裕华区', 3, 'yuhua', '0311', '050031', 'Y', '114.53115', '38.00604'),
+(44, 38, '藁城', '藁城区', '中国,河北省,石家庄市,藁城区', 3, 'gaocheng', '0311', '052160', NULL, '114.84671', '38.02162'),
+(45, 38, '鹿泉', '鹿泉区', '中国,河北省,石家庄市,鹿泉区', 3, 'luquan', '0311', '050200', 'L', '114.31347', '38.08782'),
+(46, 38, '栾城', '栾城区', '中国,河北省,石家庄市,栾城区', 3, 'luancheng', '0311', '051430', NULL, '114.64834', '37.90022'),
+(47, 38, '井陉', '井陉县', '中国,河北省,石家庄市,井陉县', 3, 'jingxing', '0311', '050300', 'J', '114.14257', '38.03688'),
+(48, 38, '正定', '正定县', '中国,河北省,石家庄市,正定县', 3, 'zhengding', '0311', '050800', 'Z', '114.57296', '38.14445'),
+(49, 38, '行唐', '行唐县', '中国,河北省,石家庄市,行唐县', 3, 'xingtang', '0311', '050600', 'X', '114.55316', '38.43654'),
+(50, 38, '灵寿', '灵寿县', '中国,河北省,石家庄市,灵寿县', 3, 'lingshou', '0311', '050500', 'L', '114.38259', '38.30845'),
+(51, 38, '高邑', '高邑县', '中国,河北省,石家庄市,高邑县', 3, 'gaoyi', '0311', '051330', 'G', '114.61142', '37.61556'),
+(52, 38, '深泽', '深泽县', '中国,河北省,石家庄市,深泽县', 3, 'shenze', '0311', '052560', 'S', '115.20358', '38.18353'),
+(53, 38, '赞皇', '赞皇县', '中国,河北省,石家庄市,赞皇县', 3, 'zanhuang', '0311', '051230', 'Z', '114.38775', '37.66135'),
+(54, 38, '无极', '无极县', '中国,河北省,石家庄市,无极县', 3, 'wuji', '0311', '052460', 'W', '114.97509', '38.17653'),
+(55, 38, '平山', '平山县', '中国,河北省,石家庄市,平山县', 3, 'pingshan', '0311', '050400', 'P', '114.186', '38.25994'),
+(56, 38, '元氏', '元氏县', '中国,河北省,石家庄市,元氏县', 3, 'yuanshi', '0311', '051130', 'Y', '114.52539', '37.76668'),
+(57, 38, '赵县', '赵县', '中国,河北省,石家庄市,赵县', 3, 'zhaoxian', '0311', '051530', 'Z', '114.77612', '37.75628'),
+(58, 38, '辛集', '辛集市', '中国,河北省,石家庄市,辛集市', 3, 'xinji', '0311', '052360', 'X', '115.20626', '37.94079'),
+(59, 38, '晋州', '晋州市', '中国,河北省,石家庄市,晋州市', 3, 'jinzhou', '0311', '052260', 'J', '115.04348', '38.03135'),
+(60, 38, '新乐', '新乐市', '中国,河北省,石家庄市,新乐市', 3, 'xinle', '0311', '050700', 'X', '114.68985', '38.34417'),
+(61, 37, '唐山', '唐山市', '中国,河北省,唐山市', 2, 'tangshan', '0315', '063000', 'T', '118.175393', '39.635113'),
+(62, 61, '路南', '路南区', '中国,河北省,唐山市,路南区', 3, 'lunan', '0315', '063000', 'L', '118.15431', '39.62505'),
+(63, 61, '路北', '路北区', '中国,河北省,唐山市,路北区', 3, 'lubei', '0315', '063000', 'L', '118.20079', '39.62436'),
+(64, 61, '古冶', '古冶区', '中国,河北省,唐山市,古冶区', 3, 'guye', '0315', '063100', 'G', '118.45803', '39.71993'),
+(65, 61, '开平', '开平区', '中国,河北省,唐山市,开平区', 3, 'kaiping', '0315', '063021', 'K', '118.26171', '39.67128'),
+(66, 61, '丰南', '丰南区', '中国,河北省,唐山市,丰南区', 3, 'fengnan', '0315', '063300', 'F', '118.11282', '39.56483'),
+(67, 61, '丰润', '丰润区', '中国,河北省,唐山市,丰润区', 3, 'fengrun', '0315', '064000', 'F', '118.12976', '39.8244'),
+(68, 61, '曹妃甸', '曹妃甸区', '中国,河北省,唐山市,曹妃甸区', 3, 'caofeidian', '0315', '063200', 'C', '118.460379', '39.273070'),
+(69, 61, '滦县', '滦县', '中国,河北省,唐山市,滦县', 3, 'luanxian', '0315', '063700', 'L', '118.70346', '39.74056'),
+(70, 61, '滦南', '滦南县', '中国,河北省,唐山市,滦南县', 3, 'luannan', '0315', '063500', 'L', '118.6741', '39.5039'),
+(71, 61, '乐亭', '乐亭县', '中国,河北省,唐山市,乐亭县', 3, 'laoting', '0315', '063600', 'L', '118.9125', '39.42561'),
+(72, 61, '迁西', '迁西县', '中国,河北省,唐山市,迁西县', 3, 'qianxi', '0315', '064300', 'Q', '118.31616', '40.14587'),
+(73, 61, '玉田', '玉田县', '中国,河北省,唐山市,玉田县', 3, 'yutian', '0315', '064100', 'Y', '117.7388', '39.90049'),
+(74, 61, '遵化', '遵化市', '中国,河北省,唐山市,遵化市', 3, 'zunhua', '0315', '064200', 'Z', '117.96444', '40.18741'),
+(75, 61, '迁安', '迁安市', '中国,河北省,唐山市,迁安市', 3, 'qian''an', '0315', '064400', 'Q', '118.70068', '39.99833'),
+(76, 37, '秦皇岛', '秦皇岛市', '中国,河北省,秦皇岛市', 2, 'qinhuangdao', '0335', '066000', 'Q', '119.586579', '39.942531'),
+(77, 76, '海港', '海港区', '中国,河北省,秦皇岛市,海港区', 3, 'haigang', '0335', '066000', 'H', '119.61046', '39.9345'),
+(78, 76, '山海关', '山海关区', '中国,河北省,秦皇岛市,山海关区', 3, 'shanhaiguan', '0335', '066200', 'S', '119.77563', '39.97869'),
+(79, 76, '北戴河', '北戴河区', '中国,河北省,秦皇岛市,北戴河区', 3, 'beidaihe', '0335', '066100', 'B', '119.48388', '39.83408'),
+(80, 76, '青龙', '青龙满族自治县', '中国,河北省,秦皇岛市,青龙满族自治县', 3, 'qinglong', '0335', '066500', 'Q', '118.95242', '40.40743'),
+(81, 76, '昌黎', '昌黎县', '中国,河北省,秦皇岛市,昌黎县', 3, 'changli', '0335', '066600', 'C', '119.16595', '39.70884'),
+(82, 76, '抚宁', '抚宁县', '中国,河北省,秦皇岛市,抚宁县', 3, 'funing', '0335', '066300', 'F', '119.24487', '39.87538'),
+(83, 76, '卢龙', '卢龙县', '中国,河北省,秦皇岛市,卢龙县', 3, 'lulong', '0335', '066400', 'L', '118.89288', '39.89176'),
+(84, 37, '邯郸', '邯郸市', '中国,河北省,邯郸市', 2, 'handan', '0310', '056002', 'H', '114.490686', '36.612273'),
+(85, 84, '邯山', '邯山区', '中国,河北省,邯郸市,邯山区', 3, 'hanshan', '0310', '056001', 'H', '114.48375', '36.60006'),
+(86, 84, '丛台', '丛台区', '中国,河北省,邯郸市,丛台区', 3, 'congtai', '0310', '056002', 'C', '114.49343', '36.61847'),
+(87, 84, '复兴', '复兴区', '中国,河北省,邯郸市,复兴区', 3, 'fuxing', '0310', '056003', 'F', '114.45928', '36.61134'),
+(88, 84, '峰峰矿区', '峰峰矿区', '中国,河北省,邯郸市,峰峰矿区', 3, 'fengfengkuangqu', '0310', '056200', 'F', '114.21148', '36.41937'),
+(89, 84, '邯郸', '邯郸县', '中国,河北省,邯郸市,邯郸县', 3, 'handan', '0310', '056101', 'H', '114.53103', '36.59385'),
+(90, 84, '临漳', '临漳县', '中国,河北省,邯郸市,临漳县', 3, 'linzhang', '0310', '056600', 'L', '114.6195', '36.33461'),
+(91, 84, '成安', '成安县', '中国,河北省,邯郸市,成安县', 3, 'cheng''an', '0310', '056700', 'C', '114.66995', '36.44411'),
+(92, 84, '大名', '大名县', '中国,河北省,邯郸市,大名县', 3, 'daming', '0310', '056900', 'D', '115.15362', '36.27994'),
+(93, 84, '涉县', '涉县', '中国,河北省,邯郸市,涉县', 3, 'shexian', '0310', '056400', 'S', '113.69183', '36.58072'),
+(94, 84, '磁县', '磁县', '中国,河北省,邯郸市,磁县', 3, 'cixian', '0310', '056500', 'C', '114.37387', '36.37392'),
+(95, 84, '肥乡', '肥乡县', '中国,河北省,邯郸市,肥乡县', 3, 'feixiang', '0310', '057550', 'F', '114.79998', '36.54807'),
+(96, 84, '永年', '永年县', '中国,河北省,邯郸市,永年县', 3, 'yongnian', '0310', '057150', 'Y', '114.48925', '36.78356'),
+(97, 84, '邱县', '邱县', '中国,河北省,邯郸市,邱县', 3, 'qiuxian', '0310', '057450', 'Q', '115.17407', '36.82082'),
+(98, 84, '鸡泽', '鸡泽县', '中国,河北省,邯郸市,鸡泽县', 3, 'jize', '0310', '057350', 'J', '114.8742', '36.92374'),
+(99, 84, '广平', '广平县', '中国,河北省,邯郸市,广平县', 3, 'guangping', '0310', '057650', 'G', '114.94653', '36.48046'),
+(100, 84, '馆陶', '馆陶县', '中国,河北省,邯郸市,馆陶县', 3, 'guantao', '0310', '057750', 'G', '115.29913', '36.53719'),
+(101, 84, '魏县', '魏县', '中国,河北省,邯郸市,魏县', 3, 'weixian', '0310', '056800', 'W', '114.93518', '36.36171'),
+(102, 84, '曲周', '曲周县', '中国,河北省,邯郸市,曲周县', 3, 'quzhou', '0310', '057250', 'Q', '114.95196', '36.77671'),
+(103, 84, '武安', '武安市', '中国,河北省,邯郸市,武安市', 3, 'wu''an', '0310', '056300', 'W', '114.20153', '36.69281'),
+(104, 37, '邢台', '邢台市', '中国,河北省,邢台市', 2, 'xingtai', '0319', '054001', 'X', '114.508851', '37.0682'),
+(105, 104, '桥东', '桥东区', '中国,河北省,邢台市,桥东区', 3, 'qiaodong', '0319', '054001', 'Q', '114.50725', '37.06801'),
+(106, 104, '桥西', '桥西区', '中国,河北省,邢台市,桥西区', 3, 'qiaoxi', '0319', '054000', 'Q', '114.46803', '37.05984'),
+(107, 104, '邢台', '邢台县', '中国,河北省,邢台市,邢台县', 3, 'xingtai', '0319', '054001', 'X', '114.56575', '37.0456'),
+(108, 104, '临城', '临城县', '中国,河北省,邢台市,临城县', 3, 'lincheng', '0319', '054300', 'L', '114.50387', '37.43977'),
+(109, 104, '内丘', '内丘县', '中国,河北省,邢台市,内丘县', 3, 'neiqiu', '0319', '054200', 'N', '114.51212', '37.28671'),
+(110, 104, '柏乡', '柏乡县', '中国,河北省,邢台市,柏乡县', 3, 'baixiang', '0319', '055450', 'B', '114.69332', '37.48242'),
+(111, 104, '隆尧', '隆尧县', '中国,河北省,邢台市,隆尧县', 3, 'longyao', '0319', '055350', 'L', '114.77615', '37.35351'),
+(112, 104, '任县', '任县', '中国,河北省,邢台市,任县', 3, 'renxian', '0319', '055150', 'R', '114.6842', '37.12575'),
+(113, 104, '南和', '南和县', '中国,河北省,邢台市,南和县', 3, 'nanhe', '0319', '054400', 'N', '114.68371', '37.00488'),
+(114, 104, '宁晋', '宁晋县', '中国,河北省,邢台市,宁晋县', 3, 'ningjin', '0319', '055550', 'N', '114.92117', '37.61696'),
+(115, 104, '巨鹿', '巨鹿县', '中国,河北省,邢台市,巨鹿县', 3, 'julu', '0319', '055250', 'J', '115.03524', '37.21801'),
+(116, 104, '新河', '新河县', '中国,河北省,邢台市,新河县', 3, 'xinhe', '0319', '055650', 'X', '115.24987', '37.52718'),
+(117, 104, '广宗', '广宗县', '中国,河北省,邢台市,广宗县', 3, 'guangzong', '0319', '054600', 'G', '115.14254', '37.0746'),
+(118, 104, '平乡', '平乡县', '中国,河北省,邢台市,平乡县', 3, 'pingxiang', '0319', '054500', 'P', '115.03002', '37.06317'),
+(119, 104, '威县', '威县', '中国,河北省,邢台市,威县', 3, 'weixian', '0319', '054700', 'W', '115.2637', '36.9768'),
+(120, 104, '清河', '清河县', '中国,河北省,邢台市,清河县', 3, 'qinghe', '0319', '054800', 'Q', '115.66479', '37.07122'),
+(121, 104, '临西', '临西县', '中国,河北省,邢台市,临西县', 3, 'linxi', '0319', '054900', 'L', '115.50097', '36.87078'),
+(122, 104, '南宫', '南宫市', '中国,河北省,邢台市,南宫市', 3, 'nangong', '0319', '055750', 'N', '115.39068', '37.35799'),
+(123, 104, '沙河', '沙河市', '中国,河北省,邢台市,沙河市', 3, 'shahe', '0319', '054100', 'S', '114.4981', '36.8577'),
+(124, 37, '保定', '保定市', '中国,河北省,保定市', 2, 'baoding', '0312', '071052', 'B', '115.482331', '38.867657'),
+(125, 124, '新市', '新市区', '中国,河北省,保定市,新市区', 3, 'xinshi', '0312', '071051', 'X', '115.4587', '38.87751'),
+(126, 124, '北市', '北市区', '中国,河北省,保定市,北市区', 3, 'beishi', '0312', '071000', 'B', '115.49715', '38.88322'),
+(127, 124, '南市', '南市区', '中国,河北省,保定市,南市区', 3, 'nanshi', '0312', '071001', 'N', '115.52859', '38.85455'),
+(128, 124, '满城', '满城县', '中国,河北省,保定市,满城县', 3, 'mancheng', '0312', '072150', 'M', '115.32296', '38.94972'),
+(129, 124, '清苑', '清苑县', '中国,河北省,保定市,清苑县', 3, 'qingyuan', '0312', '071100', 'Q', '115.49267', '38.76709'),
+(130, 124, '涞水', '涞水县', '中国,河北省,保定市,涞水县', 3, 'laishui', '0312', '074100', NULL, '115.71517', '39.39404'),
+(131, 124, '阜平', '阜平县', '中国,河北省,保定市,阜平县', 3, 'fuping', '0312', '073200', 'F', '114.19683', '38.84763'),
+(132, 124, '徐水', '徐水县', '中国,河北省,保定市,徐水县', 3, 'xushui', '0312', '072550', 'X', '115.65829', '39.02099'),
+(133, 124, '定兴', '定兴县', '中国,河北省,保定市,定兴县', 3, 'dingxing', '0312', '072650', 'D', '115.80786', '39.26312'),
+(134, 124, '唐县', '唐县', '中国,河北省,保定市,唐县', 3, 'tangxian', '0312', '072350', 'T', '114.98516', '38.74513'),
+(135, 124, '高阳', '高阳县', '中国,河北省,保定市,高阳县', 3, 'gaoyang', '0312', '071500', 'G', '115.7788', '38.70003'),
+(136, 124, '容城', '容城县', '中国,河北省,保定市,容城县', 3, 'rongcheng', '0312', '071700', 'R', '115.87158', '39.0535'),
+(137, 124, '涞源', '涞源县', '中国,河北省,保定市,涞源县', 3, 'laiyuan', '0312', '074300', NULL, '114.69128', '39.35388'),
+(138, 124, '望都', '望都县', '中国,河北省,保定市,望都县', 3, 'wangdu', '0312', '072450', 'W', '115.1567', '38.70996'),
+(139, 124, '安新', '安新县', '中国,河北省,保定市,安新县', 3, 'anxin', '0312', '071600', 'A', '115.93557', '38.93532'),
+(140, 124, '易县', '易县', '中国,河北省,保定市,易县', 3, 'yixian', '0312', '074200', 'Y', '115.4981', '39.34885'),
+(141, 124, '曲阳', '曲阳县', '中国,河北省,保定市,曲阳县', 3, 'quyang', '0312', '073100', 'Q', '114.70123', '38.62154'),
+(142, 124, '蠡县', '蠡县', '中国,河北省,保定市,蠡县', 3, 'lixian', '0312', '071400', NULL, '115.57717', '38.48974'),
+(143, 124, '顺平', '顺平县', '中国,河北省,保定市,顺平县', 3, 'shunping', '0312', '072250', 'S', '115.1347', '38.83854'),
+(144, 124, '博野', '博野县', '中国,河北省,保定市,博野县', 3, 'boye', '0312', '071300', 'B', '115.47033', '38.4564'),
+(145, 124, '雄县', '雄县', '中国,河北省,保定市,雄县', 3, 'xiongxian', '0312', '071800', 'X', '116.10873', '38.99442'),
+(146, 124, '涿州', '涿州市', '中国,河北省,保定市,涿州市', 3, 'zhuozhou', '0312', '072750', NULL, '115.98062', '39.48622'),
+(147, 124, '定州', '定州市', '中国,河北省,保定市,定州市', 3, 'dingzhou', '0312', '073000', 'D', '114.9902', '38.51623'),
+(148, 124, '安国', '安国市', '中国,河北省,保定市,安国市', 3, 'anguo', '0312', '071200', 'A', '115.32321', '38.41391'),
+(149, 124, '高碑店', '高碑店市', '中国,河北省,保定市,高碑店市', 3, 'gaobeidian', '0312', '074000', 'G', '115.87368', '39.32655'),
+(150, 37, '张家口', '张家口市', '中国,河北省,张家口市', 2, 'zhangjiakou', '0313', '075000', 'Z', '114.884091', '40.811901'),
+(151, 150, '桥东', '桥东区', '中国,河北省,张家口市,桥东区', 3, 'qiaodong', '0313', '075000', 'Q', '114.8943', '40.78844'),
+(152, 150, '桥西', '桥西区', '中国,河北省,张家口市,桥西区', 3, 'qiaoxi', '0313', '075061', 'Q', '114.86962', '40.81945'),
+(153, 150, '宣化', '宣化区', '中国,河北省,张家口市,宣化区', 3, 'xuanhua', '0313', '075100', 'X', '115.06543', '40.60957'),
+(154, 150, '下花园', '下花园区', '中国,河北省,张家口市,下花园区', 3, 'xiahuayuan', '0313', '075300', 'X', '115.28744', '40.50236'),
+(155, 150, '宣化', '宣化县', '中国,河北省,张家口市,宣化县', 3, 'xuanhua', '0313', '075100', 'X', '115.15497', '40.56618'),
+(156, 150, '张北', '张北县', '中国,河北省,张家口市,张北县', 3, 'zhangbei', '0313', '076450', 'Z', '114.71432', '41.15977'),
+(157, 150, '康保', '康保县', '中国,河北省,张家口市,康保县', 3, 'kangbao', '0313', '076650', 'K', '114.60031', '41.85225'),
+(158, 150, '沽源', '沽源县', '中国,河北省,张家口市,沽源县', 3, 'guyuan', '0313', '076550', 'G', '115.68859', '41.66959'),
+(159, 150, '尚义', '尚义县', '中国,河北省,张家口市,尚义县', 3, 'shangyi', '0313', '076750', 'S', '113.97134', '41.07782'),
+(160, 150, '蔚县', '蔚县', '中国,河北省,张家口市,蔚县', 3, 'yuxian', '0313', '075700', 'W', '114.58892', '39.84067'),
+(161, 150, '阳原', '阳原县', '中国,河北省,张家口市,阳原县', 3, 'yangyuan', '0313', '075800', 'Y', '114.15051', '40.10361'),
+(162, 150, '怀安', '怀安县', '中国,河北省,张家口市,怀安县', 3, 'huai''an', '0313', '076150', 'H', '114.38559', '40.67425'),
+(163, 150, '万全', '万全县', '中国,河北省,张家口市,万全县', 3, 'wanquan', '0313', '076250', 'W', '114.7405', '40.76694'),
+(164, 150, '怀来', '怀来县', '中国,河北省,张家口市,怀来县', 3, 'huailai', '0313', '075400', 'H', '115.51773', '40.41536'),
+(165, 150, '涿鹿', '涿鹿县', '中国,河北省,张家口市,涿鹿县', 3, 'zhuolu', '0313', '075600', NULL, '115.22403', '40.37636'),
+(166, 150, '赤城', '赤城县', '中国,河北省,张家口市,赤城县', 3, 'chicheng', '0313', '075500', 'C', '115.83187', '40.91438'),
+(167, 150, '崇礼', '崇礼县', '中国,河北省,张家口市,崇礼县', 3, 'chongli', '0313', '076350', 'C', '115.27993', '40.97519'),
+(168, 37, '承德', '承德市', '中国,河北省,承德市', 2, 'chengde', '0314', '067000', 'C', '117.939152', '40.976204'),
+(169, 168, '双桥', '双桥区', '中国,河北省,承德市,双桥区', 3, 'shuangqiao', '0314', '067000', 'S', '117.9432', '40.97466'),
+(170, 168, '双滦', '双滦区', '中国,河北省,承德市,双滦区', 3, 'shuangluan', '0314', '067001', 'S', '117.74487', '40.95375'),
+(171, 168, '鹰手营子矿区', '鹰手营子矿区', '中国,河北省,承德市,鹰手营子矿区', 3, 'yingshouyingzikuangqu', '0314', '067200', 'Y', '117.65985', '40.54744'),
+(172, 168, '承德', '承德县', '中国,河北省,承德市,承德县', 3, 'chengde', '0314', '067400', 'C', '118.17639', '40.76985'),
+(173, 168, '兴隆', '兴隆县', '中国,河北省,承德市,兴隆县', 3, 'xinglong', '0314', '067300', 'X', '117.50073', '40.41709'),
+(174, 168, '平泉', '平泉县', '中国,河北省,承德市,平泉县', 3, 'pingquan', '0314', '067500', 'P', '118.70196', '41.01839'),
+(175, 168, '滦平', '滦平县', '中国,河北省,承德市,滦平县', 3, 'luanping', '0314', '068250', 'L', '117.33276', '40.94148'),
+(176, 168, '隆化', '隆化县', '中国,河北省,承德市,隆化县', 3, 'longhua', '0314', '068150', 'L', '117.7297', '41.31412'),
+(177, 168, '丰宁', '丰宁满族自治县', '中国,河北省,承德市,丰宁满族自治县', 3, 'fengning', '0314', '068350', 'F', '116.6492', '41.20481'),
+(178, 168, '宽城', '宽城满族自治县', '中国,河北省,承德市,宽城满族自治县', 3, 'kuancheng', '0314', '067600', 'K', '118.49176', '40.60829'),
+(179, 168, '围场', '围场满族蒙古族自治县', '中国,河北省,承德市,围场满族蒙古族自治县', 3, 'weichang', '0314', '068450', 'W', '117.7601', '41.94368'),
+(180, 37, '沧州', '沧州市', '中国,河北省,沧州市', 2, 'cangzhou', '0317', '061001', 'C', '116.857461', '38.310582'),
+(181, 180, '新华', '新华区', '中国,河北省,沧州市,新华区', 3, 'xinhua', '0317', '061000', 'X', '116.86643', '38.31438'),
+(182, 180, '运河', '运河区', '中国,河北省,沧州市,运河区', 3, 'yunhe', '0317', '061001', 'Y', '116.85706', '38.31352'),
+(183, 180, '沧县', '沧县', '中国,河北省,沧州市,沧县', 3, 'cangxian', '0317', '061000', 'C', '116.87817', '38.29361'),
+(184, 180, '青县', '青县', '中国,河北省,沧州市,青县', 3, 'qingxian', '0317', '062650', 'Q', '116.80316', '38.58345'),
+(185, 180, '东光', '东光县', '中国,河北省,沧州市,东光县', 3, 'dongguang', '0317', '061600', 'D', '116.53668', '37.8857'),
+(186, 180, '海兴', '海兴县', '中国,河北省,沧州市,海兴县', 3, 'haixing', '0317', '061200', 'H', '117.49758', '38.13958'),
+(187, 180, '盐山', '盐山县', '中国,河北省,沧州市,盐山县', 3, 'yanshan', '0317', '061300', 'Y', '117.23092', '38.05647'),
+(188, 180, '肃宁', '肃宁县', '中国,河北省,沧州市,肃宁县', 3, 'suning', '0317', '062350', 'S', '115.82971', '38.42272'),
+(189, 180, '南皮', '南皮县', '中国,河北省,沧州市,南皮县', 3, 'nanpi', '0317', '061500', 'N', '116.70224', '38.04109'),
+(190, 180, '吴桥', '吴桥县', '中国,河北省,沧州市,吴桥县', 3, 'wuqiao', '0317', '061800', 'W', '116.3847', '37.62546'),
+(191, 180, '献县', '献县', '中国,河北省,沧州市,献县', 3, 'xianxian', '0317', '062250', 'X', '116.12695', '38.19228'),
+(192, 180, '孟村', '孟村回族自治县', '中国,河北省,沧州市,孟村回族自治县', 3, 'mengcun', '0317', '061400', 'M', '117.10412', '38.05338'),
+(193, 180, '泊头', '泊头市', '中国,河北省,沧州市,泊头市', 3, 'botou', '0317', '062150', 'B', '116.57824', '38.08359'),
+(194, 180, '任丘', '任丘市', '中国,河北省,沧州市,任丘市', 3, 'renqiu', '0317', '062550', 'R', '116.1033', '38.71124'),
+(195, 180, '黄骅', '黄骅市', '中国,河北省,沧州市,黄骅市', 3, 'huanghua', '0317', '061100', 'H', '117.33883', '38.3706'),
+(196, 180, '河间', '河间市', '中国,河北省,沧州市,河间市', 3, 'hejian', '0317', '062450', 'H', '116.0993', '38.44549'),
+(197, 37, '廊坊', '廊坊市', '中国,河北省,廊坊市', 2, 'langfang', '0316', '065000', 'L', '116.713873', '39.529244'),
+(198, 197, '安次', '安次区', '中国,河北省,廊坊市,安次区', 3, 'anci', '0316', '065000', 'A', '116.70308', '39.52057'),
+(199, 197, '广阳', '广阳区', '中国,河北省,廊坊市,广阳区', 3, 'guangyang', '0316', '065000', 'G', '116.71069', '39.52278'),
+(200, 197, '固安', '固安县', '中国,河北省,廊坊市,固安县', 3, 'gu''an', '0316', '065500', 'G', '116.29916', '39.43833'),
+(201, 197, '永清', '永清县', '中国,河北省,廊坊市,永清县', 3, 'yongqing', '0316', '065600', 'Y', '116.50091', '39.32069'),
+(202, 197, '香河', '香河县', '中国,河北省,廊坊市,香河县', 3, 'xianghe', '0316', '065400', 'X', '117.00634', '39.76133'),
+(203, 197, '大城', '大城县', '中国,河北省,廊坊市,大城县', 3, 'daicheng', '0316', '065900', 'D', '116.65353', '38.70534'),
+(204, 197, '文安', '文安县', '中国,河北省,廊坊市,文安县', 3, 'wen''an', '0316', '065800', 'W', '116.45846', '38.87325'),
+(205, 197, '大厂', '大厂回族自治县', '中国,河北省,廊坊市,大厂回族自治县', 3, 'dachang', '0316', '065300', 'D', '116.98916', '39.88649'),
+(206, 197, '霸州', '霸州市', '中国,河北省,廊坊市,霸州市', 3, 'bazhou', '0316', '065700', 'B', '116.39154', '39.12569'),
+(207, 197, '三河', '三河市', '中国,河北省,廊坊市,三河市', 3, 'sanhe', '0316', '065200', 'S', '117.07229', '39.98358'),
+(208, 37, '衡水', '衡水市', '中国,河北省,衡水市', 2, 'hengshui', '0318', '053000', 'H', '115.665993', '37.735097'),
+(209, 208, '桃城', '桃城区', '中国,河北省,衡水市,桃城区', 3, 'taocheng', '0318', '053000', 'T', '115.67529', '37.73499'),
+(210, 208, '枣强', '枣强县', '中国,河北省,衡水市,枣强县', 3, 'zaoqiang', '0318', '053100', 'Z', '115.72576', '37.51027'),
+(211, 208, '武邑', '武邑县', '中国,河北省,衡水市,武邑县', 3, 'wuyi', '0318', '053400', 'W', '115.88748', '37.80181'),
+(212, 208, '武强', '武强县', '中国,河北省,衡水市,武强县', 3, 'wuqiang', '0318', '053300', 'W', '115.98226', '38.04138'),
+(213, 208, '饶阳', '饶阳县', '中国,河北省,衡水市,饶阳县', 3, 'raoyang', '0318', '053900', 'R', '115.72558', '38.23529'),
+(214, 208, '安平', '安平县', '中国,河北省,衡水市,安平县', 3, 'anping', '0318', '053600', 'A', '115.51876', '38.23388'),
+(215, 208, '故城', '故城县', '中国,河北省,衡水市,故城县', 3, 'gucheng', '0318', '053800', 'G', '115.97076', '37.34773'),
+(216, 208, '景县', '景县', '中国,河北省,衡水市,景县', 3, 'jingxian', '0318', '053500', 'J', '116.26904', '37.6926'),
+(217, 208, '阜城', '阜城县', '中国,河北省,衡水市,阜城县', 3, 'fucheng', '0318', '053700', 'F', '116.14431', '37.86881'),
+(218, 208, '冀州', '冀州市', '中国,河北省,衡水市,冀州市', 3, 'jizhou', '0318', '053200', 'J', '115.57934', '37.55082'),
+(219, 208, '深州', '深州市', '中国,河北省,衡水市,深州市', 3, 'shenzhou', '0318', '053800', 'S', '115.55993', '38.00109'),
+(220, 0, '山西', '山西省', '中国,山西省', 1, 'shanxi', '', '', 'S', '112.549248', '37.857014'),
+(221, 220, '太原', '太原市', '中国,山西省,太原市', 2, 'taiyuan', '0351', '030082', 'T', '112.549248', '37.857014'),
+(222, 221, '小店', '小店区', '中国,山西省,太原市,小店区', 3, 'xiaodian', '0351', '030032', 'X', '112.56878', '37.73565'),
+(223, 221, '迎泽', '迎泽区', '中国,山西省,太原市,迎泽区', 3, 'yingze', '0351', '030002', 'Y', '112.56338', '37.86326'),
+(224, 221, '杏花岭', '杏花岭区', '中国,山西省,太原市,杏花岭区', 3, 'xinghualing', '0351', '030009', 'X', '112.56237', '37.88429'),
+(225, 221, '尖草坪', '尖草坪区', '中国,山西省,太原市,尖草坪区', 3, 'jiancaoping', '0351', '030023', 'J', '112.48709', '37.94193'),
+(226, 221, '万柏林', '万柏林区', '中国,山西省,太原市,万柏林区', 3, 'wanbailin', '0351', '030024', 'W', '112.51553', '37.85923'),
+(227, 221, '晋源', '晋源区', '中国,山西省,太原市,晋源区', 3, 'jinyuan', '0351', '030025', 'J', '112.47985', '37.72479'),
+(228, 221, '清徐', '清徐县', '中国,山西省,太原市,清徐县', 3, 'qingxu', '0351', '030400', 'Q', '112.35888', '37.60758'),
+(229, 221, '阳曲', '阳曲县', '中国,山西省,太原市,阳曲县', 3, 'yangqu', '0351', '030100', 'Y', '112.67861', '38.05989'),
+(230, 221, '娄烦', '娄烦县', '中国,山西省,太原市,娄烦县', 3, 'loufan', '0351', '030300', 'L', '111.79473', '38.06689'),
+(231, 221, '古交', '古交市', '中国,山西省,太原市,古交市', 3, 'gujiao', '0351', '030200', 'G', '112.16918', '37.90983'),
+(232, 220, '大同', '大同市', '中国,山西省,大同市', 2, 'datong', '0352', '037008', 'D', '113.295259', '40.09031'),
+(233, 232, '城区', '城区', '中国,山西省,大同市,城区', 3, 'chengqu', '0352', '037008', 'C', '113.298', '40.07566'),
+(234, 232, '矿区', '矿区', '中国,山西省,大同市,矿区', 3, 'kuangqu', '0352', '037003', 'K', '113.1772', '40.03685'),
+(235, 232, '南郊', '南郊区', '中国,山西省,大同市,南郊区', 3, 'nanjiao', '0352', '037001', 'N', '113.14947', '40.00539'),
+(236, 232, '新荣', '新荣区', '中国,山西省,大同市,新荣区', 3, 'xinrong', '0352', '037002', 'X', '113.13504', '40.25618'),
+(237, 232, '阳高', '阳高县', '中国,山西省,大同市,阳高县', 3, 'yanggao', '0352', '038100', 'Y', '113.75012', '40.36256'),
+(238, 232, '天镇', '天镇县', '中国,山西省,大同市,天镇县', 3, 'tianzhen', '0352', '038200', 'T', '114.0931', '40.42299'),
+(239, 232, '广灵', '广灵县', '中国,山西省,大同市,广灵县', 3, 'guangling', '0352', '037500', 'G', '114.28204', '39.76082'),
+(240, 232, '灵丘', '灵丘县', '中国,山西省,大同市,灵丘县', 3, 'lingqiu', '0352', '034400', 'L', '114.23672', '39.44043'),
+(241, 232, '浑源', '浑源县', '中国,山西省,大同市,浑源县', 3, 'hunyuan', '0352', '037400', 'H', '113.69552', '39.69962'),
+(242, 232, '左云', '左云县', '中国,山西省,大同市,左云县', 3, 'zuoyun', '0352', '037100', 'Z', '112.70266', '40.01336'),
+(243, 232, '大同', '大同县', '中国,山西省,大同市,大同县', 3, 'datong', '0352', '037300', 'D', '113.61212', '40.04012'),
+(244, 220, '阳泉', '阳泉市', '中国,山西省,阳泉市', 2, 'yangquan', '0353', '045000', 'Y', '113.583285', '37.861188'),
+(245, 244, '城区', '城区', '中国,山西省,阳泉市,城区', 3, 'chengqu', '0353', '045000', 'C', '113.60069', '37.8474'),
+(246, 244, '矿区', '矿区', '中国,山西省,阳泉市,矿区', 3, 'kuangqu', '0353', '045000', 'K', '113.55677', '37.86895'),
+(247, 244, '郊区', '郊区', '中国,山西省,阳泉市,郊区', 3, 'jiaoqu', '0353', '045011', 'J', '113.58539', '37.94139'),
+(248, 244, '平定', '平定县', '中国,山西省,阳泉市,平定县', 3, 'pingding', '0353', '045200', 'P', '113.65789', '37.78601'),
+(249, 244, '盂县', '盂县', '中国,山西省,阳泉市,盂县', 3, 'yuxian', '0353', '045100', 'Y', '113.41235', '38.08579'),
+(250, 220, '长治', '长治市', '中国,山西省,长治市', 2, 'changzhi', '0355', '046000', 'C', '113.113556', '36.191112'),
+(251, 250, '城区', '城区', '中国,山西省,长治市,城区', 3, 'chengqu', '0355', '046011', 'C', '113.12308', '36.20351'),
+(252, 250, '郊区', '郊区', '中国,山西省,长治市,郊区', 3, 'jiaoqu', '0355', '046011', 'J', '113.12653', '36.19918'),
+(253, 250, '长治', '长治县', '中国,山西省,长治市,长治县', 3, 'changzhi', '0355', '047100', 'C', '113.04791', '36.04722'),
+(254, 250, '襄垣', '襄垣县', '中国,山西省,长治市,襄垣县', 3, 'xiangyuan', '0355', '046200', 'X', '113.05157', '36.53527'),
+(255, 250, '屯留', '屯留县', '中国,山西省,长治市,屯留县', 3, 'tunliu', '0355', '046100', 'T', '112.89196', '36.31579'),
+(256, 250, '平顺', '平顺县', '中国,山西省,长治市,平顺县', 3, 'pingshun', '0355', '047400', 'P', '113.43603', '36.20005'),
+(257, 250, '黎城', '黎城县', '中国,山西省,长治市,黎城县', 3, 'licheng', '0355', '047600', 'L', '113.38766', '36.50301'),
+(258, 250, '壶关', '壶关县', '中国,山西省,长治市,壶关县', 3, 'huguan', '0355', '047300', 'H', '113.207', '36.11301'),
+(259, 250, '长子', '长子县', '中国,山西省,长治市,长子县', 3, 'zhangzi', '0355', '046600', 'C', '112.87731', '36.12125'),
+(260, 250, '武乡', '武乡县', '中国,山西省,长治市,武乡县', 3, 'wuxiang', '0355', '046300', 'W', '112.86343', '36.83687'),
+(261, 250, '沁县', '沁县', '中国,山西省,长治市,沁县', 3, 'qinxian', '0355', '046400', 'Q', '112.69863', '36.75628'),
+(262, 250, '沁源', '沁源县', '中国,山西省,长治市,沁源县', 3, 'qinyuan', '0355', '046500', 'Q', '112.33758', '36.50008'),
+(263, 250, '潞城', '潞城市', '中国,山西省,长治市,潞城市', 3, 'lucheng', '0355', '047500', 'L', '113.22888', '36.33414'),
+(264, 220, '晋城', '晋城市', '中国,山西省,晋城市', 2, 'jincheng', '0356', '048000', 'J', '112.851274', '35.497553'),
+(265, 264, '城区', '城区', '中国,山西省,晋城市,城区', 3, 'chengqu', '0356', '048000', 'C', '112.85319', '35.50175'),
+(266, 264, '沁水', '沁水县', '中国,山西省,晋城市,沁水县', 3, 'qinshui', '0356', '048200', 'Q', '112.1871', '35.69102'),
+(267, 264, '阳城', '阳城县', '中国,山西省,晋城市,阳城县', 3, 'yangcheng', '0356', '048100', 'Y', '112.41485', '35.48614'),
+(268, 264, '陵川', '陵川县', '中国,山西省,晋城市,陵川县', 3, 'lingchuan', '0356', '048300', 'L', '113.2806', '35.77532'),
+(269, 264, '泽州', '泽州县', '中国,山西省,晋城市,泽州县', 3, 'zezhou', '0356', '048012', 'Z', '112.83947', '35.50789'),
+(270, 264, '高平', '高平市', '中国,山西省,晋城市,高平市', 3, 'gaoping', '0356', '048400', 'G', '112.92288', '35.79705'),
+(271, 220, '朔州', '朔州市', '中国,山西省,朔州市', 2, 'shuozhou', '0349', '038500', 'S', '112.433387', '39.331261'),
+(272, 271, '朔城', '朔城区', '中国,山西省,朔州市,朔城区', 3, 'shuocheng', '0349', '036000', 'S', '112.43189', '39.31982'),
+(273, 271, '平鲁', '平鲁区', '中国,山西省,朔州市,平鲁区', 3, 'pinglu', '0349', '038600', 'P', '112.28833', '39.51155'),
+(274, 271, '山阴', '山阴县', '中国,山西省,朔州市,山阴县', 3, 'shanyin', '0349', '036900', 'S', '112.81662', '39.52697'),
+(275, 271, '应县', '应县', '中国,山西省,朔州市,应县', 3, 'yingxian', '0349', '037600', 'Y', '113.19052', '39.55279'),
+(276, 271, '右玉', '右玉县', '中国,山西省,朔州市,右玉县', 3, 'youyu', '0349', '037200', 'Y', '112.46902', '39.99011'),
+(277, 271, '怀仁', '怀仁县', '中国,山西省,朔州市,怀仁县', 3, 'huairen', '0349', '038300', 'H', '113.10009', '39.82806'),
+(278, 220, '晋中', '晋中市', '中国,山西省,晋中市', 2, 'jinzhong', '0354', '030600', 'J', '112.736465', '37.696495'),
+(279, 278, '榆次', '榆次区', '中国,山西省,晋中市,榆次区', 3, 'yuci', '0354', '030600', 'Y', '112.70788', '37.6978'),
+(280, 278, '榆社', '榆社县', '中国,山西省,晋中市,榆社县', 3, 'yushe', '0354', '031800', 'Y', '112.97558', '37.0721'),
+(281, 278, '左权', '左权县', '中国,山西省,晋中市,左权县', 3, 'zuoquan', '0354', '032600', 'Z', '113.37918', '37.08235'),
+(282, 278, '和顺', '和顺县', '中国,山西省,晋中市,和顺县', 3, 'heshun', '0354', '032700', 'H', '113.56988', '37.32963'),
+(283, 278, '昔阳', '昔阳县', '中国,山西省,晋中市,昔阳县', 3, 'xiyang', '0354', '045300', 'X', '113.70517', '37.61863'),
+(284, 278, '寿阳', '寿阳县', '中国,山西省,晋中市,寿阳县', 3, 'shouyang', '0354', '045400', 'S', '113.17495', '37.88899'),
+(285, 278, '太谷', '太谷县', '中国,山西省,晋中市,太谷县', 3, 'taigu', '0354', '030800', 'T', '112.55246', '37.42161'),
+(286, 278, '祁县', '祁县', '中国,山西省,晋中市,祁县', 3, 'qixian', '0354', '030900', 'Q', '112.33358', '37.3579'),
+(287, 278, '平遥', '平遥县', '中国,山西省,晋中市,平遥县', 3, 'pingyao', '0354', '031100', 'P', '112.17553', '37.1892'),
+(288, 278, '灵石', '灵石县', '中国,山西省,晋中市,灵石县', 3, 'lingshi', '0354', '031300', 'L', '111.7774', '36.84814'),
+(289, 278, '介休', '介休市', '中国,山西省,晋中市,介休市', 3, 'jiexiu', '0354', '032000', 'J', '111.91824', '37.02771'),
+(290, 220, '运城', '运城市', '中国,山西省,运城市', 2, 'yuncheng', '0359', '044000', 'Y', '111.003957', '35.022778'),
+(291, 290, '盐湖', '盐湖区', '中国,山西省,运城市,盐湖区', 3, 'yanhu', '0359', '044000', 'Y', '110.99827', '35.0151'),
+(292, 290, '临猗', '临猗县', '中国,山西省,运城市,临猗县', 3, 'linyi', '0359', '044100', 'L', '110.77432', '35.14455'),
+(293, 290, '万荣', '万荣县', '中国,山西省,运城市,万荣县', 3, 'wanrong', '0359', '044200', 'W', '110.83657', '35.41556'),
+(294, 290, '闻喜', '闻喜县', '中国,山西省,运城市,闻喜县', 3, 'wenxi', '0359', '043800', 'W', '111.22265', '35.35553'),
+(295, 290, '稷山', '稷山县', '中国,山西省,运城市,稷山县', 3, 'jishan', '0359', '043200', NULL, '110.97924', '35.59993'),
+(296, 290, '新绛', '新绛县', '中国,山西省,运城市,新绛县', 3, 'xinjiang', '0359', '043100', 'X', '111.22509', '35.61566'),
+(297, 290, '绛县', '绛县', '中国,山西省,运城市,绛县', 3, 'jiangxian', '0359', '043600', NULL, '111.56668', '35.49096'),
+(298, 290, '垣曲', '垣曲县', '中国,山西省,运城市,垣曲县', 3, 'yuanqu', '0359', '043700', 'Y', '111.67166', '35.29923'),
+(299, 290, '夏县', '夏县', '中国,山西省,运城市,夏县', 3, 'xiaxian', '0359', '044400', 'X', '111.21966', '35.14121'),
+(300, 290, '平陆', '平陆县', '中国,山西省,运城市,平陆县', 3, 'pinglu', '0359', '044300', 'P', '111.21704', '34.83772'),
+(301, 290, '芮城', '芮城县', '中国,山西省,运城市,芮城县', 3, 'ruicheng', '0359', '044600', NULL, '110.69455', '34.69384'),
+(302, 290, '永济', '永济市', '中国,山西省,运城市,永济市', 3, 'yongji', '0359', '044500', 'Y', '110.44537', '34.86556'),
+(303, 290, '河津', '河津市', '中国,山西省,运城市,河津市', 3, 'hejin', '0359', '043300', 'H', '110.7116', '35.59478'),
+(304, 220, '忻州', '忻州市', '中国,山西省,忻州市', 2, 'xinzhou', '0350', '034000', 'X', '112.733538', '38.41769'),
+(305, 304, '忻府', '忻府区', '中国,山西省,忻州市,忻府区', 3, 'xinfu', '0350', '034000', 'X', '112.74603', '38.40414'),
+(306, 304, '定襄', '定襄县', '中国,山西省,忻州市,定襄县', 3, 'dingxiang', '0350', '035400', 'D', '112.95733', '38.47387'),
+(307, 304, '五台', '五台县', '中国,山西省,忻州市,五台县', 3, 'wutai', '0350', '035500', 'W', '113.25256', '38.72774'),
+(308, 304, '代县', '代县', '中国,山西省,忻州市,代县', 3, 'daixian', '0350', '034200', 'D', '112.95913', '39.06717'),
+(309, 304, '繁峙', '繁峙县', '中国,山西省,忻州市,繁峙县', 3, 'fanshi', '0350', '034300', 'F', '113.26303', '39.18886'),
+(310, 304, '宁武', '宁武县', '中国,山西省,忻州市,宁武县', 3, 'ningwu', '0350', '036700', 'N', '112.30423', '39.00211'),
+(311, 304, '静乐', '静乐县', '中国,山西省,忻州市,静乐县', 3, 'jingle', '0350', '035100', 'J', '111.94158', '38.3602'),
+(312, 304, '神池', '神池县', '中国,山西省,忻州市,神池县', 3, 'shenchi', '0350', '036100', 'S', '112.20541', '39.09'),
+(313, 304, '五寨', '五寨县', '中国,山西省,忻州市,五寨县', 3, 'wuzhai', '0350', '036200', 'W', '111.8489', '38.90757'),
+(314, 304, '岢岚', '岢岚县', '中国,山西省,忻州市,岢岚县', 3, 'kelan', '0350', '036300', NULL, '111.57388', '38.70452'),
+(315, 304, '河曲', '河曲县', '中国,山西省,忻州市,河曲县', 3, 'hequ', '0350', '036500', 'H', '111.13821', '39.38439'),
+(316, 304, '保德', '保德县', '中国,山西省,忻州市,保德县', 3, 'baode', '0350', '036600', 'B', '111.08656', '39.02248'),
+(317, 304, '偏关', '偏关县', '中国,山西省,忻州市,偏关县', 3, 'pianguan', '0350', '036400', 'P', '111.50863', '39.43609'),
+(318, 304, '原平', '原平市', '中国,山西省,忻州市,原平市', 3, 'yuanping', '0350', '034100', 'Y', '112.70584', '38.73181'),
+(319, 220, '临汾', '临汾市', '中国,山西省,临汾市', 2, 'linfen', '0357', '041000', 'L', '111.517973', '36.08415'),
+(320, 319, '尧都', '尧都区', '中国,山西省,临汾市,尧都区', 3, 'yaodu', '0357', '041000', 'Y', '111.5787', '36.08298'),
+(321, 319, '曲沃', '曲沃县', '中国,山西省,临汾市,曲沃县', 3, 'quwo', '0357', '043400', 'Q', '111.47525', '35.64119'),
+(322, 319, '翼城', '翼城县', '中国,山西省,临汾市,翼城县', 3, 'yicheng', '0357', '043500', 'Y', '111.7181', '35.73881'),
+(323, 319, '襄汾', '襄汾县', '中国,山西省,临汾市,襄汾县', 3, 'xiangfen', '0357', '041500', 'X', '111.44204', '35.87711'),
+(324, 319, '洪洞', '洪洞县', '中国,山西省,临汾市,洪洞县', 3, 'hongtong', '0357', '041600', 'H', '111.67501', '36.25425'),
+(325, 319, '古县', '古县', '中国,山西省,临汾市,古县', 3, 'guxian', '0357', '042400', 'G', '111.92041', '36.26688'),
+(326, 319, '安泽', '安泽县', '中国,山西省,临汾市,安泽县', 3, 'anze', '0357', '042500', 'A', '112.24981', '36.14803'),
+(327, 319, '浮山', '浮山县', '中国,山西省,临汾市,浮山县', 3, 'fushan', '0357', '042600', 'F', '111.84744', '35.96854'),
+(328, 319, '吉县', '吉县', '中国,山西省,临汾市,吉县', 3, 'jixian', '0357', '042200', 'J', '110.68148', '36.09873'),
+(329, 319, '乡宁', '乡宁县', '中国,山西省,临汾市,乡宁县', 3, 'xiangning', '0357', '042100', 'X', '110.84652', '35.97072'),
+(330, 319, '大宁', '大宁县', '中国,山西省,临汾市,大宁县', 3, 'daning', '0357', '042300', 'D', '110.75216', '36.46624'),
+(331, 319, '隰县', '隰县', '中国,山西省,临汾市,隰县', 3, 'xixian', '0357', '041300', NULL, '110.93881', '36.69258'),
+(332, 319, '永和', '永和县', '中国,山西省,临汾市,永和县', 3, 'yonghe', '0357', '041400', 'Y', '110.63168', '36.7584'),
+(333, 319, '蒲县', '蒲县', '中国,山西省,临汾市,蒲县', 3, 'puxian', '0357', '041200', 'P', '111.09674', '36.41243'),
+(334, 319, '汾西', '汾西县', '中国,山西省,临汾市,汾西县', 3, 'fenxi', '0357', '031500', 'F', '111.56811', '36.65063'),
+(335, 319, '侯马', '侯马市', '中国,山西省,临汾市,侯马市', 3, 'houma', '0357', '043000', 'H', '111.37207', '35.61903'),
+(336, 319, '霍州', '霍州市', '中国,山西省,临汾市,霍州市', 3, 'huozhou', '0357', '031400', 'H', '111.755', '36.5638'),
+(337, 220, '吕梁', '吕梁市', '中国,山西省,吕梁市', 2, 'lvliang', '0358', '033000', 'L', '111.134335', '37.524366'),
+(338, 337, '离石', '离石区', '中国,山西省,吕梁市,离石区', 3, 'lishi', '0358', '033000', 'L', '111.15059', '37.5177'),
+(339, 337, '文水', '文水县', '中国,山西省,吕梁市,文水县', 3, 'wenshui', '0358', '032100', 'W', '112.02829', '37.43841'),
+(340, 337, '交城', '交城县', '中国,山西省,吕梁市,交城县', 3, 'jiaocheng', '0358', '030500', 'J', '112.1585', '37.5512'),
+(341, 337, '兴县', '兴县', '中国,山西省,吕梁市,兴县', 3, 'xingxian', '0358', '033600', 'X', '111.12692', '38.46321'),
+(342, 337, '临县', '临县', '中国,山西省,吕梁市,临县', 3, 'linxian', '0358', '033200', 'L', '110.99282', '37.95271'),
+(343, 337, '柳林', '柳林县', '中国,山西省,吕梁市,柳林县', 3, 'liulin', '0358', '033300', 'L', '110.88922', '37.42932'),
+(344, 337, '石楼', '石楼县', '中国,山西省,吕梁市,石楼县', 3, 'shilou', '0358', '032500', 'S', '110.8352', '36.99731'),
+(345, 337, '岚县', '岚县', '中国,山西省,吕梁市,岚县', 3, 'lanxian', '0358', '033500', NULL, '111.67627', '38.27874'),
+(346, 337, '方山', '方山县', '中国,山西省,吕梁市,方山县', 3, 'fangshan', '0358', '033100', 'F', '111.24011', '37.88979'),
+(347, 337, '中阳', '中阳县', '中国,山西省,吕梁市,中阳县', 3, 'zhongyang', '0358', '033400', 'Z', '111.1795', '37.35715'),
+(348, 337, '交口', '交口县', '中国,山西省,吕梁市,交口县', 3, 'jiaokou', '0358', '032400', 'J', '111.18103', '36.98213'),
+(349, 337, '孝义', '孝义市', '中国,山西省,吕梁市,孝义市', 3, 'xiaoyi', '0358', '032300', 'X', '111.77362', '37.14414'),
+(350, 337, '汾阳', '汾阳市', '中国,山西省,吕梁市,汾阳市', 3, 'fenyang', '0358', '032200', 'F', '111.7882', '37.26605'),
+(351, 0, '内蒙古', '内蒙古自治区', '中国,内蒙古自治区', 1, 'innermongolia', '', '', 'N', '111.670801', '40.818311'),
+(352, 351, '呼和浩特', '呼和浩特市', '中国,内蒙古自治区,呼和浩特市', 2, 'hohhot', '0471', '010000', 'H', '111.670801', '40.818311'),
+(353, 352, '新城', '新城区', '中国,内蒙古自治区,呼和浩特市,新城区', 3, 'xincheng', '0471', '010050', 'X', '111.66554', '40.85828'),
+(354, 352, '回民', '回民区', '中国,内蒙古自治区,呼和浩特市,回民区', 3, 'huimin', '0471', '010030', 'H', '111.62402', '40.80827'),
+(355, 352, '玉泉', '玉泉区', '中国,内蒙古自治区,呼和浩特市,玉泉区', 3, 'yuquan', '0471', '010020', 'Y', '111.67456', '40.75227'),
+(356, 352, '赛罕', '赛罕区', '中国,内蒙古自治区,呼和浩特市,赛罕区', 3, 'saihan', '0471', '010020', 'S', '111.70224', '40.79207'),
+(357, 352, '土默特左旗', '土默特左旗', '中国,内蒙古自治区,呼和浩特市,土默特左旗', 3, 'tumotezuoqi', '0471', '010100', 'T', '111.14898', '40.72229'),
+(358, 352, '托克托', '托克托县', '中国,内蒙古自治区,呼和浩特市,托克托县', 3, 'tuoketuo', '0471', '010200', 'T', '111.19101', '40.27492'),
+(359, 352, '和林格尔', '和林格尔县', '中国,内蒙古自治区,呼和浩特市,和林格尔县', 3, 'helingeer', '0471', '011500', 'H', '111.82205', '40.37892'),
+(360, 352, '清水河', '清水河县', '中国,内蒙古自治区,呼和浩特市,清水河县', 3, 'qingshuihe', '0471', '011600', 'Q', '111.68316', '39.9097'),
+(361, 352, '武川', '武川县', '中国,内蒙古自治区,呼和浩特市,武川县', 3, 'wuchuan', '0471', '011700', 'W', '111.45785', '41.09289'),
+(362, 351, '包头', '包头市', '中国,内蒙古自治区,包头市', 2, 'baotou', '0472', '014025', 'B', '109.840405', '40.658168'),
+(363, 362, '东河', '东河区', '中国,内蒙古自治区,包头市,东河区', 3, 'donghe', '0472', '014040', 'D', '110.0462', '40.58237'),
+(364, 362, '昆都仑', '昆都仑区', '中国,内蒙古自治区,包头市,昆都仑区', 3, 'kundulun', '0472', '014010', 'K', '109.83862', '40.64175'),
+(365, 362, '青山', '青山区', '中国,内蒙古自治区,包头市,青山区', 3, 'qingshan', '0472', '014030', 'Q', '109.90131', '40.64329'),
+(366, 362, '石拐', '石拐区', '中国,内蒙古自治区,包头市,石拐区', 3, 'shiguai', '0472', '014070', 'S', '110.27322', '40.67297'),
+(367, 362, '白云鄂博矿区', '白云鄂博矿区', '中国,内蒙古自治区,包头市,白云鄂博矿区', 3, 'baiyunebokuangqu', '0472', '014080', 'B', '109.97367', '41.76968'),
+(368, 362, '九原', '九原区', '中国,内蒙古自治区,包头市,九原区', 3, 'jiuyuan', '0472', '014060', 'J', '109.96496', '40.60554'),
+(369, 362, '土默特右旗', '土默特右旗', '中国,内蒙古自治区,包头市,土默特右旗', 3, 'tumoteyouqi', '0472', '014100', 'T', '110.52417', '40.5688'),
+(370, 362, '固阳', '固阳县', '中国,内蒙古自治区,包头市,固阳县', 3, 'guyang', '0472', '014200', 'G', '110.06372', '41.01851'),
+(371, 362, '达茂旗', '达尔罕茂明安联合旗', '中国,内蒙古自治区,包头市,达尔罕茂明安联合旗', 3, 'damaoqi', '0472', '014500', 'D', '110.43258', '41.69875'),
+(372, 351, '乌海', '乌海市', '中国,内蒙古自治区,乌海市', 2, 'wuhai', '0473', '016000', 'W', '106.825563', '39.673734'),
+(373, 372, '海勃湾', '海勃湾区', '中国,内蒙古自治区,乌海市,海勃湾区', 3, 'haibowan', '0473', '016000', 'H', '106.8222', '39.66955'),
+(374, 372, '海南', '海南区', '中国,内蒙古自治区,乌海市,海南区', 3, 'hainan', '0473', '016030', 'H', '106.88656', '39.44128'),
+(375, 372, '乌达', '乌达区', '中国,内蒙古自治区,乌海市,乌达区', 3, 'wuda', '0473', '016040', 'W', '106.72723', '39.505'),
+(376, 351, '赤峰', '赤峰市', '中国,内蒙古自治区,赤峰市', 2, 'chifeng', '0476', '024000', 'C', '118.956806', '42.275317'),
+(377, 376, '红山', '红山区', '中国,内蒙古自治区,赤峰市,红山区', 3, 'hongshan', '0476', '024020', 'H', '118.95755', '42.24312'),
+(378, 376, '元宝山', '元宝山区', '中国,内蒙古自治区,赤峰市,元宝山区', 3, 'yuanbaoshan', '0476', '024076', 'Y', '119.28921', '42.04005'),
+(379, 376, '松山', '松山区', '中国,内蒙古自治区,赤峰市,松山区', 3, 'songshan', '0476', '024005', 'S', '118.9328', '42.28613'),
+(380, 376, '阿鲁科尔沁旗', '阿鲁科尔沁旗', '中国,内蒙古自治区,赤峰市,阿鲁科尔沁旗', 3, 'alukeerqinqi', '0476', '025550', 'A', '120.06527', '43.87988'),
+(381, 376, '巴林左旗', '巴林左旗', '中国,内蒙古自治区,赤峰市,巴林左旗', 3, 'balinzuoqi', '0476', '025450', 'B', '119.38012', '43.97031'),
+(382, 376, '巴林右旗', '巴林右旗', '中国,内蒙古自治区,赤峰市,巴林右旗', 3, 'balinyouqi', '0476', '025150', 'B', '118.66461', '43.53387'),
+(383, 376, '林西', '林西县', '中国,内蒙古自治区,赤峰市,林西县', 3, 'linxi', '0476', '025250', 'L', '118.04733', '43.61165'),
+(384, 376, '克什克腾旗', '克什克腾旗', '中国,内蒙古自治区,赤峰市,克什克腾旗', 3, 'keshiketengqi', '0476', '025350', 'K', '117.54562', '43.26501'),
+(385, 376, '翁牛特旗', '翁牛特旗', '中国,内蒙古自治区,赤峰市,翁牛特旗', 3, 'wengniuteqi', '0476', '024500', 'W', '119.03042', '42.93147'),
+(386, 376, '喀喇沁旗', '喀喇沁旗', '中国,内蒙古自治区,赤峰市,喀喇沁旗', 3, 'kalaqinqi', '0476', '024400', 'K', '118.70144', '41.92917'),
+(387, 376, '宁城', '宁城县', '中国,内蒙古自治区,赤峰市,宁城县', 3, 'ningcheng', '0476', '024200', 'N', '119.34375', '41.59661'),
+(388, 376, '敖汉旗', '敖汉旗', '中国,内蒙古自治区,赤峰市,敖汉旗', 3, 'aohanqi', '0476', '024300', 'A', '119.92163', '42.29071'),
+(389, 351, '通辽', '通辽市', '中国,内蒙古自治区,通辽市', 2, 'tongliao', '0475', '028000', 'T', '122.263119', '43.617429'),
+(390, 389, '科尔沁', '科尔沁区', '中国,内蒙古自治区,通辽市,科尔沁区', 3, 'keerqin', '0475', '028000', 'K', '122.25573', '43.62257'),
+(391, 389, '科尔沁左翼中旗', '科尔沁左翼中旗', '中国,内蒙古自治区,通辽市,科尔沁左翼中旗', 3, 'keerqinzuoyizhongqi', '0475', '029300', 'K', '123.31912', '44.13014'),
+(392, 389, '科尔沁左翼后旗', '科尔沁左翼后旗', '中国,内蒙古自治区,通辽市,科尔沁左翼后旗', 3, 'keerqinzuoyihouqi', '0475', '028100', 'K', '122.35745', '42.94897'),
+(393, 389, '开鲁', '开鲁县', '中国,内蒙古自治区,通辽市,开鲁县', 3, 'kailu', '0475', '028400', 'K', '121.31884', '43.60003'),
+(394, 389, '库伦旗', '库伦旗', '中国,内蒙古自治区,通辽市,库伦旗', 3, 'kulunqi', '0475', '028200', 'K', '121.776', '42.72998'),
+(395, 389, '奈曼旗', '奈曼旗', '中国,内蒙古自治区,通辽市,奈曼旗', 3, 'naimanqi', '0475', '028300', 'N', '120.66348', '42.84527'),
+(396, 389, '扎鲁特旗', '扎鲁特旗', '中国,内蒙古自治区,通辽市,扎鲁特旗', 3, 'zhaluteqi', '0475', '029100', 'Z', '120.91507', '44.55592'),
+(397, 389, '霍林郭勒', '霍林郭勒市', '中国,内蒙古自治区,通辽市,霍林郭勒市', 3, 'huolinguole', '0475', '029200', 'H', '119.65429', '45.53454'),
+(398, 351, '鄂尔多斯', '鄂尔多斯市', '中国,内蒙古自治区,鄂尔多斯市', 2, 'ordos', '0477', '017004', 'E', '109.99029', '39.817179'),
+(399, 398, '东胜', '东胜区', '中国,内蒙古自治区,鄂尔多斯市,东胜区', 3, 'dongsheng', '0477', '017000', 'D', '109.96289', '39.82236'),
+(400, 398, '达拉特旗', '达拉特旗', '中国,内蒙古自治区,鄂尔多斯市,达拉特旗', 3, 'dalateqi', '0477', '014300', 'D', '110.03317', '40.4001'),
+(401, 398, '准格尔旗', '准格尔旗', '中国,内蒙古自治区,鄂尔多斯市,准格尔旗', 3, 'zhungeerqi', '0477', '017100', 'Z', '111.23645', '39.86783'),
+(402, 398, '鄂托克前旗', '鄂托克前旗', '中国,内蒙古自治区,鄂尔多斯市,鄂托克前旗', 3, 'etuokeqianqi', '0477', '016200', 'E', '107.48403', '38.18396'),
+(403, 398, '鄂托克旗', '鄂托克旗', '中国,内蒙古自治区,鄂尔多斯市,鄂托克旗', 3, 'etuokeqi', '0477', '016100', 'E', '107.98226', '39.09456'),
+(404, 398, '杭锦旗', '杭锦旗', '中国,内蒙古自治区,鄂尔多斯市,杭锦旗', 3, 'hangjinqi', '0477', '017400', 'H', '108.72934', '39.84023'),
+(405, 398, '乌审旗', '乌审旗', '中国,内蒙古自治区,鄂尔多斯市,乌审旗', 3, 'wushenqi', '0477', '017300', 'W', '108.8461', '38.59092'),
+(406, 398, '伊金霍洛旗', '伊金霍洛旗', '中国,内蒙古自治区,鄂尔多斯市,伊金霍洛旗', 3, 'yijinhuoluoqi', '0477', '017200', 'Y', '109.74908', '39.57393'),
+(407, 351, '呼伦贝尔', '呼伦贝尔市', '中国,内蒙古自治区,呼伦贝尔市', 2, 'hulunber', '0470', '021008', 'H', '119.758168', '49.215333'),
+(408, 407, '海拉尔', '海拉尔区', '中国,内蒙古自治区,呼伦贝尔市,海拉尔区', 3, 'hailaer', '0470', '021000', 'H', '119.7364', '49.2122'),
+(409, 407, '扎赉诺尔', '扎赉诺尔区', '中国,内蒙古自治区,呼伦贝尔市,扎赉诺尔区', 3, 'zhalainuoer', '0470', '021410', 'Z', '117.792702', '49.486943'),
+(410, 407, '阿荣旗', '阿荣旗', '中国,内蒙古自治区,呼伦贝尔市,阿荣旗', 3, 'arongqi', '0470', '162750', 'A', '123.45941', '48.12581'),
+(411, 407, '莫旗', '莫力达瓦达斡尔族自治旗', '中国,内蒙古自治区,呼伦贝尔市,莫力达瓦达斡尔族自治旗', 3, 'moqi', '0470', '162850', 'M', '124.51498', '48.48055'),
+(412, 407, '鄂伦春', '鄂伦春自治旗', '中国,内蒙古自治区,呼伦贝尔市,鄂伦春自治旗', 3, 'elunchun', '0470', '165450', 'E', '123.72604', '50.59777'),
+(413, 407, '鄂温', '鄂温克族自治旗', '中国,内蒙古自治区,呼伦贝尔市,鄂温克族自治旗', 3, 'ewen', '0470', '021100', 'E', '119.7565', '49.14284'),
+(414, 407, '陈巴尔虎旗', '陈巴尔虎旗', '中国,内蒙古自治区,呼伦贝尔市,陈巴尔虎旗', 3, 'chenbaerhuqi', '0470', '021500', 'C', '119.42434', '49.32684'),
+(415, 407, '新巴尔虎左旗', '新巴尔虎左旗', '中国,内蒙古自治区,呼伦贝尔市,新巴尔虎左旗', 3, 'xinbaerhuzuoqi', '0470', '021200', 'X', '118.26989', '48.21842'),
+(416, 407, '新巴尔虎右旗', '新巴尔虎右旗', '中国,内蒙古自治区,呼伦贝尔市,新巴尔虎右旗', 3, 'xinbaerhuyouqi', '0470', '021300', 'X', '116.82366', '48.66473'),
+(417, 407, '满洲里', '满洲里市', '中国,内蒙古自治区,呼伦贝尔市,满洲里市', 3, 'manzhouli', '0470', '021400', 'M', '117.47946', '49.58272'),
+(418, 407, '牙克石', '牙克石市', '中国,内蒙古自治区,呼伦贝尔市,牙克石市', 3, 'yakeshi', '0470', '022150', 'Y', '120.7117', '49.2856'),
+(419, 407, '扎兰屯', '扎兰屯市', '中国,内蒙古自治区,呼伦贝尔市,扎兰屯市', 3, 'zhalantun', '0470', '162650', 'Z', '122.73757', '48.01363'),
+(420, 407, '额尔古纳', '额尔古纳市', '中国,内蒙古自治区,呼伦贝尔市,额尔古纳市', 3, 'eerguna', '0470', '022250', 'E', '120.19094', '50.24249'),
+(421, 407, '根河', '根河市', '中国,内蒙古自治区,呼伦贝尔市,根河市', 3, 'genhe', '0470', '022350', 'G', '121.52197', '50.77996'),
+(422, 351, '巴彦淖尔', '巴彦淖尔市', '中国,内蒙古自治区,巴彦淖尔市', 2, 'bayannur', '0478', '015001', 'B', '107.416959', '40.757402'),
+(423, 422, '临河', '临河区', '中国,内蒙古自治区,巴彦淖尔市,临河区', 3, 'linhe', '0478', '015001', 'L', '107.42668', '40.75827'),
+(424, 422, '五原', '五原县', '中国,内蒙古自治区,巴彦淖尔市,五原县', 3, 'wuyuan', '0478', '015100', 'W', '108.26916', '41.09631'),
+(425, 422, '磴口', '磴口县', '中国,内蒙古自治区,巴彦淖尔市,磴口县', 3, 'dengkou', '0478', '015200', NULL, '107.00936', '40.33062'),
+(426, 422, '乌拉特前旗', '乌拉特前旗', '中国,内蒙古自治区,巴彦淖尔市,乌拉特前旗', 3, 'wulateqianqi', '0478', '014400', 'W', '108.65219', '40.73649'),
+(427, 422, '乌拉特中旗', '乌拉特中旗', '中国,内蒙古自治区,巴彦淖尔市,乌拉特中旗', 3, 'wulatezhongqi', '0478', '015300', 'W', '108.52587', '41.56789'),
+(428, 422, '乌拉特后旗', '乌拉特后旗', '中国,内蒙古自治区,巴彦淖尔市,乌拉特后旗', 3, 'wulatehouqi', '0478', '015500', 'W', '106.98971', '41.43151'),
+(429, 422, '杭锦后旗', '杭锦后旗', '中国,内蒙古自治区,巴彦淖尔市,杭锦后旗', 3, 'hangjinhouqi', '0478', '015400', 'H', '107.15133', '40.88627'),
+(430, 351, '乌兰察布', '乌兰察布市', '中国,内蒙古自治区,乌兰察布市', 2, 'ulanqab', '0474', '012000', 'W', '113.114543', '41.034126'),
+(431, 430, '集宁', '集宁区', '中国,内蒙古自治区,乌兰察布市,集宁区', 3, 'jining', '0474', '012000', 'J', '113.11452', '41.0353'),
+(432, 430, '卓资', '卓资县', '中国,内蒙古自治区,乌兰察布市,卓资县', 3, 'zhuozi', '0474', '012300', 'Z', '112.57757', '40.89414'),
+(433, 430, '化德', '化德县', '中国,内蒙古自治区,乌兰察布市,化德县', 3, 'huade', '0474', '013350', 'H', '114.01071', '41.90433'),
+(434, 430, '商都', '商都县', '中国,内蒙古自治区,乌兰察布市,商都县', 3, 'shangdu', '0474', '013450', 'S', '113.57772', '41.56213'),
+(435, 430, '兴和', '兴和县', '中国,内蒙古自治区,乌兰察布市,兴和县', 3, 'xinghe', '0474', '013650', 'X', '113.83395', '40.87186'),
+(436, 430, '凉城', '凉城县', '中国,内蒙古自治区,乌兰察布市,凉城县', 3, 'liangcheng', '0474', '013750', 'L', '112.49569', '40.53346'),
+(437, 430, '察右前旗', '察哈尔右翼前旗', '中国,内蒙古自治区,乌兰察布市,察哈尔右翼前旗', 3, 'chayouqianqi', '0474', '012200', 'C', '113.22131', '40.7788'),
+(438, 430, '察右中旗', '察哈尔右翼中旗', '中国,内蒙古自治区,乌兰察布市,察哈尔右翼中旗', 3, 'chayouzhongqi', '0474', '013550', 'C', '112.63537', '41.27742'),
+(439, 430, '察右后旗', '察哈尔右翼后旗', '中国,内蒙古自治区,乌兰察布市,察哈尔右翼后旗', 3, 'chayouhouqi', '0474', '012400', 'C', '113.19216', '41.43554'),
+(440, 430, '四子王旗', '四子王旗', '中国,内蒙古自治区,乌兰察布市,四子王旗', 3, 'siziwangqi', '0474', '011800', 'S', '111.70654', '41.53312'),
+(441, 430, '丰镇', '丰镇市', '中国,内蒙古自治区,乌兰察布市,丰镇市', 3, 'fengzhen', '0474', '012100', 'F', '113.10983', '40.4369'),
+(442, 351, '兴安盟', '兴安盟', '中国,内蒙古自治区,兴安盟', 2, 'hinggan', '0482', '137401', 'X', '122.070317', '46.076268'),
+(443, 442, '乌兰浩特', '乌兰浩特市', '中国,内蒙古自治区,兴安盟,乌兰浩特市', 3, 'wulanhaote', '0482', '137401', 'W', '122.06378', '46.06235'),
+(444, 442, '阿尔山', '阿尔山市', '中国,内蒙古自治区,兴安盟,阿尔山市', 3, 'aershan', '0482', '137800', 'A', '119.94317', '47.17716'),
+(445, 442, '科右前旗', '科尔沁右翼前旗', '中国,内蒙古自治区,兴安盟,科尔沁右翼前旗', 3, 'keyouqianqi', '0482', '137423', 'K', '121.95269', '46.0795'),
+(446, 442, '科右中旗', '科尔沁右翼中旗', '中国,内蒙古自治区,兴安盟,科尔沁右翼中旗', 3, 'keyouzhongqi', '0482', '029400', 'K', '121.46807', '45.05605'),
+(447, 442, '扎赉特旗', '扎赉特旗', '中国,内蒙古自治区,兴安盟,扎赉特旗', 3, 'zhalaiteqi', '0482', '137600', 'Z', '122.91229', '46.7267'),
+(448, 442, '突泉', '突泉县', '中国,内蒙古自治区,兴安盟,突泉县', 3, 'tuquan', '0482', '137500', 'T', '121.59396', '45.38187'),
+(449, 351, '锡林郭勒盟', '锡林郭勒盟', '中国,内蒙古自治区,锡林郭勒盟', 2, 'xilingol', '0479', '026000', 'X', '116.090996', '43.944018'),
+(450, 449, '二连浩特', '二连浩特市', '中国,内蒙古自治区,锡林郭勒盟,二连浩特市', 3, 'erlianhaote', '0479', '011100', 'E', '111.98297', '43.65303'),
+(451, 449, '锡林浩特', '锡林浩特市', '中国,内蒙古自治区,锡林郭勒盟,锡林浩特市', 3, 'xilinhaote', '0479', '026021', 'X', '116.08603', '43.93341'),
+(452, 449, '阿巴嘎旗', '阿巴嘎旗', '中国,内蒙古自治区,锡林郭勒盟,阿巴嘎旗', 3, 'abagaqi', '0479', '011400', 'A', '114.96826', '44.02174'),
+(453, 449, '苏尼特左旗', '苏尼特左旗', '中国,内蒙古自治区,锡林郭勒盟,苏尼特左旗', 3, 'sunitezuoqi', '0479', '011300', 'S', '113.6506', '43.85687'),
+(454, 449, '苏尼特右旗', '苏尼特右旗', '中国,内蒙古自治区,锡林郭勒盟,苏尼特右旗', 3, 'suniteyouqi', '0479', '011200', 'S', '112.65741', '42.7469'),
+(455, 449, '东乌旗', '东乌珠穆沁旗', '中国,内蒙古自治区,锡林郭勒盟,东乌珠穆沁旗', 3, 'dongwuqi', '0479', '026300', 'D', '116.97293', '45.51108'),
+(456, 449, '西乌旗', '西乌珠穆沁旗', '中国,内蒙古自治区,锡林郭勒盟,西乌珠穆沁旗', 3, 'xiwuqi', '0479', '026200', 'X', '117.60983', '44.59623'),
+(457, 449, '太仆寺旗', '太仆寺旗', '中国,内蒙古自治区,锡林郭勒盟,太仆寺旗', 3, 'taipusiqi', '0479', '027000', 'T', '115.28302', '41.87727'),
+(458, 449, '镶黄旗', '镶黄旗', '中国,内蒙古自治区,锡林郭勒盟,镶黄旗', 3, 'xianghuangqi', '0479', '013250', 'X', '113.84472', '42.23927'),
+(459, 449, '正镶白旗', '正镶白旗', '中国,内蒙古自治区,锡林郭勒盟,正镶白旗', 3, 'zhengxiangbaiqi', '0479', '013800', 'Z', '115.00067', '42.30712'),
+(460, 449, '正蓝旗', '正蓝旗', '中国,内蒙古自治区,锡林郭勒盟,正蓝旗', 3, 'zhenglanqi', '0479', '027200', 'Z', '116.00363', '42.25229'),
+(461, 449, '多伦', '多伦县', '中国,内蒙古自治区,锡林郭勒盟,多伦县', 3, 'duolun', '0479', '027300', 'D', '116.48565', '42.203'),
+(462, 351, '阿拉善盟', '阿拉善盟', '中国,内蒙古自治区,阿拉善盟', 2, 'alxa', '0483', '750306', 'A', '105.706422', '38.844814'),
+(463, 462, '阿拉善左旗', '阿拉善左旗', '中国,内蒙古自治区,阿拉善盟,阿拉善左旗', 3, 'alashanzuoqi', '0483', '750306', 'A', '105.67532', '38.8293'),
+(464, 462, '阿拉善右旗', '阿拉善右旗', '中国,内蒙古自治区,阿拉善盟,阿拉善右旗', 3, 'alashanyouqi', '0483', '737300', 'A', '101.66705', '39.21533'),
+(465, 462, '额济纳旗', '额济纳旗', '中国,内蒙古自治区,阿拉善盟,额济纳旗', 3, 'ejinaqi', '0483', '735400', 'E', '101.06887', '41.96755'),
+(466, 0, '辽宁', '辽宁省', '中国,辽宁省', 1, 'liaoning', '', '', 'L', '123.429096', '41.796767'),
+(467, 466, '沈阳', '沈阳市', '中国,辽宁省,沈阳市', 2, 'shenyang', '024', '110013', 'S', '123.429096', '41.796767'),
+(468, 467, '和平', '和平区', '中国,辽宁省,沈阳市,和平区', 3, 'heping', '024', '110001', 'H', '123.4204', '41.78997'),
+(469, 467, '沈河', '沈河区', '中国,辽宁省,沈阳市,沈河区', 3, 'shenhe', '024', '110011', 'S', '123.45871', '41.79625'),
+(470, 467, '大东', '大东区', '中国,辽宁省,沈阳市,大东区', 3, 'dadong', '024', '110041', 'D', '123.46997', '41.80539'),
+(471, 467, '皇姑', '皇姑区', '中国,辽宁省,沈阳市,皇姑区', 3, 'huanggu', '024', '110031', 'H', '123.42527', '41.82035'),
+(472, 467, '铁西', '铁西区', '中国,辽宁省,沈阳市,铁西区', 3, 'tiexi', '024', '110021', 'T', '123.37675', '41.80269'),
+(473, 467, '苏家屯', '苏家屯区', '中国,辽宁省,沈阳市,苏家屯区', 3, 'sujiatun', '024', '110101', 'S', '123.34405', '41.66475'),
+(474, 467, '浑南', '浑南区', '中国,辽宁省,沈阳市,浑南区', 3, 'hunnan', '024', '110015', 'H', '123.457707', '41.719450'),
+(475, 467, '沈北新区', '沈北新区', '中国,辽宁省,沈阳市,沈北新区', 3, 'shenbeixinqu', '024', '110121', 'S', '123.52658', '42.05297'),
+(476, 467, '于洪', '于洪区', '中国,辽宁省,沈阳市,于洪区', 3, 'yuhong', '024', '110141', 'Y', '123.30807', '41.794'),
+(477, 467, '辽中', '辽中县', '中国,辽宁省,沈阳市,辽中县', 3, 'liaozhong', '024', '110200', 'L', '122.72659', '41.51302');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(478, 467, '康平', '康平县', '中国,辽宁省,沈阳市,康平县', 3, 'kangping', '024', '110500', 'K', '123.35446', '42.75081'),
+(479, 467, '法库', '法库县', '中国,辽宁省,沈阳市,法库县', 3, 'faku', '024', '110400', 'F', '123.41214', '42.50608'),
+(480, 467, '新民', '新民市', '中国,辽宁省,沈阳市,新民市', 3, 'xinmin', '024', '110300', 'X', '122.82867', '41.99847'),
+(481, 466, '大连', '大连市', '中国,辽宁省,大连市', 2, 'dalian', '0411', '116011', 'D', '121.618622', '38.91459'),
+(482, 481, '中山', '中山区', '中国,辽宁省,大连市,中山区', 3, 'zhongshan', '0411', '116001', 'Z', '121.64465', '38.91859'),
+(483, 481, '西岗', '西岗区', '中国,辽宁省,大连市,西岗区', 3, 'xigang', '0411', '116011', 'X', '121.61238', '38.91469'),
+(484, 481, '沙河口', '沙河口区', '中国,辽宁省,大连市,沙河口区', 3, 'shahekou', '0411', '116021', 'S', '121.58017', '38.90536'),
+(485, 481, '甘井子', '甘井子区', '中国,辽宁省,大连市,甘井子区', 3, 'ganjingzi', '0411', '116033', 'G', '121.56567', '38.95017'),
+(486, 481, '旅顺口', '旅顺口区', '中国,辽宁省,大连市,旅顺口区', 3, 'lvshunkou', '0411', '116041', 'L', '121.26202', '38.85125'),
+(487, 481, '金州', '金州区', '中国,辽宁省,大连市,金州区', 3, 'jinzhou', '0411', '116100', 'J', '121.71893', '39.1004'),
+(488, 481, '长海', '长海县', '中国,辽宁省,大连市,长海县', 3, 'changhai', '0411', '116500', 'C', '122.58859', '39.27274'),
+(489, 481, '瓦房店', '瓦房店市', '中国,辽宁省,大连市,瓦房店市', 3, 'wafangdian', '0411', '116300', 'W', '121.98104', '39.62843'),
+(490, 481, '普兰店', '普兰店市', '中国,辽宁省,大连市,普兰店市', 3, 'pulandian', '0411', '116200', 'P', '121.96316', '39.39465'),
+(491, 481, '庄河', '庄河市', '中国,辽宁省,大连市,庄河市', 3, 'zhuanghe', '0411', '116400', 'Z', '122.96725', '39.68815'),
+(492, 466, '鞍山', '鞍山市', '中国,辽宁省,鞍山市', 2, 'anshan', '0412', '114001', 'A', '122.995632', '41.110626'),
+(493, 492, '铁东', '铁东区', '中国,辽宁省,鞍山市,铁东区', 3, 'tiedong', '0412', '114001', 'T', '122.99085', '41.08975'),
+(494, 492, '铁西', '铁西区', '中国,辽宁省,鞍山市,铁西区', 3, 'tiexi', '0413', '114013', 'T', '122.96967', '41.11977'),
+(495, 492, '立山', '立山区', '中国,辽宁省,鞍山市,立山区', 3, 'lishan', '0414', '114031', 'L', '123.02948', '41.15008'),
+(496, 492, '千山', '千山区', '中国,辽宁省,鞍山市,千山区', 3, 'qianshan', '0415', '114041', 'Q', '122.96048', '41.07507'),
+(497, 492, '台安', '台安县', '中国,辽宁省,鞍山市,台安县', 3, 'tai''an', '0417', '114100', 'T', '122.43585', '41.41265'),
+(498, 492, '岫岩', '岫岩满族自治县', '中国,辽宁省,鞍山市,岫岩满族自治县', 3, 'xiuyan', '0418', '114300', NULL, '123.28875', '40.27996'),
+(499, 492, '海城', '海城市', '中国,辽宁省,鞍山市,海城市', 3, 'haicheng', '0416', '114200', 'H', '122.68457', '40.88142'),
+(500, 466, '抚顺', '抚顺市', '中国,辽宁省,抚顺市', 2, 'fushun', '024', '113008', 'F', '123.921109', '41.875956'),
+(501, 500, '新抚', '新抚区', '中国,辽宁省,抚顺市,新抚区', 3, 'xinfu', '024', '113008', 'X', '123.91264', '41.86205'),
+(502, 500, '东洲', '东洲区', '中国,辽宁省,抚顺市,东洲区', 3, 'dongzhou', '024', '113003', 'D', '124.03759', '41.8519'),
+(503, 500, '望花', '望花区', '中国,辽宁省,抚顺市,望花区', 3, 'wanghua', '024', '113001', 'W', '123.78283', '41.85532'),
+(504, 500, '顺城', '顺城区', '中国,辽宁省,抚顺市,顺城区', 3, 'shuncheng', '024', '113006', 'S', '123.94506', '41.88321'),
+(505, 500, '抚顺', '抚顺县', '中国,辽宁省,抚顺市,抚顺县', 3, 'fushun', '024', '113006', 'F', '124.17755', '41.71217'),
+(506, 500, '新宾', '新宾满族自治县', '中国,辽宁省,抚顺市,新宾满族自治县', 3, 'xinbin', '024', '113200', 'X', '125.04049', '41.73409'),
+(507, 500, '清原', '清原满族自治县', '中国,辽宁省,抚顺市,清原满族自治县', 3, 'qingyuan', '024', '113300', 'Q', '124.92807', '42.10221'),
+(508, 466, '本溪', '本溪市', '中国,辽宁省,本溪市', 2, 'benxi', '0414', '117000', 'B', '123.770519', '41.297909'),
+(509, 508, '平山', '平山区', '中国,辽宁省,本溪市,平山区', 3, 'pingshan', '0414', '117000', 'P', '123.76892', '41.2997'),
+(510, 508, '溪湖', '溪湖区', '中国,辽宁省,本溪市,溪湖区', 3, 'xihu', '0414', '117002', 'X', '123.76764', '41.32921'),
+(511, 508, '明山', '明山区', '中国,辽宁省,本溪市,明山区', 3, 'mingshan', '0414', '117021', 'M', '123.81746', '41.30827'),
+(512, 508, '南芬', '南芬区', '中国,辽宁省,本溪市,南芬区', 3, 'nanfen', '0414', '117014', 'N', '123.74523', '41.1006'),
+(513, 508, '本溪', '本溪满族自治县', '中国,辽宁省,本溪市,本溪满族自治县', 3, 'benxi', '0414', '117100', 'B', '124.12741', '41.30059'),
+(514, 508, '桓仁', '桓仁满族自治县', '中国,辽宁省,本溪市,桓仁满族自治县', 3, 'huanren', '0414', '117200', 'H', '125.36062', '41.26798'),
+(515, 466, '丹东', '丹东市', '中国,辽宁省,丹东市', 2, 'dandong', '0415', '118000', 'D', '124.383044', '40.124296'),
+(516, 515, '元宝', '元宝区', '中国,辽宁省,丹东市,元宝区', 3, 'yuanbao', '0415', '118000', 'Y', '124.39575', '40.13651'),
+(517, 515, '振兴', '振兴区', '中国,辽宁省,丹东市,振兴区', 3, 'zhenxing', '0415', '118002', 'Z', '124.36035', '40.10489'),
+(518, 515, '振安', '振安区', '中国,辽宁省,丹东市,振安区', 3, 'zhen''an', '0415', '118001', 'Z', '124.42816', '40.15826'),
+(519, 515, '宽甸', '宽甸满族自治县', '中国,辽宁省,丹东市,宽甸满族自治县', 3, 'kuandian', '0415', '118200', 'K', '124.78247', '40.73187'),
+(520, 515, '东港', '东港市', '中国,辽宁省,丹东市,东港市', 3, 'donggang', '0415', '118300', 'D', '124.16287', '39.86256'),
+(521, 515, '凤城', '凤城市', '中国,辽宁省,丹东市,凤城市', 3, 'fengcheng', '0415', '118100', 'F', '124.06671', '40.45302'),
+(522, 466, '锦州', '锦州市', '中国,辽宁省,锦州市', 2, 'jinzhou', '0416', '121000', 'J', '121.135742', '41.119269'),
+(523, 522, '古塔', '古塔区', '中国,辽宁省,锦州市,古塔区', 3, 'guta', '0416', '121001', 'G', '121.12832', '41.11725'),
+(524, 522, '凌河', '凌河区', '中国,辽宁省,锦州市,凌河区', 3, 'linghe', '0416', '121000', 'L', '121.15089', '41.11496'),
+(525, 522, '太和', '太和区', '中国,辽宁省,锦州市,太和区', 3, 'taihe', '0416', '121011', 'T', '121.10354', '41.10929'),
+(526, 522, '黑山', '黑山县', '中国,辽宁省,锦州市,黑山县', 3, 'heishan', '0416', '121400', 'H', '122.12081', '41.69417'),
+(527, 522, '义县', '义县', '中国,辽宁省,锦州市,义县', 3, 'yixian', '0416', '121100', 'Y', '121.24035', '41.53458'),
+(528, 522, '凌海', '凌海市', '中国,辽宁省,锦州市,凌海市', 3, 'linghai', '0416', '121200', 'L', '121.35705', '41.1737'),
+(529, 522, '北镇', '北镇市', '中国,辽宁省,锦州市,北镇市', 3, 'beizhen', '0416', '121300', 'B', '121.79858', '41.59537'),
+(530, 466, '营口', '营口市', '中国,辽宁省,营口市', 2, 'yingkou', '0417', '115003', 'Y', '122.235151', '40.667432'),
+(531, 530, '站前', '站前区', '中国,辽宁省,营口市,站前区', 3, 'zhanqian', '0417', '115002', 'Z', '122.25896', '40.67266'),
+(532, 530, '西市', '西市区', '中国,辽宁省,营口市,西市区', 3, 'xishi', '0417', '115004', 'X', '122.20641', '40.6664'),
+(533, 530, '鲅鱼圈', '鲅鱼圈区', '中国,辽宁省,营口市,鲅鱼圈区', 3, 'bayuquan', '0417', '115007', NULL, '122.13266', '40.26865'),
+(534, 530, '老边', '老边区', '中国,辽宁省,营口市,老边区', 3, 'laobian', '0417', '115005', 'L', '122.37996', '40.6803'),
+(535, 530, '盖州', '盖州市', '中国,辽宁省,营口市,盖州市', 3, 'gaizhou', '0417', '115200', 'G', '122.35464', '40.40446'),
+(536, 530, '大石桥', '大石桥市', '中国,辽宁省,营口市,大石桥市', 3, 'dashiqiao', '0417', '115100', 'D', '122.50927', '40.64567'),
+(537, 466, '阜新', '阜新市', '中国,辽宁省,阜新市', 2, 'fuxin', '0418', '123000', 'F', '121.648962', '42.011796'),
+(538, 537, '海州', '海州区', '中国,辽宁省,阜新市,海州区', 3, 'haizhou', '0418', '123000', 'H', '121.65626', '42.01336'),
+(539, 537, '新邱', '新邱区', '中国,辽宁省,阜新市,新邱区', 3, 'xinqiu', '0418', '123005', 'X', '121.79251', '42.09181'),
+(540, 537, '太平', '太平区', '中国,辽宁省,阜新市,太平区', 3, 'taiping', '0418', '123003', 'T', '121.67865', '42.01065'),
+(541, 537, '清河门', '清河门区', '中国,辽宁省,阜新市,清河门区', 3, 'qinghemen', '0418', '123006', 'Q', '121.4161', '41.78309'),
+(542, 537, '细河', '细河区', '中国,辽宁省,阜新市,细河区', 3, 'xihe', '0418', '123000', 'X', '121.68013', '42.02533'),
+(543, 537, '阜新', '阜新蒙古族自治县', '中国,辽宁省,阜新市,阜新蒙古族自治县', 3, 'fuxin', '0418', '123100', 'F', '121.75787', '42.0651'),
+(544, 537, '彰武', '彰武县', '中国,辽宁省,阜新市,彰武县', 3, 'zhangwu', '0418', '123200', 'Z', '122.54022', '42.38625'),
+(545, 466, '辽阳', '辽阳市', '中国,辽宁省,辽阳市', 2, 'liaoyang', '0419', '111000', 'L', '123.18152', '41.269402'),
+(546, 545, '白塔', '白塔区', '中国,辽宁省,辽阳市,白塔区', 3, 'baita', '0419', '111000', 'B', '123.1747', '41.27025'),
+(547, 545, '文圣', '文圣区', '中国,辽宁省,辽阳市,文圣区', 3, 'wensheng', '0419', '111000', 'W', '123.18521', '41.26267'),
+(548, 545, '宏伟', '宏伟区', '中国,辽宁省,辽阳市,宏伟区', 3, 'hongwei', '0419', '111003', 'H', '123.1929', '41.21852'),
+(549, 545, '弓长岭', '弓长岭区', '中国,辽宁省,辽阳市,弓长岭区', 3, 'gongchangling', '0419', '111008', 'G', '123.41963', '41.15181'),
+(550, 545, '太子河', '太子河区', '中国,辽宁省,辽阳市,太子河区', 3, 'taizihe', '0419', '111000', 'T', '123.18182', '41.25337'),
+(551, 545, '辽阳', '辽阳县', '中国,辽宁省,辽阳市,辽阳县', 3, 'liaoyang', '0419', '111200', 'L', '123.10574', '41.20542'),
+(552, 545, '灯塔', '灯塔市', '中国,辽宁省,辽阳市,灯塔市', 3, 'dengta', '0419', '111300', 'D', '123.33926', '41.42612'),
+(553, 466, '盘锦', '盘锦市', '中国,辽宁省,盘锦市', 2, 'panjin', '0427', '124010', 'P', '122.06957', '41.124484'),
+(554, 553, '双台子', '双台子区', '中国,辽宁省,盘锦市,双台子区', 3, 'shuangtaizi', '0427', '124000', 'S', '122.06011', '41.1906'),
+(555, 553, '兴隆台', '兴隆台区', '中国,辽宁省,盘锦市,兴隆台区', 3, 'xinglongtai', '0427', '124010', 'X', '122.07529', '41.12402'),
+(556, 553, '大洼', '大洼县', '中国,辽宁省,盘锦市,大洼县', 3, 'dawa', '0427', '124200', 'D', '122.08239', '41.00244'),
+(557, 553, '盘山', '盘山县', '中国,辽宁省,盘锦市,盘山县', 3, 'panshan', '0427', '124000', 'P', '121.99777', '41.23805'),
+(558, 466, '铁岭', '铁岭市', '中国,辽宁省,铁岭市', 2, 'tieling', '024', '112000', 'T', '123.844279', '42.290585'),
+(559, 558, '银州', '银州区', '中国,辽宁省,铁岭市,银州区', 3, 'yinzhou', '024', '112000', 'Y', '123.8573', '42.29507'),
+(560, 558, '清河', '清河区', '中国,辽宁省,铁岭市,清河区', 3, 'qinghe', '024', '112003', 'Q', '124.15911', '42.54679'),
+(561, 558, '铁岭', '铁岭县', '中国,辽宁省,铁岭市,铁岭县', 3, 'tieling', '024', '112000', 'T', '123.77325', '42.22498'),
+(562, 558, '西丰', '西丰县', '中国,辽宁省,铁岭市,西丰县', 3, 'xifeng', '024', '112400', 'X', '124.7304', '42.73756'),
+(563, 558, '昌图', '昌图县', '中国,辽宁省,铁岭市,昌图县', 3, 'changtu', '024', '112500', 'C', '124.11206', '42.78428'),
+(564, 558, '调兵山', '调兵山市', '中国,辽宁省,铁岭市,调兵山市', 3, 'diaobingshan', '024', '112700', 'D', '123.56689', '42.4675'),
+(565, 558, '开原', '开原市', '中国,辽宁省,铁岭市,开原市', 3, 'kaiyuan', '024', '112300', 'K', '124.03945', '42.54585'),
+(566, 466, '朝阳', '朝阳市', '中国,辽宁省,朝阳市', 2, 'chaoyang', '0421', '122000', 'C', '120.451176', '41.576758'),
+(567, 566, '双塔', '双塔区', '中国,辽宁省,朝阳市,双塔区', 3, 'shuangta', '0421', '122000', 'S', '120.45385', '41.566'),
+(568, 566, '龙城', '龙城区', '中国,辽宁省,朝阳市,龙城区', 3, 'longcheng', '0421', '122000', 'L', '120.43719', '41.59264'),
+(569, 566, '朝阳', '朝阳县', '中国,辽宁省,朝阳市,朝阳县', 3, 'chaoyang', '0421', '122000', 'C', '120.17401', '41.4324'),
+(570, 566, '建平', '建平县', '中国,辽宁省,朝阳市,建平县', 3, 'jianping', '0421', '122400', 'J', '119.64392', '41.40315'),
+(571, 566, '喀喇沁左翼', '喀喇沁左翼蒙古族自治县', '中国,辽宁省,朝阳市,喀喇沁左翼蒙古族自治县', 3, 'kalaqinzuoyi', '0421', '122300', 'K', '119.74185', '41.12801'),
+(572, 566, '北票', '北票市', '中国,辽宁省,朝阳市,北票市', 3, 'beipiao', '0421', '122100', 'B', '120.76977', '41.80196'),
+(573, 566, '凌源', '凌源市', '中国,辽宁省,朝阳市,凌源市', 3, 'lingyuan', '0421', '122500', 'L', '119.40148', '41.24558'),
+(574, 466, '葫芦岛', '葫芦岛市', '中国,辽宁省,葫芦岛市', 2, 'huludao', '0429', '125000', 'H', '120.856394', '40.755572'),
+(575, 574, '连山', '连山区', '中国,辽宁省,葫芦岛市,连山区', 3, 'lianshan', '0429', '125001', 'L', '120.86393', '40.75554'),
+(576, 574, '龙港', '龙港区', '中国,辽宁省,葫芦岛市,龙港区', 3, 'longgang', '0429', '125003', 'L', '120.94866', '40.71919'),
+(577, 574, '南票', '南票区', '中国,辽宁省,葫芦岛市,南票区', 3, 'nanpiao', '0429', '125027', 'N', '120.74978', '41.10707'),
+(578, 574, '绥中', '绥中县', '中国,辽宁省,葫芦岛市,绥中县', 3, 'suizhong', '0429', '125200', 'S', '120.34451', '40.32552'),
+(579, 574, '建昌', '建昌县', '中国,辽宁省,葫芦岛市,建昌县', 3, 'jianchang', '0429', '125300', 'J', '119.8377', '40.82448'),
+(580, 574, '兴城', '兴城市', '中国,辽宁省,葫芦岛市,兴城市', 3, 'xingcheng', '0429', '125100', 'X', '120.72537', '40.61492'),
+(581, 466, '金普新区', '金普新区', '中国,辽宁省,金普新区', 2, 'jinpuxinqu', '0411', '116100', 'J', '121.789627', '39.055451'),
+(582, 581, '金州新区', '金州新区', '中国,辽宁省,金普新区,金州新区', 3, 'jinzhouxinqu', '0411', '116100', 'J', '121.784821', '39.052252'),
+(583, 581, '普湾新区', '普湾新区', '中国,辽宁省,金普新区,普湾新区', 3, 'puwanxinqu', '0411', '116200', 'P', '121.812812', '39.330093'),
+(584, 581, '保税区', '保税区', '中国,辽宁省,金普新区,保税区', 3, 'baoshuiqu', '0411', '116100', 'B', '121.94289', '39.224614'),
+(585, 0, '吉林', '吉林省', '中国,吉林省', 1, 'jilin', '', '', 'J', '125.3245', '43.886841'),
+(586, 585, '长春', '长春市', '中国,吉林省,长春市', 2, 'changchun', '0431', '130022', 'C', '125.3245', '43.886841'),
+(587, 586, '南关', '南关区', '中国,吉林省,长春市,南关区', 3, 'nanguan', '0431', '130022', 'N', '125.35035', '43.86401'),
+(588, 586, '宽城', '宽城区', '中国,吉林省,长春市,宽城区', 3, 'kuancheng', '0431', '130051', 'K', '125.32635', '43.90182'),
+(589, 586, '朝阳', '朝阳区', '中国,吉林省,长春市,朝阳区', 3, 'chaoyang', '0431', '130012', 'C', '125.2883', '43.83339'),
+(590, 586, '二道', '二道区', '中国,吉林省,长春市,二道区', 3, 'erdao', '0431', '130031', 'E', '125.37429', '43.86501'),
+(591, 586, '绿园', '绿园区', '中国,吉林省,长春市,绿园区', 3, 'lvyuan', '0431', '130062', 'L', '125.25582', '43.88045'),
+(592, 586, '双阳', '双阳区', '中国,吉林省,长春市,双阳区', 3, 'shuangyang', '0431', '130600', 'S', '125.65631', '43.52803'),
+(593, 586, '九台', '九台区', '中国,吉林省,长春市,九台区', 3, 'jiutai', '0431', '130500', 'J', '125.8395', '44.15163'),
+(594, 586, '农安', '农安县', '中国,吉林省,长春市,农安县', 3, 'nong''an', '0431', '130200', 'N', '125.18481', '44.43265'),
+(595, 586, '榆树', '榆树市', '中国,吉林省,长春市,榆树市', 3, 'yushu', '0431', '130400', 'Y', '126.55688', '44.82523'),
+(596, 586, '德惠', '德惠市', '中国,吉林省,长春市,德惠市', 3, 'dehui', '0431', '130300', 'D', '125.70538', '44.53719'),
+(597, 585, '吉林', '吉林市', '中国,吉林省,吉林市', 2, 'jilin', '0432', '132011', 'J', '126.55302', '43.843577'),
+(598, 597, '昌邑', '昌邑区', '中国,吉林省,吉林市,昌邑区', 3, 'changyi', '0432', '132002', 'C', '126.57424', '43.88183'),
+(599, 597, '龙潭', '龙潭区', '中国,吉林省,吉林市,龙潭区', 3, 'longtan', '0432', '132021', 'L', '126.56213', '43.91054'),
+(600, 597, '船营', '船营区', '中国,吉林省,吉林市,船营区', 3, 'chuanying', '0432', '132011', 'C', '126.54096', '43.83344'),
+(601, 597, '丰满', '丰满区', '中国,吉林省,吉林市,丰满区', 3, 'fengman', '0432', '132013', 'F', '126.56237', '43.82236'),
+(602, 597, '永吉', '永吉县', '中国,吉林省,吉林市,永吉县', 3, 'yongji', '0432', '132200', 'Y', '126.4963', '43.67197'),
+(603, 597, '蛟河', '蛟河市', '中国,吉林省,吉林市,蛟河市', 3, 'jiaohe', '0432', '132500', NULL, '127.34426', '43.72696'),
+(604, 597, '桦甸', '桦甸市', '中国,吉林省,吉林市,桦甸市', 3, 'huadian', '0432', '132400', NULL, '126.74624', '42.97206'),
+(605, 597, '舒兰', '舒兰市', '中国,吉林省,吉林市,舒兰市', 3, 'shulan', '0432', '132600', 'S', '126.9653', '44.40582'),
+(606, 597, '磐石', '磐石市', '中国,吉林省,吉林市,磐石市', 3, 'panshi', '0432', '132300', 'P', '126.0625', '42.94628'),
+(607, 585, '四平', '四平市', '中国,吉林省,四平市', 2, 'siping', '0434', '136000', 'S', '124.370785', '43.170344'),
+(608, 607, '铁西', '铁西区', '中国,吉林省,四平市,铁西区', 3, 'tiexi', '0434', '136000', 'T', '124.37369', '43.17456'),
+(609, 607, '铁东', '铁东区', '中国,吉林省,四平市,铁东区', 3, 'tiedong', '0434', '136001', 'T', '124.40976', '43.16241'),
+(610, 607, '梨树', '梨树县', '中国,吉林省,四平市,梨树县', 3, 'lishu', '0434', '136500', 'L', '124.33563', '43.30717'),
+(611, 607, '伊通', '伊通满族自治县', '中国,吉林省,四平市,伊通满族自治县', 3, 'yitong', '0434', '130700', 'Y', '125.30596', '43.34434'),
+(612, 607, '公主岭', '公主岭市', '中国,吉林省,四平市,公主岭市', 3, 'gongzhuling', '0434', '136100', 'G', '124.82266', '43.50453'),
+(613, 607, '双辽', '双辽市', '中国,吉林省,四平市,双辽市', 3, 'shuangliao', '0434', '136400', 'S', '123.50106', '43.52099'),
+(614, 585, '辽源', '辽源市', '中国,吉林省,辽源市', 2, 'liaoyuan', '0437', '136200', 'L', '125.145349', '42.902692'),
+(615, 614, '龙山', '龙山区', '中国,吉林省,辽源市,龙山区', 3, 'longshan', '0437', '136200', 'L', '125.13641', '42.89714'),
+(616, 614, '西安', '西安区', '中国,吉林省,辽源市,西安区', 3, 'xi''an', '0437', '136201', 'X', '125.14904', '42.927'),
+(617, 614, '东丰', '东丰县', '中国,吉林省,辽源市,东丰县', 3, 'dongfeng', '0437', '136300', 'D', '125.53244', '42.6783'),
+(618, 614, '东辽', '东辽县', '中国,吉林省,辽源市,东辽县', 3, 'dongliao', '0437', '136600', 'D', '124.98596', '42.92492'),
+(619, 585, '通化', '通化市', '中国,吉林省,通化市', 2, 'tonghua', '0435', '134001', 'T', '125.936501', '41.721177'),
+(620, 619, '东昌', '东昌区', '中国,吉林省,通化市,东昌区', 3, 'dongchang', '0435', '134001', 'D', '125.9551', '41.72849'),
+(621, 619, '二道江', '二道江区', '中国,吉林省,通化市,二道江区', 3, 'erdaojiang', '0435', '134003', 'E', '126.04257', '41.7741'),
+(622, 619, '通化', '通化县', '中国,吉林省,通化市,通化县', 3, 'tonghua', '0435', '134100', 'T', '125.75936', '41.67928'),
+(623, 619, '辉南', '辉南县', '中国,吉林省,通化市,辉南县', 3, 'huinan', '0435', '135100', 'H', '126.04684', '42.68497'),
+(624, 619, '柳河', '柳河县', '中国,吉林省,通化市,柳河县', 3, 'liuhe', '0435', '135300', 'L', '125.74475', '42.28468'),
+(625, 619, '梅河口', '梅河口市', '中国,吉林省,通化市,梅河口市', 3, 'meihekou', '0435', '135000', 'M', '125.71041', '42.53828'),
+(626, 619, '集安', '集安市', '中国,吉林省,通化市,集安市', 3, 'ji''an', '0435', '134200', 'J', '126.18829', '41.12268'),
+(627, 585, '白山', '白山市', '中国,吉林省,白山市', 2, 'baishan', '0439', '134300', 'B', '126.427839', '41.942505'),
+(628, 627, '浑江', '浑江区', '中国,吉林省,白山市,浑江区', 3, 'hunjiang', '0439', '134300', 'H', '126.422342', '41.945656'),
+(629, 627, '江源', '江源区', '中国,吉林省,白山市,江源区', 3, 'jiangyuan', '0439', '134700', 'J', '126.59079', '42.05664'),
+(630, 627, '抚松', '抚松县', '中国,吉林省,白山市,抚松县', 3, 'fusong', '0439', '134500', 'F', '127.2803', '42.34198'),
+(631, 627, '靖宇', '靖宇县', '中国,吉林省,白山市,靖宇县', 3, 'jingyu', '0439', '135200', 'J', '126.81308', '42.38863'),
+(632, 627, '长白', '长白朝鲜族自治县', '中国,吉林省,白山市,长白朝鲜族自治县', 3, 'changbai', '0439', '134400', 'C', '128.20047', '41.41996'),
+(633, 627, '临江', '临江市', '中国,吉林省,白山市,临江市', 3, 'linjiang', '0439', '134600', 'L', '126.91751', '41.81142'),
+(634, 585, '松原', '松原市', '中国,吉林省,松原市', 2, 'songyuan', '0438', '138000', 'S', '124.823608', '45.118243'),
+(635, 634, '宁江', '宁江区', '中国,吉林省,松原市,宁江区', 3, 'ningjiang', '0438', '138000', 'N', '124.81689', '45.17175'),
+(636, 634, '前郭尔罗斯', '前郭尔罗斯蒙古族自治县', '中国,吉林省,松原市,前郭尔罗斯蒙古族自治县', 3, 'qianguoerluosi', '0438', '138000', 'Q', '124.82351', '45.11726'),
+(637, 634, '长岭', '长岭县', '中国,吉林省,松原市,长岭县', 3, 'changling', '0438', '131500', 'C', '123.96725', '44.27581'),
+(638, 634, '乾安', '乾安县', '中国,吉林省,松原市,乾安县', 3, 'qian''an', '0438', '131400', 'Q', '124.02737', '45.01068'),
+(639, 634, '扶余', '扶余市', '中国,吉林省,松原市,扶余市', 3, 'fuyu', '0438', '131200', 'F', '126.042758', '44.986199'),
+(640, 585, '白城', '白城市', '中国,吉林省,白城市', 2, 'baicheng', '0436', '137000', 'B', '122.841114', '45.619026'),
+(641, 640, '洮北', '洮北区', '中国,吉林省,白城市,洮北区', 3, 'taobei', '0436', '137000', NULL, '122.85104', '45.62167'),
+(642, 640, '镇赉', '镇赉县', '中国,吉林省,白城市,镇赉县', 3, 'zhenlai', '0436', '137300', 'Z', '123.19924', '45.84779'),
+(643, 640, '通榆', '通榆县', '中国,吉林省,白城市,通榆县', 3, 'tongyu', '0436', '137200', 'T', '123.08761', '44.81388'),
+(644, 640, '洮南', '洮南市', '中国,吉林省,白城市,洮南市', 3, 'taonan', '0436', '137100', NULL, '122.78772', '45.33502'),
+(645, 640, '大安', '大安市', '中国,吉林省,白城市,大安市', 3, 'da''an', '0436', '131300', 'D', '124.29519', '45.50846'),
+(646, 585, '延边', '延边朝鲜族自治州', '中国,吉林省,延边朝鲜族自治州', 2, 'yanbian', '0433', '133000', 'Y', '129.513228', '42.904823'),
+(647, 646, '延吉', '延吉市', '中国,吉林省,延边朝鲜族自治州,延吉市', 3, 'yanji', '0433', '133000', 'Y', '129.51357', '42.90682'),
+(648, 646, '图们', '图们市', '中国,吉林省,延边朝鲜族自治州,图们市', 3, 'tumen', '0433', '133100', 'T', '129.84381', '42.96801'),
+(649, 646, '敦化', '敦化市', '中国,吉林省,延边朝鲜族自治州,敦化市', 3, 'dunhua', '0433', '133700', 'D', '128.23242', '43.37304'),
+(650, 646, '珲春', '珲春市', '中国,吉林省,延边朝鲜族自治州,珲春市', 3, 'hunchun', '0433', '133300', NULL, '130.36572', '42.86242'),
+(651, 646, '龙井', '龙井市', '中国,吉林省,延边朝鲜族自治州,龙井市', 3, 'longjing', '0433', '133400', 'L', '129.42584', '42.76804'),
+(652, 646, '和龙', '和龙市', '中国,吉林省,延边朝鲜族自治州,和龙市', 3, 'helong', '0433', '133500', 'H', '129.01077', '42.5464'),
+(653, 646, '汪清', '汪清县', '中国,吉林省,延边朝鲜族自治州,汪清县', 3, 'wangqing', '0433', '133200', 'W', '129.77121', '43.31278'),
+(654, 646, '安图', '安图县', '中国,吉林省,延边朝鲜族自治州,安图县', 3, 'antu', '0433', '133600', 'A', '128.90625', '43.11533'),
+(655, 0, '黑龙江', '黑龙江省', '中国,黑龙江省', 1, 'heilongjiang', '', '', 'H', '126.642464', '45.756967'),
+(656, 655, '哈尔滨', '哈尔滨市', '中国,黑龙江省,哈尔滨市', 2, 'harbin', '0451', '150010', 'H', '126.642464', '45.756967'),
+(657, 656, '道里', '道里区', '中国,黑龙江省,哈尔滨市,道里区', 3, 'daoli', '0451', '150010', 'D', '126.61705', '45.75586'),
+(658, 656, '南岗', '南岗区', '中国,黑龙江省,哈尔滨市,南岗区', 3, 'nangang', '0451', '150006', 'N', '126.66854', '45.75996'),
+(659, 656, '道外', '道外区', '中国,黑龙江省,哈尔滨市,道外区', 3, 'daowai', '0451', '150020', 'D', '126.64938', '45.79187'),
+(660, 656, '平房', '平房区', '中国,黑龙江省,哈尔滨市,平房区', 3, 'pingfang', '0451', '150060', 'P', '126.63729', '45.59777'),
+(661, 656, '松北', '松北区', '中国,黑龙江省,哈尔滨市,松北区', 3, 'songbei', '0451', '150028', 'S', '126.56276', '45.80831'),
+(662, 656, '香坊', '香坊区', '中国,黑龙江省,哈尔滨市,香坊区', 3, 'xiangfang', '0451', '150036', 'X', '126.67968', '45.72383'),
+(663, 656, '呼兰', '呼兰区', '中国,黑龙江省,哈尔滨市,呼兰区', 3, 'hulan', '0451', '150500', 'H', '126.58792', '45.88895'),
+(664, 656, '阿城', '阿城区', '中国,黑龙江省,哈尔滨市,阿城区', 3, 'a''cheng', '0451', '150300', 'A', '126.97525', '45.54144'),
+(665, 656, '双城', '双城区', '中国,黑龙江省,哈尔滨市,双城区', 3, 'shuangcheng', '0451', '150100', 'S', '126.308784', '45.377942'),
+(666, 656, '依兰', '依兰县', '中国,黑龙江省,哈尔滨市,依兰县', 3, 'yilan', '0451', '154800', 'Y', '129.56817', '46.3247'),
+(667, 656, '方正', '方正县', '中国,黑龙江省,哈尔滨市,方正县', 3, 'fangzheng', '0451', '150800', 'F', '128.82952', '45.85162'),
+(668, 656, '宾县', '宾县', '中国,黑龙江省,哈尔滨市,宾县', 3, 'binxian', '0451', '150400', 'B', '127.48675', '45.75504'),
+(669, 656, '巴彦', '巴彦县', '中国,黑龙江省,哈尔滨市,巴彦县', 3, 'bayan', '0451', '151800', 'B', '127.40799', '46.08148'),
+(670, 656, '木兰', '木兰县', '中国,黑龙江省,哈尔滨市,木兰县', 3, 'mulan', '0451', '151900', 'M', '128.0448', '45.94944'),
+(671, 656, '通河', '通河县', '中国,黑龙江省,哈尔滨市,通河县', 3, 'tonghe', '0451', '150900', 'T', '128.74603', '45.99007'),
+(672, 656, '延寿', '延寿县', '中国,黑龙江省,哈尔滨市,延寿县', 3, 'yanshou', '0451', '150700', 'Y', '128.33419', '45.4554'),
+(673, 656, '尚志', '尚志市', '中国,黑龙江省,哈尔滨市,尚志市', 3, 'shangzhi', '0451', '150600', 'S', '127.96191', '45.21736'),
+(674, 656, '五常', '五常市', '中国,黑龙江省,哈尔滨市,五常市', 3, 'wuchang', '0451', '150200', 'W', '127.16751', '44.93184'),
+(675, 655, '齐齐哈尔', '齐齐哈尔市', '中国,黑龙江省,齐齐哈尔市', 2, 'qiqihar', '0452', '161005', 'Q', '123.953486', '47.348079'),
+(676, 675, '龙沙', '龙沙区', '中国,黑龙江省,齐齐哈尔市,龙沙区', 3, 'longsha', '0452', '161000', 'L', '123.95752', '47.31776'),
+(677, 675, '建华', '建华区', '中国,黑龙江省,齐齐哈尔市,建华区', 3, 'jianhua', '0452', '161006', 'J', '124.0133', '47.36718'),
+(678, 675, '铁锋', '铁锋区', '中国,黑龙江省,齐齐哈尔市,铁锋区', 3, 'tiefeng', '0452', '161000', 'T', '123.97821', '47.34075'),
+(679, 675, '昂昂溪', '昂昂溪区', '中国,黑龙江省,齐齐哈尔市,昂昂溪区', 3, 'angangxi', '0452', '161031', 'A', '123.82229', '47.15513'),
+(680, 675, '富拉尔基', '富拉尔基区', '中国,黑龙江省,齐齐哈尔市,富拉尔基区', 3, 'fulaerji', '0452', '161041', 'F', '123.62918', '47.20884'),
+(681, 675, '碾子山', '碾子山区', '中国,黑龙江省,齐齐哈尔市,碾子山区', 3, 'nianzishan', '0452', '161046', 'N', '122.88183', '47.51662'),
+(682, 675, '梅里斯', '梅里斯达斡尔族区', '中国,黑龙江省,齐齐哈尔市,梅里斯达斡尔族区', 3, 'meilisi', '0452', '161021', 'M', '123.75274', '47.30946'),
+(683, 675, '龙江', '龙江县', '中国,黑龙江省,齐齐哈尔市,龙江县', 3, 'longjiang', '0452', '161100', 'L', '123.20532', '47.33868'),
+(684, 675, '依安', '依安县', '中国,黑龙江省,齐齐哈尔市,依安县', 3, 'yi''an', '0452', '161500', 'Y', '125.30896', '47.8931'),
+(685, 675, '泰来', '泰来县', '中国,黑龙江省,齐齐哈尔市,泰来县', 3, 'tailai', '0452', '162400', 'T', '123.42285', '46.39386'),
+(686, 675, '甘南', '甘南县', '中国,黑龙江省,齐齐哈尔市,甘南县', 3, 'gannan', '0452', '162100', 'G', '123.50317', '47.92437'),
+(687, 675, '富裕', '富裕县', '中国,黑龙江省,齐齐哈尔市,富裕县', 3, 'fuyu', '0452', '161200', 'F', '124.47457', '47.77431'),
+(688, 675, '克山', '克山县', '中国,黑龙江省,齐齐哈尔市,克山县', 3, 'keshan', '0452', '161600', 'K', '125.87396', '48.03265'),
+(689, 675, '克东', '克东县', '中国,黑龙江省,齐齐哈尔市,克东县', 3, 'kedong', '0452', '164800', 'K', '126.24917', '48.03828'),
+(690, 675, '拜泉', '拜泉县', '中国,黑龙江省,齐齐哈尔市,拜泉县', 3, 'baiquan', '0452', '164700', 'B', '126.09167', '47.60817'),
+(691, 675, '讷河', '讷河市', '中国,黑龙江省,齐齐哈尔市,讷河市', 3, 'nehe', '0452', '161300', NULL, '124.87713', '48.48388'),
+(692, 655, '鸡西', '鸡西市', '中国,黑龙江省,鸡西市', 2, 'jixi', '0467', '158100', 'J', '130.975966', '45.300046'),
+(693, 692, '鸡冠', '鸡冠区', '中国,黑龙江省,鸡西市,鸡冠区', 3, 'jiguan', '0467', '158100', 'J', '130.98139', '45.30396'),
+(694, 692, '恒山', '恒山区', '中国,黑龙江省,鸡西市,恒山区', 3, 'hengshan', '0467', '158130', 'H', '130.90493', '45.21071'),
+(695, 692, '滴道', '滴道区', '中国,黑龙江省,鸡西市,滴道区', 3, 'didao', '0467', '158150', 'D', '130.84841', '45.35109'),
+(696, 692, '梨树', '梨树区', '中国,黑龙江省,鸡西市,梨树区', 3, 'lishu', '0467', '158160', 'L', '130.69848', '45.09037'),
+(697, 692, '城子河', '城子河区', '中国,黑龙江省,鸡西市,城子河区', 3, 'chengzihe', '0467', '158170', 'C', '131.01132', '45.33689'),
+(698, 692, '麻山', '麻山区', '中国,黑龙江省,鸡西市,麻山区', 3, 'mashan', '0467', '158180', 'M', '130.47811', '45.21209'),
+(699, 692, '鸡东', '鸡东县', '中国,黑龙江省,鸡西市,鸡东县', 3, 'jidong', '0467', '158200', 'J', '131.12423', '45.26025'),
+(700, 692, '虎林', '虎林市', '中国,黑龙江省,鸡西市,虎林市', 3, 'hulin', '0467', '158400', 'H', '132.93679', '45.76291'),
+(701, 692, '密山', '密山市', '中国,黑龙江省,鸡西市,密山市', 3, 'mishan', '0467', '158300', 'M', '131.84625', '45.5297'),
+(702, 655, '鹤岗', '鹤岗市', '中国,黑龙江省,鹤岗市', 2, 'hegang', '0468', '154100', 'H', '130.277487', '47.332085'),
+(703, 702, '向阳', '向阳区', '中国,黑龙江省,鹤岗市,向阳区', 3, 'xiangyang', '0468', '154100', 'X', '130.2943', '47.34247'),
+(704, 702, '工农', '工农区', '中国,黑龙江省,鹤岗市,工农区', 3, 'gongnong', '0468', '154101', 'G', '130.27468', '47.31869'),
+(705, 702, '南山', '南山区', '中国,黑龙江省,鹤岗市,南山区', 3, 'nanshan', '0468', '154104', 'N', '130.27676', '47.31404'),
+(706, 702, '兴安', '兴安区', '中国,黑龙江省,鹤岗市,兴安区', 3, 'xing''an', '0468', '154102', 'X', '130.23965', '47.2526'),
+(707, 702, '东山', '东山区', '中国,黑龙江省,鹤岗市,东山区', 3, 'dongshan', '0468', '154106', 'D', '130.31706', '47.33853'),
+(708, 702, '兴山', '兴山区', '中国,黑龙江省,鹤岗市,兴山区', 3, 'xingshan', '0468', '154105', 'X', '130.29271', '47.35776'),
+(709, 702, '萝北', '萝北县', '中国,黑龙江省,鹤岗市,萝北县', 3, 'luobei', '0468', '154200', 'L', '130.83346', '47.57959'),
+(710, 702, '绥滨', '绥滨县', '中国,黑龙江省,鹤岗市,绥滨县', 3, 'suibin', '0468', '156200', 'S', '131.86029', '47.2903'),
+(711, 655, '双鸭山', '双鸭山市', '中国,黑龙江省,双鸭山市', 2, 'shuangyashan', '0469', '155100', 'S', '131.157304', '46.643442'),
+(712, 711, '尖山', '尖山区', '中国,黑龙江省,双鸭山市,尖山区', 3, 'jianshan', '0469', '155100', 'J', '131.15841', '46.64635'),
+(713, 711, '岭东', '岭东区', '中国,黑龙江省,双鸭山市,岭东区', 3, 'lingdong', '0469', '155120', 'L', '131.16473', '46.59043'),
+(714, 711, '四方台', '四方台区', '中国,黑龙江省,双鸭山市,四方台区', 3, 'sifangtai', '0469', '155130', 'S', '131.33593', '46.59499'),
+(715, 711, '宝山', '宝山区', '中国,黑龙江省,双鸭山市,宝山区', 3, 'baoshan', '0469', '155131', 'B', '131.4016', '46.57718'),
+(716, 711, '集贤', '集贤县', '中国,黑龙江省,双鸭山市,集贤县', 3, 'jixian', '0469', '155900', 'J', '131.14053', '46.72678'),
+(717, 711, '友谊', '友谊县', '中国,黑龙江省,双鸭山市,友谊县', 3, 'youyi', '0469', '155800', 'Y', '131.80789', '46.76739'),
+(718, 711, '宝清', '宝清县', '中国,黑龙江省,双鸭山市,宝清县', 3, 'baoqing', '0469', '155600', 'B', '132.19695', '46.32716'),
+(719, 711, '饶河', '饶河县', '中国,黑龙江省,双鸭山市,饶河县', 3, 'raohe', '0469', '155700', 'R', '134.01986', '46.79899'),
+(720, 655, '大庆', '大庆市', '中国,黑龙江省,大庆市', 2, 'daqing', '0459', '163000', 'D', '125.11272', '46.590734'),
+(721, 720, '萨尔图', '萨尔图区', '中国,黑龙江省,大庆市,萨尔图区', 3, 'saertu', '0459', '163001', 'S', '125.08792', '46.59359'),
+(722, 720, '龙凤', '龙凤区', '中国,黑龙江省,大庆市,龙凤区', 3, 'longfeng', '0459', '163711', 'L', '125.11657', '46.53273'),
+(723, 720, '让胡路', '让胡路区', '中国,黑龙江省,大庆市,让胡路区', 3, 'ranghulu', '0459', '163712', 'R', '124.87075', '46.6522'),
+(724, 720, '红岗', '红岗区', '中国,黑龙江省,大庆市,红岗区', 3, 'honggang', '0459', '163511', 'H', '124.89248', '46.40128'),
+(725, 720, '大同', '大同区', '中国,黑龙江省,大庆市,大同区', 3, 'datong', '0459', '163515', 'D', '124.81591', '46.03295'),
+(726, 720, '肇州', '肇州县', '中国,黑龙江省,大庆市,肇州县', 3, 'zhaozhou', '0459', '166400', 'Z', '125.27059', '45.70414'),
+(727, 720, '肇源', '肇源县', '中国,黑龙江省,大庆市,肇源县', 3, 'zhaoyuan', '0459', '166500', 'Z', '125.08456', '45.52032'),
+(728, 720, '林甸', '林甸县', '中国,黑龙江省,大庆市,林甸县', 3, 'lindian', '0459', '166300', 'L', '124.87564', '47.18601'),
+(729, 720, '杜尔伯特', '杜尔伯特蒙古族自治县', '中国,黑龙江省,大庆市,杜尔伯特蒙古族自治县', 3, 'duerbote', '0459', '166200', 'D', '124.44937', '46.86507'),
+(730, 655, '伊春', '伊春市', '中国,黑龙江省,伊春市', 2, 'yichun', '0458', '153000', 'Y', '128.899396', '47.724775'),
+(731, 730, '伊春', '伊春区', '中国,黑龙江省,伊春市,伊春区', 3, 'yichun', '0458', '153000', 'Y', '128.90752', '47.728'),
+(732, 730, '南岔', '南岔区', '中国,黑龙江省,伊春市,南岔区', 3, 'nancha', '0458', '153100', 'N', '129.28362', '47.13897'),
+(733, 730, '友好', '友好区', '中国,黑龙江省,伊春市,友好区', 3, 'youhao', '0458', '153031', 'Y', '128.84039', '47.85371'),
+(734, 730, '西林', '西林区', '中国,黑龙江省,伊春市,西林区', 3, 'xilin', '0458', '153025', 'X', '129.31201', '47.48103'),
+(735, 730, '翠峦', '翠峦区', '中国,黑龙江省,伊春市,翠峦区', 3, 'cuiluan', '0458', '153013', 'C', '128.66729', '47.72503'),
+(736, 730, '新青', '新青区', '中国,黑龙江省,伊春市,新青区', 3, 'xinqing', '0458', '153036', 'X', '129.53653', '48.29067'),
+(737, 730, '美溪', '美溪区', '中国,黑龙江省,伊春市,美溪区', 3, 'meixi', '0458', '153021', 'M', '129.13708', '47.63513'),
+(738, 730, '金山屯', '金山屯区', '中国,黑龙江省,伊春市,金山屯区', 3, 'jinshantun', '0458', '153026', 'J', '129.43768', '47.41349'),
+(739, 730, '五营', '五营区', '中国,黑龙江省,伊春市,五营区', 3, 'wuying', '0458', '153033', 'W', '129.24545', '48.10791'),
+(740, 730, '乌马河', '乌马河区', '中国,黑龙江省,伊春市,乌马河区', 3, 'wumahe', '0458', '153011', 'W', '128.79672', '47.728'),
+(741, 730, '汤旺河', '汤旺河区', '中国,黑龙江省,伊春市,汤旺河区', 3, 'tangwanghe', '0458', '153037', 'T', '129.57226', '48.45182'),
+(742, 730, '带岭', '带岭区', '中国,黑龙江省,伊春市,带岭区', 3, 'dailing', '0458', '153106', 'D', '129.02352', '47.02553'),
+(743, 730, '乌伊岭', '乌伊岭区', '中国,黑龙江省,伊春市,乌伊岭区', 3, 'wuyiling', '0458', '153038', 'W', '129.43981', '48.59602'),
+(744, 730, '红星', '红星区', '中国,黑龙江省,伊春市,红星区', 3, 'hongxing', '0458', '153035', 'H', '129.3887', '48.23944'),
+(745, 730, '上甘岭', '上甘岭区', '中国,黑龙江省,伊春市,上甘岭区', 3, 'shangganling', '0458', '153032', 'S', '129.02447', '47.97522'),
+(746, 730, '嘉荫', '嘉荫县', '中国,黑龙江省,伊春市,嘉荫县', 3, 'jiayin', '0458', '153200', 'J', '130.39825', '48.8917'),
+(747, 730, '铁力', '铁力市', '中国,黑龙江省,伊春市,铁力市', 3, 'tieli', '0458', '152500', 'T', '128.0317', '46.98571'),
+(748, 655, '佳木斯', '佳木斯市', '中国,黑龙江省,佳木斯市', 2, 'jiamusi', '0454', '154002', 'J', '130.361634', '46.809606'),
+(749, 748, '向阳', '向阳区', '中国,黑龙江省,佳木斯市,向阳区', 3, 'xiangyang', '0454', '154002', 'X', '130.36519', '46.80778'),
+(750, 748, '前进', '前进区', '中国,黑龙江省,佳木斯市,前进区', 3, 'qianjin', '0454', '154002', 'Q', '130.37497', '46.81401'),
+(751, 748, '东风', '东风区', '中国,黑龙江省,佳木斯市,东风区', 3, 'dongfeng', '0454', '154005', 'D', '130.40366', '46.82257'),
+(752, 748, '郊区', '郊区', '中国,黑龙江省,佳木斯市,郊区', 3, 'jiaoqu', '0454', '154004', 'J', '130.32731', '46.80958'),
+(753, 748, '桦南', '桦南县', '中国,黑龙江省,佳木斯市,桦南县', 3, 'huanan', '0454', '154400', NULL, '130.55361', '46.23921'),
+(754, 748, '桦川', '桦川县', '中国,黑龙江省,佳木斯市,桦川县', 3, 'huachuan', '0454', '154300', NULL, '130.71893', '47.02297'),
+(755, 748, '汤原', '汤原县', '中国,黑龙江省,佳木斯市,汤原县', 3, 'tangyuan', '0454', '154700', 'T', '129.90966', '46.72755'),
+(756, 748, '抚远', '抚远县', '中国,黑龙江省,佳木斯市,抚远县', 3, 'fuyuan', '0454', '156500', 'F', '134.29595', '48.36794'),
+(757, 748, '同江', '同江市', '中国,黑龙江省,佳木斯市,同江市', 3, 'tongjiang', '0454', '156400', 'T', '132.51095', '47.64211'),
+(758, 748, '富锦', '富锦市', '中国,黑龙江省,佳木斯市,富锦市', 3, 'fujin', '0454', '156100', 'F', '132.03707', '47.25132'),
+(759, 655, '七台河', '七台河市', '中国,黑龙江省,七台河市', 2, 'qitaihe', '0464', '154600', 'Q', '131.015584', '45.771266'),
+(760, 759, '新兴', '新兴区', '中国,黑龙江省,七台河市,新兴区', 3, 'xinxing', '0464', '154604', 'X', '130.93212', '45.81624'),
+(761, 759, '桃山', '桃山区', '中国,黑龙江省,七台河市,桃山区', 3, 'taoshan', '0464', '154600', 'T', '131.01786', '45.76782'),
+(762, 759, '茄子河', '茄子河区', '中国,黑龙江省,七台河市,茄子河区', 3, 'qiezihe', '0464', '154622', 'Q', '131.06807', '45.78519'),
+(763, 759, '勃利', '勃利县', '中国,黑龙江省,七台河市,勃利县', 3, 'boli', '0464', '154500', 'B', '130.59179', '45.755'),
+(764, 655, '牡丹江', '牡丹江市', '中国,黑龙江省,牡丹江市', 2, 'mudanjiang', '0453', '157000', 'M', '129.618602', '44.582962'),
+(765, 764, '东安', '东安区', '中国,黑龙江省,牡丹江市,东安区', 3, 'dong''an', '0453', '157000', 'D', '129.62665', '44.58133'),
+(766, 764, '阳明', '阳明区', '中国,黑龙江省,牡丹江市,阳明区', 3, 'yangming', '0453', '157013', 'Y', '129.63547', '44.59603'),
+(767, 764, '爱民', '爱民区', '中国,黑龙江省,牡丹江市,爱民区', 3, 'aimin', '0453', '157009', 'A', '129.59077', '44.59648'),
+(768, 764, '西安', '西安区', '中国,黑龙江省,牡丹江市,西安区', 3, 'xi''an', '0453', '157000', 'X', '129.61616', '44.57766'),
+(769, 764, '东宁', '东宁县', '中国,黑龙江省,牡丹江市,东宁县', 3, 'dongning', '0453', '157200', 'D', '131.12793', '44.0661'),
+(770, 764, '林口', '林口县', '中国,黑龙江省,牡丹江市,林口县', 3, 'linkou', '0453', '157600', 'L', '130.28393', '45.27809'),
+(771, 764, '绥芬河', '绥芬河市', '中国,黑龙江省,牡丹江市,绥芬河市', 3, 'suifenhe', '0453', '157300', 'S', '131.15139', '44.41249'),
+(772, 764, '海林', '海林市', '中国,黑龙江省,牡丹江市,海林市', 3, 'hailin', '0453', '157100', 'H', '129.38156', '44.59'),
+(773, 764, '宁安', '宁安市', '中国,黑龙江省,牡丹江市,宁安市', 3, 'ning''an', '0453', '157400', 'N', '129.48303', '44.34016'),
+(774, 764, '穆棱', '穆棱市', '中国,黑龙江省,牡丹江市,穆棱市', 3, 'muling', '0453', '157500', 'M', '130.52465', '44.919'),
+(775, 655, '黑河', '黑河市', '中国,黑龙江省,黑河市', 2, 'heihe', '0456', '164300', 'H', '127.499023', '50.249585'),
+(776, 775, '爱辉', '爱辉区', '中国,黑龙江省,黑河市,爱辉区', 3, 'aihui', '0456', '164300', 'A', '127.50074', '50.25202'),
+(777, 775, '嫩江', '嫩江县', '中国,黑龙江省,黑河市,嫩江县', 3, 'nenjiang', '0456', '161400', 'N', '125.22607', '49.17844'),
+(778, 775, '逊克', '逊克县', '中国,黑龙江省,黑河市,逊克县', 3, 'xunke', '0456', '164400', 'X', '128.47882', '49.57983'),
+(779, 775, '孙吴', '孙吴县', '中国,黑龙江省,黑河市,孙吴县', 3, 'sunwu', '0456', '164200', 'S', '127.33599', '49.42539'),
+(780, 775, '北安', '北安市', '中国,黑龙江省,黑河市,北安市', 3, 'bei''an', '0456', '164000', 'B', '126.48193', '48.23872'),
+(781, 775, '五大连池', '五大连池市', '中国,黑龙江省,黑河市,五大连池市', 3, 'wudalianchi', '0456', '164100', 'W', '126.20294', '48.51507'),
+(782, 655, '绥化', '绥化市', '中国,黑龙江省,绥化市', 2, 'suihua', '0455', '152000', 'S', '126.99293', '46.637393'),
+(783, 782, '北林', '北林区', '中国,黑龙江省,绥化市,北林区', 3, 'beilin', '0455', '152000', 'B', '126.98564', '46.63735'),
+(784, 782, '望奎', '望奎县', '中国,黑龙江省,绥化市,望奎县', 3, 'wangkui', '0455', '152100', 'W', '126.48187', '46.83079'),
+(785, 782, '兰西', '兰西县', '中国,黑龙江省,绥化市,兰西县', 3, 'lanxi', '0455', '151500', 'L', '126.28994', '46.2525'),
+(786, 782, '青冈', '青冈县', '中国,黑龙江省,绥化市,青冈县', 3, 'qinggang', '0455', '151600', 'Q', '126.11325', '46.68534'),
+(787, 782, '庆安', '庆安县', '中国,黑龙江省,绥化市,庆安县', 3, 'qing''an', '0455', '152400', 'Q', '127.50753', '46.88016'),
+(788, 782, '明水', '明水县', '中国,黑龙江省,绥化市,明水县', 3, 'mingshui', '0455', '151700', 'M', '125.90594', '47.17327'),
+(789, 782, '绥棱', '绥棱县', '中国,黑龙江省,绥化市,绥棱县', 3, 'suileng', '0455', '152200', 'S', '127.11584', '47.24267'),
+(790, 782, '安达', '安达市', '中国,黑龙江省,绥化市,安达市', 3, 'anda', '0455', '151400', 'A', '125.34375', '46.4177'),
+(791, 782, '肇东', '肇东市', '中国,黑龙江省,绥化市,肇东市', 3, 'zhaodong', '0455', '151100', 'Z', '125.96243', '46.05131'),
+(792, 782, '海伦', '海伦市', '中国,黑龙江省,绥化市,海伦市', 3, 'hailun', '0455', '152300', 'H', '126.9682', '47.46093'),
+(793, 655, '大兴安岭', '大兴安岭地区', '中国,黑龙江省,大兴安岭地区', 2, 'daxinganling', '0457', '165000', 'D', '124.711526', '52.335262'),
+(794, 793, '加格达奇', '加格达奇区', '中国,黑龙江省,大兴安岭地区,加格达奇区', 3, 'jiagedaqi', '0457', '165000', 'J', '124.30954', '51.98144'),
+(795, 793, '新林', '新林区', '中国,黑龙江省,大兴安岭地区,新林区', 3, 'xinlin', '0457', '165000', 'X', '124.397983', '51.67341'),
+(796, 793, '松岭', '松岭区', '中国,黑龙江省,大兴安岭地区,松岭区', 3, 'songling', '0457', '165000', 'S', '124.189713', '51.985453'),
+(797, 793, '呼中', '呼中区', '中国,黑龙江省,大兴安岭地区,呼中区', 3, 'huzhong', '0457', '165000', 'H', '123.60009', '52.03346'),
+(798, 793, '呼玛', '呼玛县', '中国,黑龙江省,大兴安岭地区,呼玛县', 3, 'huma', '0457', '165100', 'H', '126.66174', '51.73112'),
+(799, 793, '塔河', '塔河县', '中国,黑龙江省,大兴安岭地区,塔河县', 3, 'tahe', '0457', '165200', 'T', '124.70999', '52.33431'),
+(800, 793, '漠河', '漠河县', '中国,黑龙江省,大兴安岭地区,漠河县', 3, 'mohe', '0457', '165300', 'M', '122.53759', '52.97003'),
+(801, 0, '上海', '上海', '中国,上海', 1, 'shanghai', '', '', 'S', '121.472644', '31.231706'),
+(802, 801, '上海', '上海市', '中国,上海,上海市', 2, 'shanghai', '021', '200000', 'S', '121.472644', '31.231706'),
+(803, 802, '黄浦', '黄浦区', '中国,上海,上海市,黄浦区', 3, 'huangpu', '021', '200001', 'H', '121.49295', '31.22337'),
+(804, 802, '徐汇', '徐汇区', '中国,上海,上海市,徐汇区', 3, 'xuhui', '021', '200030', 'X', '121.43676', '31.18831'),
+(805, 802, '长宁', '长宁区', '中国,上海,上海市,长宁区', 3, 'changning', '021', '200050', 'C', '121.42462', '31.22036'),
+(806, 802, '静安', '静安区', '中国,上海,上海市,静安区', 3, 'jing''an', '021', '200040', 'J', '121.4444', '31.22884'),
+(807, 802, '普陀', '普陀区', '中国,上海,上海市,普陀区', 3, 'putuo', '021', '200333', 'P', '121.39703', '31.24951'),
+(808, 802, '闸北', '闸北区', '中国,上海,上海市,闸北区', 3, 'zhabei', '021', '200070', 'Z', '121.44636', '31.28075'),
+(809, 802, '虹口', '虹口区', '中国,上海,上海市,虹口区', 3, 'hongkou', '021', '200086', 'H', '121.48162', '31.27788'),
+(810, 802, '杨浦', '杨浦区', '中国,上海,上海市,杨浦区', 3, 'yangpu', '021', '200082', 'Y', '121.526', '31.2595'),
+(811, 802, '闵行', '闵行区', '中国,上海,上海市,闵行区', 3, 'minhang', '021', '201100', NULL, '121.38162', '31.11246'),
+(812, 802, '宝山', '宝山区', '中国,上海,上海市,宝山区', 3, 'baoshan', '021', '201900', 'B', '121.4891', '31.4045'),
+(813, 802, '嘉定', '嘉定区', '中国,上海,上海市,嘉定区', 3, 'jiading', '021', '201800', 'J', '121.2655', '31.37473'),
+(814, 802, '浦东', '浦东新区', '中国,上海,上海市,浦东新区', 3, 'pudong', '021', '200135', 'P', '121.5447', '31.22249'),
+(815, 802, '金山', '金山区', '中国,上海,上海市,金山区', 3, 'jinshan', '021', '200540', 'J', '121.34164', '30.74163'),
+(816, 802, '松江', '松江区', '中国,上海,上海市,松江区', 3, 'songjiang', '021', '201600', 'S', '121.22879', '31.03222'),
+(817, 802, '青浦', '青浦区', '中国,上海,上海市,青浦区', 3, 'qingpu', '021', '201700', 'Q', '121.12417', '31.14974'),
+(818, 802, '奉贤', '奉贤区', '中国,上海,上海市,奉贤区', 3, 'fengxian', '021', '201400', 'F', '121.47412', '30.9179'),
+(819, 802, '崇明', '崇明县', '中国,上海,上海市,崇明县', 3, 'chongming', '021', '202150', 'C', '121.39758', '31.62278'),
+(820, 0, '江苏', '江苏省', '中国,江苏省', 1, 'jiangsu', '', '', 'J', '118.767413', '32.041544'),
+(821, 820, '南京', '南京市', '中国,江苏省,南京市', 2, 'nanjing', '025', '210008', 'N', '118.767413', '32.041544'),
+(822, 821, '玄武', '玄武区', '中国,江苏省,南京市,玄武区', 3, 'xuanwu', '025', '210018', 'X', '118.79772', '32.04856'),
+(823, 821, '秦淮', '秦淮区', '中国,江苏省,南京市,秦淮区', 3, 'qinhuai', '025', '210001', 'Q', '118.79815', '32.01112'),
+(824, 821, '建邺', '建邺区', '中国,江苏省,南京市,建邺区', 3, 'jianye', '025', '210004', 'J', '118.76641', '32.03096'),
+(825, 821, '鼓楼', '鼓楼区', '中国,江苏省,南京市,鼓楼区', 3, 'gulou', '025', '210009', 'G', '118.76974', '32.06632'),
+(826, 821, '浦口', '浦口区', '中国,江苏省,南京市,浦口区', 3, 'pukou', '025', '211800', 'P', '118.62802', '32.05881'),
+(827, 821, '栖霞', '栖霞区', '中国,江苏省,南京市,栖霞区', 3, 'qixia', '025', '210046', 'Q', '118.88064', '32.11352'),
+(828, 821, '雨花台', '雨花台区', '中国,江苏省,南京市,雨花台区', 3, 'yuhuatai', '025', '210012', 'Y', '118.7799', '31.99202'),
+(829, 821, '江宁', '江宁区', '中国,江苏省,南京市,江宁区', 3, 'jiangning', '025', '211100', 'J', '118.8399', '31.95263'),
+(830, 821, '六合', '六合区', '中国,江苏省,南京市,六合区', 3, 'luhe', '025', '211500', 'L', '118.8413', '32.34222'),
+(831, 821, '溧水', '溧水区', '中国,江苏省,南京市,溧水区', 3, 'lishui', '025', '211200', NULL, '119.028732', '31.653061'),
+(832, 821, '高淳', '高淳区', '中国,江苏省,南京市,高淳区', 3, 'gaochun', '025', '211300', 'G', '118.87589', '31.327132'),
+(833, 820, '无锡', '无锡市', '中国,江苏省,无锡市', 2, 'wuxi', '0510', '214000', 'W', '120.301663', '31.574729'),
+(834, 833, '崇安', '崇安区', '中国,江苏省,无锡市,崇安区', 3, 'chong''an', '0510', '214001', 'C', '120.29975', '31.58002'),
+(835, 833, '南长', '南长区', '中国,江苏省,无锡市,南长区', 3, 'nanchang', '0510', '214021', 'N', '120.30873', '31.56359'),
+(836, 833, '北塘', '北塘区', '中国,江苏省,无锡市,北塘区', 3, 'beitang', '0510', '214044', 'B', '120.29405', '31.60592'),
+(837, 833, '锡山', '锡山区', '中国,江苏省,无锡市,锡山区', 3, 'xishan', '0510', '214101', 'X', '120.35699', '31.5886'),
+(838, 833, '惠山', '惠山区', '中国,江苏省,无锡市,惠山区', 3, 'huishan', '0510', '214174', 'H', '120.29849', '31.68088'),
+(839, 833, '滨湖', '滨湖区', '中国,江苏省,无锡市,滨湖区', 3, 'binhu', '0510', '214123', 'B', '120.29461', '31.52162'),
+(840, 833, '江阴', '江阴市', '中国,江苏省,无锡市,江阴市', 3, 'jiangyin', '0510', '214431', 'J', '120.2853', '31.91996'),
+(841, 833, '宜兴', '宜兴市', '中国,江苏省,无锡市,宜兴市', 3, 'yixing', '0510', '214200', 'Y', '119.82357', '31.33978'),
+(842, 820, '徐州', '徐州市', '中国,江苏省,徐州市', 2, 'xuzhou', '0516', '221003', 'X', '117.184811', '34.261792'),
+(843, 842, '鼓楼', '鼓楼区', '中国,江苏省,徐州市,鼓楼区', 3, 'gulou', '0516', '221005', 'G', '117.18559', '34.28851'),
+(844, 842, '云龙', '云龙区', '中国,江苏省,徐州市,云龙区', 3, 'yunlong', '0516', '221007', 'Y', '117.23053', '34.24895'),
+(845, 842, '贾汪', '贾汪区', '中国,江苏省,徐州市,贾汪区', 3, 'jiawang', '0516', '221003', 'J', '117.45346', '34.44264'),
+(846, 842, '泉山', '泉山区', '中国,江苏省,徐州市,泉山区', 3, 'quanshan', '0516', '221006', 'Q', '117.19378', '34.24418'),
+(847, 842, '铜山', '铜山区', '中国,江苏省,徐州市,铜山区', 3, 'tongshan', '0516', '221106', 'T', '117.183894', '34.19288'),
+(848, 842, '丰县', '丰县', '中国,江苏省,徐州市,丰县', 3, 'fengxian', '0516', '221700', 'F', '116.59957', '34.69972'),
+(849, 842, '沛县', '沛县', '中国,江苏省,徐州市,沛县', 3, 'peixian', '0516', '221600', 'P', '116.93743', '34.72163'),
+(850, 842, '睢宁', '睢宁县', '中国,江苏省,徐州市,睢宁县', 3, 'suining', '0516', '221200', NULL, '117.94104', '33.91269'),
+(851, 842, '新沂', '新沂市', '中国,江苏省,徐州市,新沂市', 3, 'xinyi', '0516', '221400', 'X', '118.35452', '34.36942'),
+(852, 842, '邳州', '邳州市', '中国,江苏省,徐州市,邳州市', 3, 'pizhou', '0516', '221300', NULL, '117.95858', '34.33329'),
+(853, 820, '常州', '常州市', '中国,江苏省,常州市', 2, 'changzhou', '0519', '213000', 'C', '119.946973', '31.772752'),
+(854, 853, '天宁', '天宁区', '中国,江苏省,常州市,天宁区', 3, 'tianning', '0519', '213000', 'T', '119.95132', '31.75211'),
+(855, 853, '钟楼', '钟楼区', '中国,江苏省,常州市,钟楼区', 3, 'zhonglou', '0519', '213023', 'Z', '119.90178', '31.80221'),
+(856, 853, '戚墅堰', '戚墅堰区', '中国,江苏省,常州市,戚墅堰区', 3, 'qishuyan', '0519', '213025', 'Q', '120.06106', '31.71956'),
+(857, 853, '新北', '新北区', '中国,江苏省,常州市,新北区', 3, 'xinbei', '0519', '213022', 'X', '119.97131', '31.83046'),
+(858, 853, '武进', '武进区', '中国,江苏省,常州市,武进区', 3, 'wujin', '0519', '213100', 'W', '119.94244', '31.70086'),
+(859, 853, '溧阳', '溧阳市', '中国,江苏省,常州市,溧阳市', 3, 'liyang', '0519', '213300', NULL, '119.4837', '31.41538'),
+(860, 853, '金坛', '金坛市', '中国,江苏省,常州市,金坛市', 3, 'jintan', '0519', '213200', 'J', '119.57757', '31.74043'),
+(861, 820, '苏州', '苏州市', '中国,江苏省,苏州市', 2, 'suzhou', '0512', '215002', 'S', '120.619585', '31.299379'),
+(862, 861, '虎丘', '虎丘区', '中国,江苏省,苏州市,虎丘区', 3, 'huqiu', '0512', '215004', 'H', '120.57345', '31.2953'),
+(863, 861, '吴中', '吴中区', '中国,江苏省,苏州市,吴中区', 3, 'wuzhong', '0512', '215128', 'W', '120.63211', '31.26226'),
+(864, 861, '相城', '相城区', '中国,江苏省,苏州市,相城区', 3, 'xiangcheng', '0512', '215131', 'X', '120.64239', '31.36889'),
+(865, 861, '姑苏', '姑苏区', '中国,江苏省,苏州市,姑苏区', 3, 'gusu', '0512', '215031', 'G', '120.619585', '31.299379'),
+(866, 861, '吴江', '吴江区', '中国,江苏省,苏州市,吴江区', 3, 'wujiang', '0512', '215200', 'W', '120.638317', '31.159815'),
+(867, 861, '常熟', '常熟市', '中国,江苏省,苏州市,常熟市', 3, 'changshu', '0512', '215500', 'C', '120.75225', '31.65374'),
+(868, 861, '张家港', '张家港市', '中国,江苏省,苏州市,张家港市', 3, 'zhangjiagang', '0512', '215600', 'Z', '120.55538', '31.87532'),
+(869, 861, '昆山', '昆山市', '中国,江苏省,苏州市,昆山市', 3, 'kunshan', '0512', '215300', 'K', '120.98074', '31.38464'),
+(870, 861, '太仓', '太仓市', '中国,江苏省,苏州市,太仓市', 3, 'taicang', '0512', '215400', 'T', '121.10891', '31.4497'),
+(871, 820, '南通', '南通市', '中国,江苏省,南通市', 2, 'nantong', '0513', '226001', 'N', '120.864608', '32.016212'),
+(872, 871, '崇川', '崇川区', '中国,江苏省,南通市,崇川区', 3, 'chongchuan', '0513', '226001', 'C', '120.8573', '32.0098'),
+(873, 871, '港闸', '港闸区', '中国,江苏省,南通市,港闸区', 3, 'gangzha', '0513', '226001', 'G', '120.81778', '32.03163'),
+(874, 871, '通州', '通州区', '中国,江苏省,南通市,通州区', 3, 'tongzhou', '0513', '226300', 'T', '121.07293', '32.0676'),
+(875, 871, '海安', '海安县', '中国,江苏省,南通市,海安县', 3, 'hai''an', '0513', '226600', 'H', '120.45852', '32.54514'),
+(876, 871, '如东', '如东县', '中国,江苏省,南通市,如东县', 3, 'rudong', '0513', '226400', 'R', '121.18942', '32.31439'),
+(877, 871, '启东', '启东市', '中国,江苏省,南通市,启东市', 3, 'qidong', '0513', '226200', 'Q', '121.65985', '31.81083'),
+(878, 871, '如皋', '如皋市', '中国,江苏省,南通市,如皋市', 3, 'rugao', '0513', '226500', 'R', '120.55969', '32.37597'),
+(879, 871, '海门', '海门市', '中国,江苏省,南通市,海门市', 3, 'haimen', '0513', '226100', 'H', '121.16995', '31.89422'),
+(880, 820, '连云港', '连云港市', '中国,江苏省,连云港市', 2, 'lianyungang', '0518', '222002', 'L', '119.178821', '34.600018'),
+(881, 880, '连云', '连云区', '中国,江苏省,连云港市,连云区', 3, 'lianyun', '0518', '222042', 'L', '119.37304', '34.75293'),
+(882, 880, '海州', '海州区', '中国,江苏省,连云港市,海州区', 3, 'haizhou', '0518', '222003', 'H', '119.13128', '34.56986'),
+(883, 880, '赣榆', '赣榆区', '中国,江苏省,连云港市,赣榆区', 3, 'ganyu', '0518', '222100', 'G', '119.128774', '34.839154'),
+(884, 880, '东海', '东海县', '中国,江苏省,连云港市,东海县', 3, 'donghai', '0518', '222300', 'D', '118.77145', '34.54215'),
+(885, 880, '灌云', '灌云县', '中国,江苏省,连云港市,灌云县', 3, 'guanyun', '0518', '222200', 'G', '119.23925', '34.28391'),
+(886, 880, '灌南', '灌南县', '中国,江苏省,连云港市,灌南县', 3, 'guannan', '0518', '222500', 'G', '119.35632', '34.09'),
+(887, 820, '淮安', '淮安市', '中国,江苏省,淮安市', 2, 'huai''an', '0517', '223001', 'H', '119.021265', '33.597506'),
+(888, 887, '清河', '清河区', '中国,江苏省,淮安市,清河区', 3, 'qinghe', '0517', '223001', 'Q', '119.00778', '33.59949'),
+(889, 887, '淮安', '淮安区', '中国,江苏省,淮安市,淮安区', 3, 'huai''an', '0517', '223200', 'H', '119.021265', '33.597506'),
+(890, 887, '淮阴', '淮阴区', '中国,江苏省,淮安市,淮阴区', 3, 'huaiyin', '0517', '223300', 'H', '119.03485', '33.63171'),
+(891, 887, '清浦', '清浦区', '中国,江苏省,淮安市,清浦区', 3, 'qingpu', '0517', '223002', 'Q', '119.02648', '33.55232'),
+(892, 887, '涟水', '涟水县', '中国,江苏省,淮安市,涟水县', 3, 'lianshui', '0517', '223400', 'L', '119.26083', '33.78094'),
+(893, 887, '洪泽', '洪泽县', '中国,江苏省,淮安市,洪泽县', 3, 'hongze', '0517', '223100', 'H', '118.87344', '33.29429'),
+(894, 887, '盱眙', '盱眙县', '中国,江苏省,淮安市,盱眙县', 3, 'xuyi', '0517', '211700', NULL, '118.54495', '33.01086'),
+(895, 887, '金湖', '金湖县', '中国,江苏省,淮安市,金湖县', 3, 'jinhu', '0517', '211600', 'J', '119.02307', '33.02219'),
+(896, 820, '盐城', '盐城市', '中国,江苏省,盐城市', 2, 'yancheng', '0515', '224005', 'Y', '120.139998', '33.377631'),
+(897, 896, '亭湖', '亭湖区', '中国,江苏省,盐城市,亭湖区', 3, 'tinghu', '0515', '224005', 'T', '120.16583', '33.37825'),
+(898, 896, '盐都', '盐都区', '中国,江苏省,盐城市,盐都区', 3, 'yandu', '0515', '224055', 'Y', '120.15441', '33.3373'),
+(899, 896, '响水', '响水县', '中国,江苏省,盐城市,响水县', 3, 'xiangshui', '0515', '224600', 'X', '119.56985', '34.20513'),
+(900, 896, '滨海', '滨海县', '中国,江苏省,盐城市,滨海县', 3, 'binhai', '0515', '224500', 'B', '119.82058', '33.98972'),
+(901, 896, '阜宁', '阜宁县', '中国,江苏省,盐城市,阜宁县', 3, 'funing', '0515', '224400', 'F', '119.80175', '33.78228'),
+(902, 896, '射阳', '射阳县', '中国,江苏省,盐城市,射阳县', 3, 'sheyang', '0515', '224300', 'S', '120.26043', '33.77636'),
+(903, 896, '建湖', '建湖县', '中国,江苏省,盐城市,建湖县', 3, 'jianhu', '0515', '224700', 'J', '119.79852', '33.47241'),
+(904, 896, '东台', '东台市', '中国,江苏省,盐城市,东台市', 3, 'dongtai', '0515', '224200', 'D', '120.32376', '32.85078'),
+(905, 896, '大丰', '大丰市', '中国,江苏省,盐城市,大丰市', 3, 'dafeng', '0515', '224100', 'D', '120.46594', '33.19893'),
+(906, 820, '扬州', '扬州市', '中国,江苏省,扬州市', 2, 'yangzhou', '0514', '225002', 'Y', '119.421003', '32.393159'),
+(907, 906, '广陵', '广陵区', '中国,江苏省,扬州市,广陵区', 3, 'guangling', '0514', '225002', 'G', '119.43186', '32.39472'),
+(908, 906, '邗江', '邗江区', '中国,江苏省,扬州市,邗江区', 3, 'hanjiang', '0514', '225002', NULL, '119.39816', '32.3765'),
+(909, 906, '江都', '江都区', '中国,江苏省,扬州市,江都区', 3, 'jiangdu', '0514', '225200', 'J', '119.567481', '32.426564'),
+(910, 906, '宝应', '宝应县', '中国,江苏省,扬州市,宝应县', 3, 'baoying', '0514', '225800', 'B', '119.31213', '33.23549'),
+(911, 906, '仪征', '仪征市', '中国,江苏省,扬州市,仪征市', 3, 'yizheng', '0514', '211400', 'Y', '119.18432', '32.27197'),
+(912, 906, '高邮', '高邮市', '中国,江苏省,扬州市,高邮市', 3, 'gaoyou', '0514', '225600', 'G', '119.45965', '32.78135'),
+(913, 820, '镇江', '镇江市', '中国,江苏省,镇江市', 2, 'zhenjiang', '0511', '212004', 'Z', '119.452753', '32.204402'),
+(914, 913, '京口', '京口区', '中国,江苏省,镇江市,京口区', 3, 'jingkou', '0511', '212003', 'J', '119.46947', '32.19809'),
+(915, 913, '润州', '润州区', '中国,江苏省,镇江市,润州区', 3, 'runzhou', '0511', '212005', 'R', '119.41134', '32.19523'),
+(916, 913, '丹徒', '丹徒区', '中国,江苏省,镇江市,丹徒区', 3, 'dantu', '0511', '212028', 'D', '119.43383', '32.13183'),
+(917, 913, '丹阳', '丹阳市', '中国,江苏省,镇江市,丹阳市', 3, 'danyang', '0511', '212300', 'D', '119.57525', '31.99121'),
+(918, 913, '扬中', '扬中市', '中国,江苏省,镇江市,扬中市', 3, 'yangzhong', '0511', '212200', 'Y', '119.79718', '32.2363'),
+(919, 913, '句容', '句容市', '中国,江苏省,镇江市,句容市', 3, 'jurong', '0511', '212400', 'J', '119.16482', '31.95591'),
+(920, 820, '泰州', '泰州市', '中国,江苏省,泰州市', 2, 'taizhou', '0523', '225300', 'T', '119.915176', '32.484882'),
+(921, 920, '海陵', '海陵区', '中国,江苏省,泰州市,海陵区', 3, 'hailing', '0523', '225300', 'H', '119.91942', '32.49101'),
+(922, 920, '高港', '高港区', '中国,江苏省,泰州市,高港区', 3, 'gaogang', '0523', '225321', 'G', '119.88089', '32.31833'),
+(923, 920, '姜堰', '姜堰区', '中国,江苏省,泰州市,姜堰区', 3, 'jiangyan', '0523', '225500', 'J', '120.148208', '32.508483'),
+(924, 920, '兴化', '兴化市', '中国,江苏省,泰州市,兴化市', 3, 'xinghua', '0523', '225700', 'X', '119.85238', '32.90944'),
+(925, 920, '靖江', '靖江市', '中国,江苏省,泰州市,靖江市', 3, 'jingjiang', '0523', '214500', 'J', '120.27291', '32.01595'),
+(926, 920, '泰兴', '泰兴市', '中国,江苏省,泰州市,泰兴市', 3, 'taixing', '0523', '225400', 'T', '120.05194', '32.17187'),
+(927, 820, '宿迁', '宿迁市', '中国,江苏省,宿迁市', 2, 'suqian', '0527', '223800', 'S', '118.293328', '33.945154'),
+(928, 927, '宿城', '宿城区', '中国,江苏省,宿迁市,宿城区', 3, 'sucheng', '0527', '223800', 'S', '118.29141', '33.94219'),
+(929, 927, '宿豫', '宿豫区', '中国,江苏省,宿迁市,宿豫区', 3, 'suyu', '0527', '223800', 'S', '118.32922', '33.94673'),
+(930, 927, '沭阳', '沭阳县', '中国,江苏省,宿迁市,沭阳县', 3, 'shuyang', '0527', '223600', NULL, '118.76873', '34.11446'),
+(931, 927, '泗阳', '泗阳县', '中国,江苏省,宿迁市,泗阳县', 3, 'siyang', '0527', '223700', NULL, '118.7033', '33.72096'),
+(932, 927, '泗洪', '泗洪县', '中国,江苏省,宿迁市,泗洪县', 3, 'sihong', '0527', '223900', NULL, '118.21716', '33.45996'),
+(933, 0, '浙江', '浙江省', '中国,浙江省', 1, 'zhejiang', '', '', 'Z', '120.153576', '30.287459'),
+(934, 933, '杭州', '杭州市', '中国,浙江省,杭州市', 2, 'hangzhou', '0571', '310026', 'H', '120.153576', '30.287459'),
+(935, 934, '上城', '上城区', '中国,浙江省,杭州市,上城区', 3, 'shangcheng', '0571', '310002', 'S', '120.16922', '30.24255'),
+(936, 934, '下城', '下城区', '中国,浙江省,杭州市,下城区', 3, 'xiacheng', '0571', '310006', 'X', '120.18096', '30.28153'),
+(937, 934, '江干', '江干区', '中国,浙江省,杭州市,江干区', 3, 'jianggan', '0571', '310016', 'J', '120.20517', '30.2572'),
+(938, 934, '拱墅', '拱墅区', '中国,浙江省,杭州市,拱墅区', 3, 'gongshu', '0571', '310011', 'G', '120.14209', '30.31968'),
+(939, 934, '西湖', '西湖区', '中国,浙江省,杭州市,西湖区', 3, 'xihu', '0571', '310013', 'X', '120.12979', '30.25949'),
+(940, 934, '滨江', '滨江区', '中国,浙江省,杭州市,滨江区', 3, 'binjiang', '0571', '310051', 'B', '120.21194', '30.20835'),
+(941, 934, '萧山', '萧山区', '中国,浙江省,杭州市,萧山区', 3, 'xiaoshan', '0571', '311200', 'X', '120.26452', '30.18505'),
+(942, 934, '余杭', '余杭区', '中国,浙江省,杭州市,余杭区', 3, 'yuhang', '0571', '311100', 'Y', '120.29986', '30.41829'),
+(943, 934, '桐庐', '桐庐县', '中国,浙江省,杭州市,桐庐县', 3, 'tonglu', '0571', '311500', 'T', '119.68853', '29.79779'),
+(944, 934, '淳安', '淳安县', '中国,浙江省,杭州市,淳安县', 3, 'chun''an', '0571', '311700', 'C', '119.04257', '29.60988'),
+(945, 934, '建德', '建德市', '中国,浙江省,杭州市,建德市', 3, 'jiande', '0571', '311600', 'J', '119.28158', '29.47603'),
+(946, 934, '富阳', '富阳区', '中国,浙江省,杭州市,富阳区', 3, 'fuyang', '0571', '311400', 'F', '119.96041', '30.04878'),
+(947, 934, '临安', '临安市', '中国,浙江省,杭州市,临安市', 3, 'lin''an', '0571', '311300', 'L', '119.72473', '30.23447'),
+(948, 933, '宁波', '宁波市', '中国,浙江省,宁波市', 2, 'ningbo', '0574', '315000', 'N', '121.549792', '29.868388'),
+(949, 948, '海曙', '海曙区', '中国,浙江省,宁波市,海曙区', 3, 'haishu', '0574', '315000', 'H', '121.55106', '29.85977'),
+(950, 948, '江东', '江东区', '中国,浙江省,宁波市,江东区', 3, 'jiangdong', '0574', '315040', 'J', '121.57028', '29.86701'),
+(951, 948, '江北', '江北区', '中国,浙江省,宁波市,江北区', 3, 'jiangbei', '0574', '315020', 'J', '121.55681', '29.88776'),
+(952, 948, '北仑', '北仑区', '中国,浙江省,宁波市,北仑区', 3, 'beilun', '0574', '315800', 'B', '121.84408', '29.90069'),
+(953, 948, '镇海', '镇海区', '中国,浙江省,宁波市,镇海区', 3, 'zhenhai', '0574', '315200', 'Z', '121.71615', '29.94893'),
+(954, 948, '鄞州', '鄞州区', '中国,浙江省,宁波市,鄞州区', 3, 'yinzhou', '0574', '315100', NULL, '121.54754', '29.81614'),
+(955, 948, '象山', '象山县', '中国,浙江省,宁波市,象山县', 3, 'xiangshan', '0574', '315700', 'X', '121.86917', '29.47758'),
+(956, 948, '宁海', '宁海县', '中国,浙江省,宁波市,宁海县', 3, 'ninghai', '0574', '315600', 'N', '121.43072', '29.2889'),
+(957, 948, '余姚', '余姚市', '中国,浙江省,宁波市,余姚市', 3, 'yuyao', '0574', '315400', 'Y', '121.15341', '30.03867'),
+(958, 948, '慈溪', '慈溪市', '中国,浙江省,宁波市,慈溪市', 3, 'cixi', '0574', '315300', 'C', '121.26641', '30.16959');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(959, 948, '奉化', '奉化市', '中国,浙江省,宁波市,奉化市', 3, 'fenghua', '0574', '315500', 'F', '121.41003', '29.65537'),
+(960, 933, '温州', '温州市', '中国,浙江省,温州市', 2, 'wenzhou', '0577', '325000', 'W', '120.672111', '28.000575'),
+(961, 960, '鹿城', '鹿城区', '中国,浙江省,温州市,鹿城区', 3, 'lucheng', '0577', '325000', 'L', '120.65505', '28.01489'),
+(962, 960, '龙湾', '龙湾区', '中国,浙江省,温州市,龙湾区', 3, 'longwan', '0577', '325013', 'L', '120.83053', '27.91284'),
+(963, 960, '瓯海', '瓯海区', '中国,浙江省,温州市,瓯海区', 3, 'ouhai', '0577', '325005', NULL, '120.63751', '28.00714'),
+(964, 960, '洞头', '洞头县', '中国,浙江省,温州市,洞头县', 3, 'dongtou', '0577', '325700', 'D', '121.15606', '27.83634'),
+(965, 960, '永嘉', '永嘉县', '中国,浙江省,温州市,永嘉县', 3, 'yongjia', '0577', '325100', 'Y', '120.69317', '28.15456'),
+(966, 960, '平阳', '平阳县', '中国,浙江省,温州市,平阳县', 3, 'pingyang', '0577', '325400', 'P', '120.56506', '27.66245'),
+(967, 960, '苍南', '苍南县', '中国,浙江省,温州市,苍南县', 3, 'cangnan', '0577', '325800', 'C', '120.42608', '27.51739'),
+(968, 960, '文成', '文成县', '中国,浙江省,温州市,文成县', 3, 'wencheng', '0577', '325300', 'W', '120.09063', '27.78678'),
+(969, 960, '泰顺', '泰顺县', '中国,浙江省,温州市,泰顺县', 3, 'taishun', '0577', '325500', 'T', '119.7182', '27.55694'),
+(970, 960, '瑞安', '瑞安市', '中国,浙江省,温州市,瑞安市', 3, 'rui''an', '0577', '325200', 'R', '120.65466', '27.78041'),
+(971, 960, '乐清', '乐清市', '中国,浙江省,温州市,乐清市', 3, 'yueqing', '0577', '325600', 'L', '120.9617', '28.12404'),
+(972, 933, '嘉兴', '嘉兴市', '中国,浙江省,嘉兴市', 2, 'jiaxing', '0573', '314000', 'J', '120.750865', '30.762653'),
+(973, 972, '南湖', '南湖区', '中国,浙江省,嘉兴市,南湖区', 3, 'nanhu', '0573', '314051', 'N', '120.78524', '30.74865'),
+(974, 972, '秀洲', '秀洲区', '中国,浙江省,嘉兴市,秀洲区', 3, 'xiuzhou', '0573', '314031', 'X', '120.70867', '30.76454'),
+(975, 972, '嘉善', '嘉善县', '中国,浙江省,嘉兴市,嘉善县', 3, 'jiashan', '0573', '314100', 'J', '120.92559', '30.82993'),
+(976, 972, '海盐', '海盐县', '中国,浙江省,嘉兴市,海盐县', 3, 'haiyan', '0573', '314300', 'H', '120.9457', '30.52547'),
+(977, 972, '海宁', '海宁市', '中国,浙江省,嘉兴市,海宁市', 3, 'haining', '0573', '314400', 'H', '120.6813', '30.5097'),
+(978, 972, '平湖', '平湖市', '中国,浙江省,嘉兴市,平湖市', 3, 'pinghu', '0573', '314200', 'P', '121.02166', '30.69618'),
+(979, 972, '桐乡', '桐乡市', '中国,浙江省,嘉兴市,桐乡市', 3, 'tongxiang', '0573', '314500', 'T', '120.56485', '30.6302'),
+(980, 933, '湖州', '湖州市', '中国,浙江省,湖州市', 2, 'huzhou', '0572', '313000', 'H', '120.102398', '30.867198'),
+(981, 980, '吴兴', '吴兴区', '中国,浙江省,湖州市,吴兴区', 3, 'wuxing', '0572', '313000', 'W', '120.12548', '30.85752'),
+(982, 980, '南浔', '南浔区', '中国,浙江省,湖州市,南浔区', 3, 'nanxun', '0572', '313009', 'N', '120.42038', '30.86686'),
+(983, 980, '德清', '德清县', '中国,浙江省,湖州市,德清县', 3, 'deqing', '0572', '313200', 'D', '119.97836', '30.53369'),
+(984, 980, '长兴', '长兴县', '中国,浙江省,湖州市,长兴县', 3, 'changxing', '0572', '313100', 'C', '119.90783', '31.00606'),
+(985, 980, '安吉', '安吉县', '中国,浙江省,湖州市,安吉县', 3, 'anji', '0572', '313300', 'A', '119.68158', '30.63798'),
+(986, 933, '绍兴', '绍兴市', '中国,浙江省,绍兴市', 2, 'shaoxing', '0575', '312000', 'S', '120.582112', '29.997117'),
+(987, 986, '越城', '越城区', '中国,浙江省,绍兴市,越城区', 3, 'yuecheng', '0575', '312000', 'Y', '120.5819', '29.98895'),
+(988, 986, '柯桥', '柯桥区', '中国,浙江省,绍兴市,柯桥区', 3, 'keqiao', '0575', '312030', 'K', '120.492736', '30.08763'),
+(989, 986, '上虞', '上虞区', '中国,浙江省,绍兴市,上虞区', 3, 'shangyu', '0575', '312300', 'S', '120.476075', '30.078038'),
+(990, 986, '新昌', '新昌县', '中国,浙江省,绍兴市,新昌县', 3, 'xinchang', '0575', '312500', 'X', '120.90435', '29.49991'),
+(991, 986, '诸暨', '诸暨市', '中国,浙江省,绍兴市,诸暨市', 3, 'zhuji', '0575', '311800', 'Z', '120.23629', '29.71358'),
+(992, 986, '嵊州', '嵊州市', '中国,浙江省,绍兴市,嵊州市', 3, 'shengzhou', '0575', '312400', NULL, '120.82174', '29.58854'),
+(993, 933, '金华', '金华市', '中国,浙江省,金华市', 2, 'jinhua', '0579', '321000', 'J', '119.649506', '29.089524'),
+(994, 993, '婺城', '婺城区', '中国,浙江省,金华市,婺城区', 3, 'wucheng', '0579', '321000', NULL, '119.57135', '29.09521'),
+(995, 993, '金东', '金东区', '中国,浙江省,金华市,金东区', 3, 'jindong', '0579', '321000', 'J', '119.69302', '29.0991'),
+(996, 993, '武义', '武义县', '中国,浙江省,金华市,武义县', 3, 'wuyi', '0579', '321200', 'W', '119.8164', '28.89331'),
+(997, 993, '浦江', '浦江县', '中国,浙江省,金华市,浦江县', 3, 'pujiang', '0579', '322200', 'P', '119.89181', '29.45353'),
+(998, 993, '磐安', '磐安县', '中国,浙江省,金华市,磐安县', 3, 'pan''an', '0579', '322300', 'P', '120.45022', '29.05733'),
+(999, 993, '兰溪', '兰溪市', '中国,浙江省,金华市,兰溪市', 3, 'lanxi', '0579', '321100', 'L', '119.45965', '29.20841'),
+(1000, 993, '义乌', '义乌市', '中国,浙江省,金华市,义乌市', 3, 'yiwu', '0579', '322000', 'Y', '120.0744', '29.30558'),
+(1001, 993, '东阳', '东阳市', '中国,浙江省,金华市,东阳市', 3, 'dongyang', '0579', '322100', 'D', '120.24185', '29.28942'),
+(1002, 993, '永康', '永康市', '中国,浙江省,金华市,永康市', 3, 'yongkang', '0579', '321300', 'Y', '120.04727', '28.88844'),
+(1003, 933, '衢州', '衢州市', '中国,浙江省,衢州市', 2, 'quzhou', '0570', '324002', NULL, '118.87263', '28.941708'),
+(1004, 1003, '柯城', '柯城区', '中国,浙江省,衢州市,柯城区', 3, 'kecheng', '0570', '324100', 'K', '118.87109', '28.96858'),
+(1005, 1003, '衢江', '衢江区', '中国,浙江省,衢州市,衢江区', 3, 'qujiang', '0570', '324022', NULL, '118.9598', '28.97977'),
+(1006, 1003, '常山', '常山县', '中国,浙江省,衢州市,常山县', 3, 'changshan', '0570', '324200', 'C', '118.51025', '28.90191'),
+(1007, 1003, '开化', '开化县', '中国,浙江省,衢州市,开化县', 3, 'kaihua', '0570', '324300', 'K', '118.41616', '29.13785'),
+(1008, 1003, '龙游', '龙游县', '中国,浙江省,衢州市,龙游县', 3, 'longyou', '0570', '324400', 'L', '119.17221', '29.02823'),
+(1009, 1003, '江山', '江山市', '中国,浙江省,衢州市,江山市', 3, 'jiangshan', '0570', '324100', 'J', '118.62674', '28.7386'),
+(1010, 933, '舟山', '舟山市', '中国,浙江省,舟山市', 2, 'zhoushan', '0580', '316000', 'Z', '122.106863', '30.016028'),
+(1011, 1010, '定海', '定海区', '中国,浙江省,舟山市,定海区', 3, 'dinghai', '0580', '316000', 'D', '122.10677', '30.01985'),
+(1012, 1010, '普陀', '普陀区', '中国,浙江省,舟山市,普陀区', 3, 'putuo', '0580', '316100', 'P', '122.30278', '29.94908'),
+(1013, 1010, '岱山', '岱山县', '中国,浙江省,舟山市,岱山县', 3, 'daishan', '0580', '316200', NULL, '122.20486', '30.24385'),
+(1014, 1010, '嵊泗', '嵊泗县', '中国,浙江省,舟山市,嵊泗县', 3, 'shengsi', '0580', '202450', NULL, '122.45129', '30.72678'),
+(1015, 933, '台州', '台州市', '中国,浙江省,台州市', 2, 'taizhou', '0576', '318000', 'T', '121.428599', '28.661378'),
+(1016, 1015, '椒江', '椒江区', '中国,浙江省,台州市,椒江区', 3, 'jiaojiang', '0576', '318000', 'J', '121.44287', '28.67301'),
+(1017, 1015, '黄岩', '黄岩区', '中国,浙江省,台州市,黄岩区', 3, 'huangyan', '0576', '318020', 'H', '121.25891', '28.65077'),
+(1018, 1015, '路桥', '路桥区', '中国,浙江省,台州市,路桥区', 3, 'luqiao', '0576', '318050', 'L', '121.37381', '28.58016'),
+(1019, 1015, '玉环', '玉环县', '中国,浙江省,台州市,玉环县', 3, 'yuhuan', '0576', '317600', 'Y', '121.23242', '28.13637'),
+(1020, 1015, '三门', '三门县', '中国,浙江省,台州市,三门县', 3, 'sanmen', '0576', '317100', 'S', '121.3937', '29.1051'),
+(1021, 1015, '天台', '天台县', '中国,浙江省,台州市,天台县', 3, 'tiantai', '0576', '317200', 'T', '121.00848', '29.1429'),
+(1022, 1015, '仙居', '仙居县', '中国,浙江省,台州市,仙居县', 3, 'xianju', '0576', '317300', 'X', '120.72872', '28.84672'),
+(1023, 1015, '温岭', '温岭市', '中国,浙江省,台州市,温岭市', 3, 'wenling', '0576', '317500', 'W', '121.38595', '28.37176'),
+(1024, 1015, '临海', '临海市', '中国,浙江省,台州市,临海市', 3, 'linhai', '0576', '317000', 'L', '121.13885', '28.85603'),
+(1025, 933, '丽水', '丽水市', '中国,浙江省,丽水市', 2, 'lishui', '0578', '323000', 'L', '119.921786', '28.451993'),
+(1026, 1025, '莲都', '莲都区', '中国,浙江省,丽水市,莲都区', 3, 'liandu', '0578', '323000', 'L', '119.9127', '28.44583'),
+(1027, 1025, '青田', '青田县', '中国,浙江省,丽水市,青田县', 3, 'qingtian', '0578', '323900', 'Q', '120.29028', '28.13897'),
+(1028, 1025, '缙云', '缙云县', '中国,浙江省,丽水市,缙云县', 3, 'jinyun', '0578', '321400', NULL, '120.09036', '28.65944'),
+(1029, 1025, '遂昌', '遂昌县', '中国,浙江省,丽水市,遂昌县', 3, 'suichang', '0578', '323300', 'S', '119.27606', '28.59291'),
+(1030, 1025, '松阳', '松阳县', '中国,浙江省,丽水市,松阳县', 3, 'songyang', '0578', '323400', 'S', '119.48199', '28.4494'),
+(1031, 1025, '云和', '云和县', '中国,浙江省,丽水市,云和县', 3, 'yunhe', '0578', '323600', 'Y', '119.57287', '28.11643'),
+(1032, 1025, '庆元', '庆元县', '中国,浙江省,丽水市,庆元县', 3, 'qingyuan', '0578', '323800', 'Q', '119.06256', '27.61842'),
+(1033, 1025, '景宁', '景宁畲族自治县', '中国,浙江省,丽水市,景宁畲族自治县', 3, 'jingning', '0578', '323500', 'J', '119.63839', '27.97393'),
+(1034, 1025, '龙泉', '龙泉市', '中国,浙江省,丽水市,龙泉市', 3, 'longquan', '0578', '323700', 'L', '119.14163', '28.0743'),
+(1035, 933, '舟山新区', '舟山群岛新区', '中国,浙江省,舟山群岛新区', 2, 'zhoushan', '0580', '316000', 'Z', '122.317657', '29.813242'),
+(1036, 1035, '金塘', '金塘岛', '中国,浙江省,舟山群岛新区,金塘岛', 3, 'jintang', '0580', '316000', 'J', '121.893373', '30.040641'),
+(1037, 1035, '六横', '六横岛', '中国,浙江省,舟山群岛新区,六横岛', 3, 'liuheng', '0580', '316000', 'L', '122.14265', '29.662938'),
+(1038, 1035, '衢山', '衢山岛', '中国,浙江省,舟山群岛新区,衢山岛', 3, 'qushan', '0580', '316000', NULL, '122.358425', '30.442642'),
+(1039, 1035, '舟山', '舟山本岛西北部', '中国,浙江省,舟山群岛新区,舟山本岛西北部', 3, 'zhoushan', '0580', '316000', 'Z', '122.03064', '30.140377'),
+(1040, 1035, '岱山', '岱山岛西南部', '中国,浙江省,舟山群岛新区,岱山岛西南部', 3, 'daishan', '0580', '316000', NULL, '122.180123', '30.277269'),
+(1041, 1035, '泗礁', '泗礁岛', '中国,浙江省,舟山群岛新区,泗礁岛', 3, 'sijiao', '0580', '316000', NULL, '122.45803', '30.725112'),
+(1042, 1035, '朱家尖', '朱家尖岛', '中国,浙江省,舟山群岛新区,朱家尖岛', 3, 'zhujiajian', '0580', '316000', 'Z', '122.390636', '29.916303'),
+(1043, 1035, '洋山', '洋山岛', '中国,浙江省,舟山群岛新区,洋山岛', 3, 'yangshan', '0580', '316000', 'Y', '121.995891', '30.094637'),
+(1044, 1035, '长涂', '长涂岛', '中国,浙江省,舟山群岛新区,长涂岛', 3, 'changtu', '0580', '316000', 'C', '122.284681', '30.24888'),
+(1045, 1035, '虾峙', '虾峙岛', '中国,浙江省,舟山群岛新区,虾峙岛', 3, 'xiazhi', '0580', '316000', 'X', '122.244686', '29.752941'),
+(1046, 0, '安徽', '安徽省', '中国,安徽省', 1, 'anhui', '', '', 'A', '117.283042', '31.86119'),
+(1047, 1046, '合肥', '合肥市', '中国,安徽省,合肥市', 2, 'hefei', '0551', '230001', 'H', '117.283042', '31.86119'),
+(1048, 1047, '瑶海', '瑶海区', '中国,安徽省,合肥市,瑶海区', 3, 'yaohai', '0551', '230011', 'Y', '117.30947', '31.85809'),
+(1049, 1047, '庐阳', '庐阳区', '中国,安徽省,合肥市,庐阳区', 3, 'luyang', '0551', '230001', 'L', '117.26452', '31.87874'),
+(1050, 1047, '蜀山', '蜀山区', '中国,安徽省,合肥市,蜀山区', 3, 'shushan', '0551', '230031', 'S', '117.26104', '31.85117'),
+(1051, 1047, '包河', '包河区', '中国,安徽省,合肥市,包河区', 3, 'baohe', '0551', '230041', 'B', '117.30984', '31.79502'),
+(1052, 1047, '长丰', '长丰县', '中国,安徽省,合肥市,长丰县', 3, 'changfeng', '0551', '231100', 'C', '117.16549', '32.47959'),
+(1053, 1047, '肥东', '肥东县', '中国,安徽省,合肥市,肥东县', 3, 'feidong', '0551', '231600', 'F', '117.47128', '31.88525'),
+(1054, 1047, '肥西', '肥西县', '中国,安徽省,合肥市,肥西县', 3, 'feixi', '0551', '231200', 'F', '117.16845', '31.72143'),
+(1055, 1047, '庐江', '庐江县', '中国,安徽省,合肥市,庐江县', 3, 'lujiang', '0565', '231500', 'L', '117.289844', '31.251488'),
+(1056, 1047, '巢湖', '巢湖市', '中国,安徽省,合肥市,巢湖市', 3, 'chaohu', '0565', '238000', 'C', '117.874155', '31.600518'),
+(1057, 1046, '芜湖', '芜湖市', '中国,安徽省,芜湖市', 2, 'wuhu', '0551', '241000', 'W', '118.376451', '31.326319'),
+(1058, 1057, '镜湖', '镜湖区', '中国,安徽省,芜湖市,镜湖区', 3, 'jinghu', '0553', '241000', 'J', '118.38525', '31.34038'),
+(1059, 1057, '弋江', '弋江区', '中国,安徽省,芜湖市,弋江区', 3, 'yijiang', '0553', '241000', NULL, '118.37265', '31.31178'),
+(1060, 1057, '鸠江', '鸠江区', '中国,安徽省,芜湖市,鸠江区', 3, 'jiujiang', '0553', '241000', NULL, '118.39215', '31.36928'),
+(1061, 1057, '三山', '三山区', '中国,安徽省,芜湖市,三山区', 3, 'sanshan', '0553', '241000', 'S', '118.22509', '31.20703'),
+(1062, 1057, '芜湖', '芜湖县', '中国,安徽省,芜湖市,芜湖县', 3, 'wuhu', '0553', '241100', 'W', '118.57525', '31.13476'),
+(1063, 1057, '繁昌', '繁昌县', '中国,安徽省,芜湖市,繁昌县', 3, 'fanchang', '0553', '241200', 'F', '118.19982', '31.08319'),
+(1064, 1057, '南陵', '南陵县', '中国,安徽省,芜湖市,南陵县', 3, 'nanling', '0553', '242400', 'N', '118.33688', '30.91969'),
+(1065, 1057, '无为', '无为县', '中国,安徽省,芜湖市,无为县', 3, 'wuwei', '0565', '238300', 'W', '117.911432', '31.303075'),
+(1066, 1046, '蚌埠', '蚌埠市', '中国,安徽省,蚌埠市', 2, 'bengbu', '0552', '233000', 'B', '117.36237', '32.934037'),
+(1067, 1066, '龙子湖', '龙子湖区', '中国,安徽省,蚌埠市,龙子湖区', 3, 'longzihu', '0552', '233000', 'L', '117.39379', '32.94301'),
+(1068, 1066, '蚌山', '蚌山区', '中国,安徽省,蚌埠市,蚌山区', 3, 'bengshan', '0552', '233000', 'B', '117.36767', '32.94411'),
+(1069, 1066, '禹会', '禹会区', '中国,安徽省,蚌埠市,禹会区', 3, 'yuhui', '0552', '233010', 'Y', '117.35315', '32.93336'),
+(1070, 1066, '淮上', '淮上区', '中国,安徽省,蚌埠市,淮上区', 3, 'huaishang', '0552', '233002', 'H', '117.35983', '32.96423'),
+(1071, 1066, '怀远', '怀远县', '中国,安徽省,蚌埠市,怀远县', 3, 'huaiyuan', '0552', '233400', 'H', '117.20507', '32.97007'),
+(1072, 1066, '五河', '五河县', '中国,安徽省,蚌埠市,五河县', 3, 'wuhe', '0552', '233300', 'W', '117.89144', '33.14457'),
+(1073, 1066, '固镇', '固镇县', '中国,安徽省,蚌埠市,固镇县', 3, 'guzhen', '0552', '233700', 'G', '117.31558', '33.31803'),
+(1074, 1046, '淮南', '淮南市', '中国,安徽省,淮南市', 2, 'huainan', '0554', '232001', 'H', '117.025449', '32.645947'),
+(1075, 1074, '大通', '大通区', '中国,安徽省,淮南市,大通区', 3, 'datong', '0554', '232033', 'D', '117.05255', '32.63265'),
+(1076, 1074, '田家庵', '田家庵区', '中国,安徽省,淮南市,田家庵区', 3, 'tianjiaan', '0554', '232000', 'T', '117.01739', '32.64697'),
+(1077, 1074, '谢家集', '谢家集区', '中国,安徽省,淮南市,谢家集区', 3, 'xiejiaji', '0554', '232052', 'X', '116.86377', '32.59818'),
+(1078, 1074, '八公山', '八公山区', '中国,安徽省,淮南市,八公山区', 3, 'bagongshan', '0554', '232072', 'B', '116.83694', '32.62941'),
+(1079, 1074, '潘集', '潘集区', '中国,安徽省,淮南市,潘集区', 3, 'panji', '0554', '232082', 'P', '116.81622', '32.78287'),
+(1080, 1074, '凤台', '凤台县', '中国,安徽省,淮南市,凤台县', 3, 'fengtai', '0554', '232100', 'F', '116.71569', '32.70752'),
+(1081, 1046, '马鞍山', '马鞍山市', '中国,安徽省,马鞍山市', 2, 'ma''anshan', '0555', '243001', 'M', '118.507906', '31.689362'),
+(1082, 1081, '花山', '花山区', '中国,安徽省,马鞍山市,花山区', 3, 'huashan', '0555', '243000', 'H', '118.51231', '31.7001'),
+(1083, 1081, '雨山', '雨山区', '中国,安徽省,马鞍山市,雨山区', 3, 'yushan', '0555', '243071', 'Y', '118.49869', '31.68219'),
+(1084, 1081, '博望', '博望区', '中国,安徽省,马鞍山市,博望区', 3, 'bowang', '0555', '243131', 'B', '118.844387', '31.561871'),
+(1085, 1081, '当涂', '当涂县', '中国,安徽省,马鞍山市,当涂县', 3, 'dangtu', '0555', '243100', 'D', '118.49786', '31.57098'),
+(1086, 1081, '含山', '含山县', '中国,安徽省,马鞍山市,含山县', 3, 'hanshan', '0555', '238100', 'H', '118.105545', '31.727758'),
+(1087, 1081, '和县', '和县', '中国,安徽省,马鞍山市,和县', 3, 'hexian', '0555', '238200', 'H', '118.351405', '31.741794'),
+(1088, 1046, '淮北', '淮北市', '中国,安徽省,淮北市', 2, 'huaibei', '0561', '235000', 'H', '116.794664', '33.971707'),
+(1089, 1088, '杜集', '杜集区', '中国,安徽省,淮北市,杜集区', 3, 'duji', '0561', '235000', 'D', '116.82998', '33.99363'),
+(1090, 1088, '相山', '相山区', '中国,安徽省,淮北市,相山区', 3, 'xiangshan', '0561', '235000', 'X', '116.79464', '33.95979'),
+(1091, 1088, '烈山', '烈山区', '中国,安徽省,淮北市,烈山区', 3, 'lieshan', '0561', '235000', 'L', '116.81448', '33.89355'),
+(1092, 1088, '濉溪', '濉溪县', '中国,安徽省,淮北市,濉溪县', 3, 'suixi', '0561', '235100', NULL, '116.76785', '33.91455'),
+(1093, 1046, '铜陵', '铜陵市', '中国,安徽省,铜陵市', 2, 'tongling', '0562', '244000', 'T', '117.816576', '30.929935'),
+(1094, 1093, '铜官山', '铜官山区', '中国,安徽省,铜陵市,铜官山区', 3, 'tongguanshan', '0562', '244000', 'T', '117.81525', '30.93423'),
+(1095, 1093, '狮子山', '狮子山区', '中国,安徽省,铜陵市,狮子山区', 3, 'shizishan', '0562', '244000', 'S', '117.89178', '30.92631'),
+(1096, 1093, '郊区', '郊区', '中国,安徽省,铜陵市,郊区', 3, 'jiaoqu', '0562', '244000', 'J', '117.80868', '30.91976'),
+(1097, 1093, '铜陵', '铜陵县', '中国,安徽省,铜陵市,铜陵县', 3, 'tongling', '0562', '244100', 'T', '117.79113', '30.95365'),
+(1098, 1046, '安庆', '安庆市', '中国,安徽省,安庆市', 2, 'anqing', '0556', '246001', 'A', '117.053571', '30.524816'),
+(1099, 1098, '迎江', '迎江区', '中国,安徽省,安庆市,迎江区', 3, 'yingjiang', '0556', '246001', 'Y', '117.0493', '30.50421'),
+(1100, 1098, '大观', '大观区', '中国,安徽省,安庆市,大观区', 3, 'daguan', '0556', '246002', 'D', '117.03426', '30.51216'),
+(1101, 1098, '宜秀', '宜秀区', '中国,安徽省,安庆市,宜秀区', 3, 'yixiu', '0556', '246003', 'Y', '117.06127', '30.50783'),
+(1102, 1098, '怀宁', '怀宁县', '中国,安徽省,安庆市,怀宁县', 3, 'huaining', '0556', '246100', 'H', '116.82968', '30.73376'),
+(1103, 1098, '枞阳', '枞阳县', '中国,安徽省,安庆市,枞阳县', 3, 'zongyang', '0556', '246700', NULL, '117.22015', '30.69956'),
+(1104, 1098, '潜山', '潜山县', '中国,安徽省,安庆市,潜山县', 3, 'qianshan', '0556', '246300', 'Q', '116.57574', '30.63037'),
+(1105, 1098, '太湖', '太湖县', '中国,安徽省,安庆市,太湖县', 3, 'taihu', '0556', '246400', 'T', '116.3088', '30.4541'),
+(1106, 1098, '宿松', '宿松县', '中国,安徽省,安庆市,宿松县', 3, 'susong', '0556', '246500', 'S', '116.12915', '30.1536'),
+(1107, 1098, '望江', '望江县', '中国,安徽省,安庆市,望江县', 3, 'wangjiang', '0556', '246200', 'W', '116.68814', '30.12585'),
+(1108, 1098, '岳西', '岳西县', '中国,安徽省,安庆市,岳西县', 3, 'yuexi', '0556', '246600', 'Y', '116.35995', '30.84983'),
+(1109, 1098, '桐城', '桐城市', '中国,安徽省,安庆市,桐城市', 3, 'tongcheng', '0556', '231400', 'T', '116.95071', '31.05216'),
+(1110, 1046, '黄山', '黄山市', '中国,安徽省,黄山市', 2, 'huangshan', '0559', '245000', 'H', '118.317325', '29.709239'),
+(1111, 1110, '屯溪', '屯溪区', '中国,安徽省,黄山市,屯溪区', 3, 'tunxi', '0559', '245000', 'T', '118.33368', '29.71138'),
+(1112, 1110, '黄山', '黄山区', '中国,安徽省,黄山市,黄山区', 3, 'huangshan', '0559', '242700', 'H', '118.1416', '30.2729'),
+(1113, 1110, '徽州', '徽州区', '中国,安徽省,黄山市,徽州区', 3, 'huizhou', '0559', '245061', 'H', '118.33654', '29.82784'),
+(1114, 1110, '歙县', '歙县', '中国,安徽省,黄山市,歙县', 3, 'shexian', '0559', '245200', NULL, '118.43676', '29.86745'),
+(1115, 1110, '休宁', '休宁县', '中国,安徽省,黄山市,休宁县', 3, 'xiuning', '0559', '245400', 'X', '118.18136', '29.78607'),
+(1116, 1110, '黟县', '黟县', '中国,安徽省,黄山市,黟县', 3, 'yixian', '0559', '245500', NULL, '117.94137', '29.92588'),
+(1117, 1110, '祁门', '祁门县', '中国,安徽省,黄山市,祁门县', 3, 'qimen', '0559', '245600', 'Q', '117.71847', '29.85723'),
+(1118, 1046, '滁州', '滁州市', '中国,安徽省,滁州市', 2, 'chuzhou', '0550', '239000', 'C', '118.316264', '32.303627'),
+(1119, 1118, '琅琊', '琅琊区', '中国,安徽省,滁州市,琅琊区', 3, 'langya', '0550', '239000', 'L', '118.30538', '32.29521'),
+(1120, 1118, '南谯', '南谯区', '中国,安徽省,滁州市,南谯区', 3, 'nanqiao', '0550', '239000', 'N', '118.31222', '32.31861'),
+(1121, 1118, '来安', '来安县', '中国,安徽省,滁州市,来安县', 3, 'lai''an', '0550', '239200', 'L', '118.43438', '32.45176'),
+(1122, 1118, '全椒', '全椒县', '中国,安徽省,滁州市,全椒县', 3, 'quanjiao', '0550', '239500', 'Q', '118.27291', '32.08524'),
+(1123, 1118, '定远', '定远县', '中国,安徽省,滁州市,定远县', 3, 'dingyuan', '0550', '233200', 'D', '117.68035', '32.52488'),
+(1124, 1118, '凤阳', '凤阳县', '中国,安徽省,滁州市,凤阳县', 3, 'fengyang', '0550', '233100', 'F', '117.56454', '32.86507'),
+(1125, 1118, '天长', '天长市', '中国,安徽省,滁州市,天长市', 3, 'tianchang', '0550', '239300', 'T', '118.99868', '32.69124'),
+(1126, 1118, '明光', '明光市', '中国,安徽省,滁州市,明光市', 3, 'mingguang', '0550', '239400', 'M', '117.99093', '32.77819'),
+(1127, 1046, '阜阳', '阜阳市', '中国,安徽省,阜阳市', 2, 'fuyang', '0558', '236033', 'F', '115.819729', '32.896969'),
+(1128, 1127, '颍州', '颍州区', '中国,安徽省,阜阳市,颍州区', 3, 'yingzhou', '0558', '236001', NULL, '115.80694', '32.88346'),
+(1129, 1127, '颍东', '颍东区', '中国,安徽省,阜阳市,颍东区', 3, 'yingdong', '0558', '236058', NULL, '115.85659', '32.91296'),
+(1130, 1127, '颍泉', '颍泉区', '中国,安徽省,阜阳市,颍泉区', 3, 'yingquan', '0558', '236045', NULL, '115.80712', '32.9249'),
+(1131, 1127, '临泉', '临泉县', '中国,安徽省,阜阳市,临泉县', 3, 'linquan', '0558', '236400', 'L', '115.26232', '33.06758'),
+(1132, 1127, '太和', '太和县', '中国,安徽省,阜阳市,太和县', 3, 'taihe', '0558', '236600', 'T', '115.62191', '33.16025'),
+(1133, 1127, '阜南', '阜南县', '中国,安徽省,阜阳市,阜南县', 3, 'funan', '0558', '236300', 'F', '115.58563', '32.63551'),
+(1134, 1127, '颍上', '颍上县', '中国,安徽省,阜阳市,颍上县', 3, 'yingshang', '0558', '236200', NULL, '116.26458', '32.62998'),
+(1135, 1127, '界首', '界首市', '中国,安徽省,阜阳市,界首市', 3, 'jieshou', '0558', '236500', 'J', '115.37445', '33.25714'),
+(1136, 1046, '宿州', '宿州市', '中国,安徽省,宿州市', 2, 'suzhou', '0557', '234000', 'S', '116.984084', '33.633891'),
+(1137, 1136, '埇桥', '埇桥区', '中国,安徽省,宿州市,埇桥区', 3, 'yongqiao', '0557', '234000', NULL, '116.97731', '33.64058'),
+(1138, 1136, '砀山', '砀山县', '中国,安徽省,宿州市,砀山县', 3, 'dangshan', '0557', '235300', NULL, '116.35363', '34.42356'),
+(1139, 1136, '萧县', '萧县', '中国,安徽省,宿州市,萧县', 3, 'xiaoxian', '0557', '235200', 'X', '116.94546', '34.1879'),
+(1140, 1136, '灵璧', '灵璧县', '中国,安徽省,宿州市,灵璧县', 3, 'lingbi', '0557', '234200', 'L', '117.55813', '33.54339'),
+(1141, 1136, '泗县', '泗县', '中国,安徽省,宿州市,泗县', 3, 'sixian', '0557', '234300', NULL, '117.91033', '33.48295'),
+(1142, 1046, '六安', '六安市', '中国,安徽省,六安市', 2, 'lu''an', '0564', '237000', 'L', '116.507676', '31.752889'),
+(1143, 1142, '金安', '金安区', '中国,安徽省,六安市,金安区', 3, 'jin''an', '0564', '237005', 'J', '116.50912', '31.75573'),
+(1144, 1142, '裕安', '裕安区', '中国,安徽省,六安市,裕安区', 3, 'yu''an', '0564', '237010', 'Y', '116.47985', '31.73787'),
+(1145, 1142, '寿县', '寿县', '中国,安徽省,六安市,寿县', 3, 'shouxian', '0564', '232200', 'S', '116.78466', '32.57653'),
+(1146, 1142, '霍邱', '霍邱县', '中国,安徽省,六安市,霍邱县', 3, 'huoqiu', '0564', '237400', 'H', '116.27795', '32.353'),
+(1147, 1142, '舒城', '舒城县', '中国,安徽省,六安市,舒城县', 3, 'shucheng', '0564', '231300', 'S', '116.94491', '31.46413'),
+(1148, 1142, '金寨', '金寨县', '中国,安徽省,六安市,金寨县', 3, 'jinzhai', '0564', '237300', 'J', '115.93463', '31.7351'),
+(1149, 1142, '霍山', '霍山县', '中国,安徽省,六安市,霍山县', 3, 'huoshan', '0564', '237200', 'H', '116.33291', '31.3929'),
+(1150, 1046, '亳州', '亳州市', '中国,安徽省,亳州市', 2, 'bozhou', '0558', '236802', NULL, '115.782939', '33.869338'),
+(1151, 1150, '谯城', '谯城区', '中国,安徽省,亳州市,谯城区', 3, 'qiaocheng', '0558', '236800', NULL, '115.77941', '33.87532'),
+(1152, 1150, '涡阳', '涡阳县', '中国,安徽省,亳州市,涡阳县', 3, 'guoyang', '0558', '233600', 'W', '116.21682', '33.50911'),
+(1153, 1150, '蒙城', '蒙城县', '中国,安徽省,亳州市,蒙城县', 3, 'mengcheng', '0558', '233500', 'M', '116.5646', '33.26477'),
+(1154, 1150, '利辛', '利辛县', '中国,安徽省,亳州市,利辛县', 3, 'lixin', '0558', '236700', 'L', '116.208', '33.14198'),
+(1155, 1046, '池州', '池州市', '中国,安徽省,池州市', 2, 'chizhou', '0566', '247100', 'C', '117.489157', '30.656037'),
+(1156, 1155, '贵池', '贵池区', '中国,安徽省,池州市,贵池区', 3, 'guichi', '0566', '247100', 'G', '117.48722', '30.65283'),
+(1157, 1155, '东至', '东至县', '中国,安徽省,池州市,东至县', 3, 'dongzhi', '0566', '247200', 'D', '117.02719', '30.0969'),
+(1158, 1155, '石台', '石台县', '中国,安徽省,池州市,石台县', 3, 'shitai', '0566', '245100', 'S', '117.48666', '30.21042'),
+(1159, 1155, '青阳', '青阳县', '中国,安徽省,池州市,青阳县', 3, 'qingyang', '0566', '242800', 'Q', '117.84744', '30.63932'),
+(1160, 1046, '宣城', '宣城市', '中国,安徽省,宣城市', 2, 'xuancheng', '0563', '242000', 'X', '118.757995', '30.945667'),
+(1161, 1160, '宣州', '宣州区', '中国,安徽省,宣城市,宣州区', 3, 'xuanzhou', '0563', '242000', 'X', '118.75462', '30.94439'),
+(1162, 1160, '郎溪', '郎溪县', '中国,安徽省,宣城市,郎溪县', 3, 'langxi', '0563', '242100', 'L', '119.17923', '31.12599'),
+(1163, 1160, '广德', '广德县', '中国,安徽省,宣城市,广德县', 3, 'guangde', '0563', '242200', 'G', '119.41769', '30.89371'),
+(1164, 1160, '泾县', '泾县', '中国,安徽省,宣城市,泾县', 3, 'jingxian', '0563', '242500', NULL, '118.41964', '30.69498'),
+(1165, 1160, '绩溪', '绩溪县', '中国,安徽省,宣城市,绩溪县', 3, 'jixi', '0563', '245300', 'J', '118.59765', '30.07069'),
+(1166, 1160, '旌德', '旌德县', '中国,安徽省,宣城市,旌德县', 3, 'jingde', '0563', '242600', NULL, '118.54299', '30.28898'),
+(1167, 1160, '宁国', '宁国市', '中国,安徽省,宣城市,宁国市', 3, 'ningguo', '0563', '242300', 'N', '118.98349', '30.6238'),
+(1168, 0, '福建', '福建省', '中国,福建省', 1, 'fujian', '', '', 'F', '119.306239', '26.075302'),
+(1169, 1168, '福州', '福州市', '中国,福建省,福州市', 2, 'fuzhou', '0591', '350001', 'F', '119.306239', '26.075302'),
+(1170, 1169, '鼓楼', '鼓楼区', '中国,福建省,福州市,鼓楼区', 3, 'gulou', '0591', '350001', 'G', '119.30384', '26.08225'),
+(1171, 1169, '台江', '台江区', '中国,福建省,福州市,台江区', 3, 'taijiang', '0591', '350004', 'T', '119.30899', '26.06204'),
+(1172, 1169, '仓山', '仓山区', '中国,福建省,福州市,仓山区', 3, 'cangshan', '0591', '350007', 'C', '119.31543', '26.04335'),
+(1173, 1169, '马尾', '马尾区', '中国,福建省,福州市,马尾区', 3, 'mawei', '0591', '350015', 'M', '119.4555', '25.98942'),
+(1174, 1169, '晋安', '晋安区', '中国,福建省,福州市,晋安区', 3, 'jin''an', '0591', '350011', 'J', '119.32828', '26.0818'),
+(1175, 1169, '闽侯', '闽侯县', '中国,福建省,福州市,闽侯县', 3, 'minhou', '0591', '350100', 'M', '119.13388', '26.15014'),
+(1176, 1169, '连江', '连江县', '中国,福建省,福州市,连江县', 3, 'lianjiang', '0591', '350500', 'L', '119.53433', '26.19466'),
+(1177, 1169, '罗源', '罗源县', '中国,福建省,福州市,罗源县', 3, 'luoyuan', '0591', '350600', 'L', '119.5509', '26.48752'),
+(1178, 1169, '闽清', '闽清县', '中国,福建省,福州市,闽清县', 3, 'minqing', '0591', '350800', 'M', '118.8623', '26.21901'),
+(1179, 1169, '永泰', '永泰县', '中国,福建省,福州市,永泰县', 3, 'yongtai', '0591', '350700', 'Y', '118.936', '25.86816'),
+(1180, 1169, '平潭', '平潭县', '中国,福建省,福州市,平潭县', 3, 'pingtan', '0591', '350400', 'P', '119.791197', '25.503672'),
+(1181, 1169, '福清', '福清市', '中国,福建省,福州市,福清市', 3, 'fuqing', '0591', '350300', 'F', '119.38507', '25.72086'),
+(1182, 1169, '长乐', '长乐市', '中国,福建省,福州市,长乐市', 3, 'changle', '0591', '350200', 'C', '119.52313', '25.96276'),
+(1183, 1168, '厦门', '厦门市', '中国,福建省,厦门市', 2, 'xiamen', '0592', '361003', 'X', '118.11022', '24.490474'),
+(1184, 1183, '思明', '思明区', '中国,福建省,厦门市,思明区', 3, 'siming', '0592', '361001', 'S', '118.08233', '24.44543'),
+(1185, 1183, '海沧', '海沧区', '中国,福建省,厦门市,海沧区', 3, 'haicang', '0592', '361026', 'H', '118.03289', '24.48461'),
+(1186, 1183, '湖里', '湖里区', '中国,福建省,厦门市,湖里区', 3, 'huli', '0592', '361006', 'H', '118.14621', '24.51253'),
+(1187, 1183, '集美', '集美区', '中国,福建省,厦门市,集美区', 3, 'jimei', '0592', '361021', 'J', '118.09719', '24.57584'),
+(1188, 1183, '同安', '同安区', '中国,福建省,厦门市,同安区', 3, 'tong''an', '0592', '361100', 'T', '118.15197', '24.72308'),
+(1189, 1183, '翔安', '翔安区', '中国,福建省,厦门市,翔安区', 3, 'xiang''an', '0592', '361101', 'X', '118.24783', '24.61863'),
+(1190, 1168, '莆田', '莆田市', '中国,福建省,莆田市', 2, 'putian', '0594', '351100', 'P', '119.007558', '25.431011'),
+(1191, 1190, '城厢', '城厢区', '中国,福建省,莆田市,城厢区', 3, 'chengxiang', '0594', '351100', 'C', '118.99462', '25.41872'),
+(1192, 1190, '涵江', '涵江区', '中国,福建省,莆田市,涵江区', 3, 'hanjiang', '0594', '351111', 'H', '119.11621', '25.45876'),
+(1193, 1190, '荔城', '荔城区', '中国,福建省,莆田市,荔城区', 3, 'licheng', '0594', '351100', 'L', '119.01339', '25.43369'),
+(1194, 1190, '秀屿', '秀屿区', '中国,福建省,莆田市,秀屿区', 3, 'xiuyu', '0594', '351152', 'X', '119.10553', '25.31831'),
+(1195, 1190, '仙游', '仙游县', '中国,福建省,莆田市,仙游县', 3, 'xianyou', '0594', '351200', 'X', '118.69177', '25.36214'),
+(1196, 1168, '三明', '三明市', '中国,福建省,三明市', 2, 'sanming', '0598', '365000', 'S', '117.635001', '26.265444'),
+(1197, 1196, '梅列', '梅列区', '中国,福建省,三明市,梅列区', 3, 'meilie', '0598', '365000', 'M', '117.64585', '26.27171'),
+(1198, 1196, '三元', '三元区', '中国,福建省,三明市,三元区', 3, 'sanyuan', '0598', '365001', 'S', '117.60788', '26.23372'),
+(1199, 1196, '明溪', '明溪县', '中国,福建省,三明市,明溪县', 3, 'mingxi', '0598', '365200', 'M', '117.20498', '26.35294'),
+(1200, 1196, '清流', '清流县', '中国,福建省,三明市,清流县', 3, 'qingliu', '0598', '365300', 'Q', '116.8146', '26.17144'),
+(1201, 1196, '宁化', '宁化县', '中国,福建省,三明市,宁化县', 3, 'ninghua', '0598', '365400', 'N', '116.66101', '26.25874'),
+(1202, 1196, '大田', '大田县', '中国,福建省,三明市,大田县', 3, 'datian', '0598', '366100', 'D', '117.8471', '25.6926'),
+(1203, 1196, '尤溪', '尤溪县', '中国,福建省,三明市,尤溪县', 3, 'youxi', '0598', '365100', 'Y', '118.19049', '26.17002'),
+(1204, 1196, '沙县', '沙县', '中国,福建省,三明市,沙县', 3, 'shaxian', '0598', '365500', 'S', '117.79266', '26.39615'),
+(1205, 1196, '将乐', '将乐县', '中国,福建省,三明市,将乐县', 3, 'jiangle', '0598', '353300', 'J', '117.47317', '26.72837'),
+(1206, 1196, '泰宁', '泰宁县', '中国,福建省,三明市,泰宁县', 3, 'taining', '0598', '354400', 'T', '117.17578', '26.9001'),
+(1207, 1196, '建宁', '建宁县', '中国,福建省,三明市,建宁县', 3, 'jianning', '0598', '354500', 'J', '116.84603', '26.83091'),
+(1208, 1196, '永安', '永安市', '中国,福建省,三明市,永安市', 3, 'yong''an', '0598', '366000', 'Y', '117.36517', '25.94136'),
+(1209, 1168, '泉州', '泉州市', '中国,福建省,泉州市', 2, 'quanzhou', '0595', '362000', 'Q', '118.589421', '24.908853'),
+(1210, 1209, '鲤城', '鲤城区', '中国,福建省,泉州市,鲤城区', 3, 'licheng', '0595', '362000', 'L', '118.56591', '24.88741'),
+(1211, 1209, '丰泽', '丰泽区', '中国,福建省,泉州市,丰泽区', 3, 'fengze', '0595', '362000', 'F', '118.61328', '24.89119'),
+(1212, 1209, '洛江', '洛江区', '中国,福建省,泉州市,洛江区', 3, 'luojiang', '0595', '362011', 'L', '118.67111', '24.93984'),
+(1213, 1209, '泉港', '泉港区', '中国,福建省,泉州市,泉港区', 3, 'quangang', '0595', '362114', 'Q', '118.91586', '25.12005'),
+(1214, 1209, '惠安', '惠安县', '中国,福建省,泉州市,惠安县', 3, 'hui''an', '0595', '362100', 'H', '118.79687', '25.03059'),
+(1215, 1209, '安溪', '安溪县', '中国,福建省,泉州市,安溪县', 3, 'anxi', '0595', '362400', 'A', '118.18719', '25.05627'),
+(1216, 1209, '永春', '永春县', '中国,福建省,泉州市,永春县', 3, 'yongchun', '0595', '362600', 'Y', '118.29437', '25.32183'),
+(1217, 1209, '德化', '德化县', '中国,福建省,泉州市,德化县', 3, 'dehua', '0595', '362500', 'D', '118.24176', '25.49224'),
+(1218, 1209, '金门', '金门县', '中国,福建省,泉州市,金门县', 3, 'jinmen', '', '', 'J', '118.32263', '24.42922'),
+(1219, 1209, '石狮', '石狮市', '中国,福建省,泉州市,石狮市', 3, 'shishi', '0595', '362700', 'S', '118.64779', '24.73242'),
+(1220, 1209, '晋江', '晋江市', '中国,福建省,泉州市,晋江市', 3, 'jinjiang', '0595', '362200', 'J', '118.55194', '24.78141'),
+(1221, 1209, '南安', '南安市', '中国,福建省,泉州市,南安市', 3, 'nan''an', '0595', '362300', 'N', '118.38589', '24.96055'),
+(1222, 1168, '漳州', '漳州市', '中国,福建省,漳州市', 2, 'zhangzhou', '0596', '363005', 'Z', '117.661801', '24.510897'),
+(1223, 1222, '芗城', '芗城区', '中国,福建省,漳州市,芗城区', 3, 'xiangcheng', '0596', '363000', NULL, '117.65402', '24.51081'),
+(1224, 1222, '龙文', '龙文区', '中国,福建省,漳州市,龙文区', 3, 'longwen', '0596', '363005', 'L', '117.70971', '24.50323'),
+(1225, 1222, '云霄', '云霄县', '中国,福建省,漳州市,云霄县', 3, 'yunxiao', '0596', '363300', 'Y', '117.34051', '23.95534'),
+(1226, 1222, '漳浦', '漳浦县', '中国,福建省,漳州市,漳浦县', 3, 'zhangpu', '0596', '363200', 'Z', '117.61367', '24.11706'),
+(1227, 1222, '诏安', '诏安县', '中国,福建省,漳州市,诏安县', 3, 'zhao''an', '0596', '363500', NULL, '117.17501', '23.71148'),
+(1228, 1222, '长泰', '长泰县', '中国,福建省,漳州市,长泰县', 3, 'changtai', '0596', '363900', 'C', '117.75924', '24.62526'),
+(1229, 1222, '东山', '东山县', '中国,福建省,漳州市,东山县', 3, 'dongshan', '0596', '363400', 'D', '117.42822', '23.70109'),
+(1230, 1222, '南靖', '南靖县', '中国,福建省,漳州市,南靖县', 3, 'nanjing', '0596', '363600', 'N', '117.35736', '24.51448'),
+(1231, 1222, '平和', '平和县', '中国,福建省,漳州市,平和县', 3, 'pinghe', '0596', '363700', 'P', '117.3124', '24.36395'),
+(1232, 1222, '华安', '华安县', '中国,福建省,漳州市,华安县', 3, 'hua''an', '0596', '363800', 'H', '117.54077', '25.00563'),
+(1233, 1222, '龙海', '龙海市', '中国,福建省,漳州市,龙海市', 3, 'longhai', '0596', '363100', 'L', '117.81802', '24.44655'),
+(1234, 1168, '南平', '南平市', '中国,福建省,南平市', 2, 'nanping', '0599', '353000', 'N', '118.178459', '26.635627'),
+(1235, 1234, '延平', '延平区', '中国,福建省,南平市,延平区', 3, 'yanping', '0600', '353000', 'Y', '118.18189', '26.63745'),
+(1236, 1234, '建阳', '建阳区', '中国,福建省,南平市,建阳区', 3, 'jianyang', '0599', '354200', 'J', '118.12267', '27.332067'),
+(1237, 1234, '顺昌', '顺昌县', '中国,福建省,南平市,顺昌县', 3, 'shunchang', '0605', '353200', 'S', '117.8103', '26.79298'),
+(1238, 1234, '浦城', '浦城县', '中国,福建省,南平市,浦城县', 3, 'pucheng', '0606', '353400', 'P', '118.54007', '27.91888'),
+(1239, 1234, '光泽', '光泽县', '中国,福建省,南平市,光泽县', 3, 'guangze', '0607', '354100', 'G', '117.33346', '27.54231'),
+(1240, 1234, '松溪', '松溪县', '中国,福建省,南平市,松溪县', 3, 'songxi', '0608', '353500', 'S', '118.78533', '27.52624'),
+(1241, 1234, '政和', '政和县', '中国,福建省,南平市,政和县', 3, 'zhenghe', '0609', '353600', 'Z', '118.85571', '27.36769'),
+(1242, 1234, '邵武', '邵武市', '中国,福建省,南平市,邵武市', 3, 'shaowu', '0601', '354000', 'S', '117.4924', '27.34033'),
+(1243, 1234, '武夷山', '武夷山市', '中国,福建省,南平市,武夷山市', 3, 'wuyishan', '0602', '354300', 'W', '118.03665', '27.75543'),
+(1244, 1234, '建瓯', '建瓯市', '中国,福建省,南平市,建瓯市', 3, 'jianou', '0603', '353100', 'J', '118.29766', '27.02301'),
+(1245, 1168, '龙岩', '龙岩市', '中国,福建省,龙岩市', 2, 'longyan', '0597', '364000', 'L', '117.02978', '25.091603'),
+(1246, 1245, '新罗', '新罗区', '中国,福建省,龙岩市,新罗区', 3, 'xinluo', '0597', '364000', 'X', '117.03693', '25.09834'),
+(1247, 1245, '长汀', '长汀县', '中国,福建省,龙岩市,长汀县', 3, 'changting', '0597', '366300', 'C', '116.35888', '25.82773'),
+(1248, 1245, '永定', '永定区', '中国,福建省,龙岩市,永定区', 3, 'yongding', '0597', '364100', 'Y', '116.73199', '24.72302'),
+(1249, 1245, '上杭', '上杭县', '中国,福建省,龙岩市,上杭县', 3, 'shanghang', '0597', '364200', 'S', '116.42022', '25.04943'),
+(1250, 1245, '武平', '武平县', '中国,福建省,龙岩市,武平县', 3, 'wuping', '0597', '364300', 'W', '116.10229', '25.09244'),
+(1251, 1245, '连城', '连城县', '中国,福建省,龙岩市,连城县', 3, 'liancheng', '0597', '366200', 'L', '116.75454', '25.7103'),
+(1252, 1245, '漳平', '漳平市', '中国,福建省,龙岩市,漳平市', 3, 'zhangping', '0597', '364400', 'Z', '117.41992', '25.29109'),
+(1253, 1168, '宁德', '宁德市', '中国,福建省,宁德市', 2, 'ningde', '0593', '352100', 'N', '119.527082', '26.65924'),
+(1254, 1253, '蕉城', '蕉城区', '中国,福建省,宁德市,蕉城区', 3, 'jiaocheng', '0593', '352100', 'J', '119.52643', '26.66048'),
+(1255, 1253, '霞浦', '霞浦县', '中国,福建省,宁德市,霞浦县', 3, 'xiapu', '0593', '355100', 'X', '119.99893', '26.88578'),
+(1256, 1253, '古田', '古田县', '中国,福建省,宁德市,古田县', 3, 'gutian', '0593', '352200', 'G', '118.74688', '26.57682'),
+(1257, 1253, '屏南', '屏南县', '中国,福建省,宁德市,屏南县', 3, 'pingnan', '0593', '352300', 'P', '118.98861', '26.91099'),
+(1258, 1253, '寿宁', '寿宁县', '中国,福建省,宁德市,寿宁县', 3, 'shouning', '0593', '355500', 'S', '119.5039', '27.45996'),
+(1259, 1253, '周宁', '周宁县', '中国,福建省,宁德市,周宁县', 3, 'zhouning', '0593', '355400', 'Z', '119.33837', '27.10664'),
+(1260, 1253, '柘荣', '柘荣县', '中国,福建省,宁德市,柘荣县', 3, 'zherong', '0593', '355300', NULL, '119.89971', '27.23543'),
+(1261, 1253, '福安', '福安市', '中国,福建省,宁德市,福安市', 3, 'fu''an', '0593', '355000', 'F', '119.6495', '27.08673'),
+(1262, 1253, '福鼎', '福鼎市', '中国,福建省,宁德市,福鼎市', 3, 'fuding', '0593', '355200', 'F', '120.21664', '27.3243'),
+(1263, 0, '江西', '江西省', '中国,江西省', 1, 'jiangxi', '', '', 'J', '115.892151', '28.676493'),
+(1264, 1263, '南昌', '南昌市', '中国,江西省,南昌市', 2, 'nanchang', '0791', '330008', 'N', '115.892151', '28.676493'),
+(1265, 1264, '东湖', '东湖区', '中国,江西省,南昌市,东湖区', 3, 'donghu', '0791', '330006', 'D', '115.8988', '28.68505'),
+(1266, 1264, '西湖', '西湖区', '中国,江西省,南昌市,西湖区', 3, 'xihu', '0791', '330009', 'X', '115.87728', '28.65688'),
+(1267, 1264, '青云谱', '青云谱区', '中国,江西省,南昌市,青云谱区', 3, 'qingyunpu', '0791', '330001', 'Q', '115.915', '28.63199'),
+(1268, 1264, '湾里', '湾里区', '中国,江西省,南昌市,湾里区', 3, 'wanli', '0791', '330004', 'W', '115.73104', '28.71529'),
+(1269, 1264, '青山湖', '青山湖区', '中国,江西省,南昌市,青山湖区', 3, 'qingshanhu', '0791', '330029', 'Q', '115.9617', '28.68206'),
+(1270, 1264, '南昌', '南昌县', '中国,江西省,南昌市,南昌县', 3, 'nanchang', '0791', '330200', 'N', '115.94393', '28.54559'),
+(1271, 1264, '新建', '新建县', '中国,江西省,南昌市,新建县', 3, 'xinjian', '0791', '330100', 'X', '115.81546', '28.69248'),
+(1272, 1264, '安义', '安义县', '中国,江西省,南昌市,安义县', 3, 'anyi', '0791', '330500', 'A', '115.54879', '28.84602'),
+(1273, 1264, '进贤', '进贤县', '中国,江西省,南昌市,进贤县', 3, 'jinxian', '0791', '331700', 'J', '116.24087', '28.37679'),
+(1274, 1263, '景德镇', '景德镇市', '中国,江西省,景德镇市', 2, 'jingdezhen', '0798', '333000', 'J', '117.214664', '29.29256'),
+(1275, 1274, '昌江', '昌江区', '中国,江西省,景德镇市,昌江区', 3, 'changjiang', '0799', '333000', 'C', '117.18359', '29.27321'),
+(1276, 1274, '珠山', '珠山区', '中国,江西省,景德镇市,珠山区', 3, 'zhushan', '0800', '333000', 'Z', '117.20233', '29.30127'),
+(1277, 1274, '浮梁', '浮梁县', '中国,江西省,景德镇市,浮梁县', 3, 'fuliang', '0802', '333400', 'F', '117.21517', '29.35156'),
+(1278, 1274, '乐平', '乐平市', '中国,江西省,景德镇市,乐平市', 3, 'leping', '0801', '333300', 'L', '117.12887', '28.96295'),
+(1279, 1263, '萍乡', '萍乡市', '中国,江西省,萍乡市', 2, 'pingxiang', '0799', '337000', 'P', '113.852186', '27.622946'),
+(1280, 1279, '安源', '安源区', '中国,江西省,萍乡市,安源区', 3, 'anyuan', '0800', '337000', 'A', '113.89135', '27.61653'),
+(1281, 1279, '湘东', '湘东区', '中国,江西省,萍乡市,湘东区', 3, 'xiangdong', '0801', '337016', 'X', '113.73294', '27.64007'),
+(1282, 1279, '莲花', '莲花县', '中国,江西省,萍乡市,莲花县', 3, 'lianhua', '0802', '337100', 'L', '113.96142', '27.12866'),
+(1283, 1279, '上栗', '上栗县', '中国,江西省,萍乡市,上栗县', 3, 'shangli', '0803', '337009', 'S', '113.79403', '27.87467'),
+(1284, 1279, '芦溪', '芦溪县', '中国,江西省,萍乡市,芦溪县', 3, 'luxi', '0804', '337053', 'L', '114.02951', '27.63063'),
+(1285, 1263, '九江', '九江市', '中国,江西省,九江市', 2, 'jiujiang', '0792', '332000', 'J', '115.992811', '29.712034'),
+(1286, 1285, '庐山', '庐山区', '中国,江西省,九江市,庐山区', 3, 'lushan', '0792', '332005', 'L', '115.98904', '29.67177'),
+(1287, 1285, '浔阳', '浔阳区', '中国,江西省,九江市,浔阳区', 3, 'xunyang', '0792', '332000', NULL, '115.98986', '29.72786'),
+(1288, 1285, '九江', '九江县', '中国,江西省,九江市,九江县', 3, 'jiujiang', '0792', '332100', 'J', '115.91128', '29.60852'),
+(1289, 1285, '武宁', '武宁县', '中国,江西省,九江市,武宁县', 3, 'wuning', '0792', '332300', 'W', '115.10061', '29.2584'),
+(1290, 1285, '修水', '修水县', '中国,江西省,九江市,修水县', 3, 'xiushui', '0792', '332400', 'X', '114.54684', '29.02539'),
+(1291, 1285, '永修', '永修县', '中国,江西省,九江市,永修县', 3, 'yongxiu', '0792', '330300', 'Y', '115.80911', '29.02093'),
+(1292, 1285, '德安', '德安县', '中国,江西省,九江市,德安县', 3, 'de''an', '0792', '330400', 'D', '115.75601', '29.31341'),
+(1293, 1285, '星子', '星子县', '中国,江西省,九江市,星子县', 3, 'xingzi', '0792', '332800', 'X', '116.04492', '29.44608'),
+(1294, 1285, '都昌', '都昌县', '中国,江西省,九江市,都昌县', 3, 'duchang', '0792', '332600', 'D', '116.20401', '29.27327'),
+(1295, 1285, '湖口', '湖口县', '中国,江西省,九江市,湖口县', 3, 'hukou', '0792', '332500', 'H', '116.21853', '29.73818'),
+(1296, 1285, '彭泽', '彭泽县', '中国,江西省,九江市,彭泽县', 3, 'pengze', '0792', '332700', 'P', '116.55011', '29.89589'),
+(1297, 1285, '瑞昌', '瑞昌市', '中国,江西省,九江市,瑞昌市', 3, 'ruichang', '0792', '332200', 'R', '115.66705', '29.67183'),
+(1298, 1285, '共青城', '共青城市', '中国,江西省,九江市,共青城市', 3, 'gongqingcheng', '0792', '332020', 'G', '115.801939', '29.238785'),
+(1299, 1263, '新余', '新余市', '中国,江西省,新余市', 2, 'xinyu', '0790', '338025', 'X', '114.930835', '27.810834'),
+(1300, 1299, '渝水', '渝水区', '中国,江西省,新余市,渝水区', 3, 'yushui', '0790', '338025', 'Y', '114.944', '27.80098'),
+(1301, 1299, '分宜', '分宜县', '中国,江西省,新余市,分宜县', 3, 'fenyi', '0790', '336600', 'F', '114.69189', '27.81475'),
+(1302, 1263, '鹰潭', '鹰潭市', '中国,江西省,鹰潭市', 2, 'yingtan', '0701', '335000', 'Y', '117.033838', '28.238638'),
+(1303, 1302, '月湖', '月湖区', '中国,江西省,鹰潭市,月湖区', 3, 'yuehu', '0701', '335000', 'Y', '117.03732', '28.23913'),
+(1304, 1302, '余江', '余江县', '中国,江西省,鹰潭市,余江县', 3, 'yujiang', '0701', '335200', 'Y', '116.81851', '28.21034'),
+(1305, 1302, '贵溪', '贵溪市', '中国,江西省,鹰潭市,贵溪市', 3, 'guixi', '0701', '335400', 'G', '117.24246', '28.2926'),
+(1306, 1263, '赣州', '赣州市', '中国,江西省,赣州市', 2, 'ganzhou', '0797', '341000', 'G', '114.940278', '25.85097'),
+(1307, 1306, '章贡', '章贡区', '中国,江西省,赣州市,章贡区', 3, 'zhanggong', '0797', '341000', 'Z', '114.94284', '25.8624'),
+(1308, 1306, '南康', '南康区', '中国,江西省,赣州市,南康区', 3, 'nankang', '0797', '341400', 'N', '114.756933', '25.661721'),
+(1309, 1306, '赣县', '赣县', '中国,江西省,赣州市,赣县', 3, 'ganxian', '0797', '341100', 'G', '115.01171', '25.86149'),
+(1310, 1306, '信丰', '信丰县', '中国,江西省,赣州市,信丰县', 3, 'xinfeng', '0797', '341600', 'X', '114.92279', '25.38612'),
+(1311, 1306, '大余', '大余县', '中国,江西省,赣州市,大余县', 3, 'dayu', '0797', '341500', 'D', '114.35757', '25.39561'),
+(1312, 1306, '上犹', '上犹县', '中国,江西省,赣州市,上犹县', 3, 'shangyou', '0797', '341200', 'S', '114.54138', '25.79567'),
+(1313, 1306, '崇义', '崇义县', '中国,江西省,赣州市,崇义县', 3, 'chongyi', '0797', '341300', 'C', '114.30835', '25.68186'),
+(1314, 1306, '安远', '安远县', '中国,江西省,赣州市,安远县', 3, 'anyuan', '0797', '342100', 'A', '115.39483', '25.1371'),
+(1315, 1306, '龙南', '龙南县', '中国,江西省,赣州市,龙南县', 3, 'longnan', '0797', '341700', 'L', '114.78994', '24.91086'),
+(1316, 1306, '定南', '定南县', '中国,江西省,赣州市,定南县', 3, 'dingnan', '0797', '341900', 'D', '115.02713', '24.78395'),
+(1317, 1306, '全南', '全南县', '中国,江西省,赣州市,全南县', 3, 'quannan', '0797', '341800', 'Q', '114.5292', '24.74324'),
+(1318, 1306, '宁都', '宁都县', '中国,江西省,赣州市,宁都县', 3, 'ningdu', '0797', '342800', 'N', '116.01565', '26.47227'),
+(1319, 1306, '于都', '于都县', '中国,江西省,赣州市,于都县', 3, 'yudu', '0797', '342300', 'Y', '115.41415', '25.95257'),
+(1320, 1306, '兴国', '兴国县', '中国,江西省,赣州市,兴国县', 3, 'xingguo', '0797', '342400', 'X', '115.36309', '26.33776'),
+(1321, 1306, '会昌', '会昌县', '中国,江西省,赣州市,会昌县', 3, 'huichang', '0797', '342600', 'H', '115.78555', '25.60068'),
+(1322, 1306, '寻乌', '寻乌县', '中国,江西省,赣州市,寻乌县', 3, 'xunwu', '0797', '342200', 'X', '115.64852', '24.95513'),
+(1323, 1306, '石城', '石城县', '中国,江西省,赣州市,石城县', 3, 'shicheng', '0797', '342700', 'S', '116.3442', '26.32617'),
+(1324, 1306, '瑞金', '瑞金市', '中国,江西省,赣州市,瑞金市', 3, 'ruijin', '0797', '342500', 'R', '116.02703', '25.88557'),
+(1325, 1263, '吉安', '吉安市', '中国,江西省,吉安市', 2, 'ji''an', '0796', '343000', 'J', '114.986373', '27.111699'),
+(1326, 1325, '吉州', '吉州区', '中国,江西省,吉安市,吉州区', 3, 'jizhou', '0796', '343000', 'J', '114.97598', '27.10669'),
+(1327, 1325, '青原', '青原区', '中国,江西省,吉安市,青原区', 3, 'qingyuan', '0796', '343009', 'Q', '115.01747', '27.10577'),
+(1328, 1325, '吉安', '吉安县', '中国,江西省,吉安市,吉安县', 3, 'ji''an', '0796', '343100', 'J', '114.90695', '27.04048'),
+(1329, 1325, '吉水', '吉水县', '中国,江西省,吉安市,吉水县', 3, 'jishui', '0796', '331600', 'J', '115.1343', '27.21071'),
+(1330, 1325, '峡江', '峡江县', '中国,江西省,吉安市,峡江县', 3, 'xiajiang', '0796', '331409', 'X', '115.31723', '27.576'),
+(1331, 1325, '新干', '新干县', '中国,江西省,吉安市,新干县', 3, 'xingan', '0796', '331300', 'X', '115.39306', '27.74092'),
+(1332, 1325, '永丰', '永丰县', '中国,江西省,吉安市,永丰县', 3, 'yongfeng', '0796', '331500', 'Y', '115.44238', '27.31785'),
+(1333, 1325, '泰和', '泰和县', '中国,江西省,吉安市,泰和县', 3, 'taihe', '0796', '343700', 'T', '114.90789', '26.79113'),
+(1334, 1325, '遂川', '遂川县', '中国,江西省,吉安市,遂川县', 3, 'suichuan', '0796', '343900', 'S', '114.51629', '26.32598'),
+(1335, 1325, '万安', '万安县', '中国,江西省,吉安市,万安县', 3, 'wan''an', '0796', '343800', 'W', '114.78659', '26.45931'),
+(1336, 1325, '安福', '安福县', '中国,江西省,吉安市,安福县', 3, 'anfu', '0796', '343200', 'A', '114.61956', '27.39276'),
+(1337, 1325, '永新', '永新县', '中国,江西省,吉安市,永新县', 3, 'yongxin', '0796', '343400', 'Y', '114.24246', '26.94488'),
+(1338, 1325, '井冈山', '井冈山市', '中国,江西省,吉安市,井冈山市', 3, 'jinggangshan', '0796', '343600', 'J', '114.28949', '26.74804'),
+(1339, 1263, '宜春', '宜春市', '中国,江西省,宜春市', 2, 'yichun', '0795', '336000', 'Y', '114.391136', '27.8043'),
+(1340, 1339, '袁州', '袁州区', '中国,江西省,宜春市,袁州区', 3, 'yuanzhou', '0795', '336000', 'Y', '114.38246', '27.79649'),
+(1341, 1339, '奉新', '奉新县', '中国,江西省,宜春市,奉新县', 3, 'fengxin', '0795', '330700', 'F', '115.40036', '28.6879'),
+(1342, 1339, '万载', '万载县', '中国,江西省,宜春市,万载县', 3, 'wanzai', '0795', '336100', 'W', '114.4458', '28.10656'),
+(1343, 1339, '上高', '上高县', '中国,江西省,宜春市,上高县', 3, 'shanggao', '0795', '336400', 'S', '114.92459', '28.23423'),
+(1344, 1339, '宜丰', '宜丰县', '中国,江西省,宜春市,宜丰县', 3, 'yifeng', '0795', '336300', 'Y', '114.7803', '28.38555'),
+(1345, 1339, '靖安', '靖安县', '中国,江西省,宜春市,靖安县', 3, 'jing''an', '0795', '330600', 'J', '115.36279', '28.86167'),
+(1346, 1339, '铜鼓', '铜鼓县', '中国,江西省,宜春市,铜鼓县', 3, 'tonggu', '0795', '336200', 'T', '114.37036', '28.52311'),
+(1347, 1339, '丰城', '丰城市', '中国,江西省,宜春市,丰城市', 3, 'fengcheng', '0795', '331100', 'F', '115.77114', '28.15918'),
+(1348, 1339, '樟树', '樟树市', '中国,江西省,宜春市,樟树市', 3, 'zhangshu', '0795', '331200', 'Z', '115.5465', '28.05332'),
+(1349, 1339, '高安', '高安市', '中国,江西省,宜春市,高安市', 3, 'gao''an', '0795', '330800', 'G', '115.3753', '28.4178'),
+(1350, 1263, '抚州', '抚州市', '中国,江西省,抚州市', 2, 'fuzhou', '0794', '344000', 'F', '116.358351', '27.98385'),
+(1351, 1350, '临川', '临川区', '中国,江西省,抚州市,临川区', 3, 'linchuan', '0794', '344000', 'L', '116.35919', '27.97721'),
+(1352, 1350, '南城', '南城县', '中国,江西省,抚州市,南城县', 3, 'nancheng', '0794', '344700', 'N', '116.64419', '27.55381'),
+(1353, 1350, '黎川', '黎川县', '中国,江西省,抚州市,黎川县', 3, 'lichuan', '0794', '344600', 'L', '116.90771', '27.28232'),
+(1354, 1350, '南丰', '南丰县', '中国,江西省,抚州市,南丰县', 3, 'nanfeng', '0794', '344500', 'N', '116.5256', '27.21842'),
+(1355, 1350, '崇仁', '崇仁县', '中国,江西省,抚州市,崇仁县', 3, 'chongren', '0794', '344200', 'C', '116.06021', '27.75962'),
+(1356, 1350, '乐安', '乐安县', '中国,江西省,抚州市,乐安县', 3, 'le''an', '0794', '344300', 'L', '115.83108', '27.42812'),
+(1357, 1350, '宜黄', '宜黄县', '中国,江西省,抚州市,宜黄县', 3, 'yihuang', '0794', '344400', 'Y', '116.23626', '27.55487'),
+(1358, 1350, '金溪', '金溪县', '中国,江西省,抚州市,金溪县', 3, 'jinxi', '0794', '344800', 'J', '116.77392', '27.90753'),
+(1359, 1350, '资溪', '资溪县', '中国,江西省,抚州市,资溪县', 3, 'zixi', '0794', '335300', 'Z', '117.06939', '27.70493'),
+(1360, 1350, '东乡', '东乡县', '中国,江西省,抚州市,东乡县', 3, 'dongxiang', '0794', '331800', 'D', '116.59039', '28.23614'),
+(1361, 1350, '广昌', '广昌县', '中国,江西省,抚州市,广昌县', 3, 'guangchang', '0794', '344900', 'G', '116.32547', '26.8341'),
+(1362, 1263, '上饶', '上饶市', '中国,江西省,上饶市', 2, 'shangrao', '0793', '334000', 'S', '117.971185', '28.44442'),
+(1363, 1362, '信州', '信州区', '中国,江西省,上饶市,信州区', 3, 'xinzhou', '0793', '334000', 'X', '117.96682', '28.43121'),
+(1364, 1362, '上饶', '上饶县', '中国,江西省,上饶市,上饶县', 3, 'shangrao', '0793', '334100', 'S', '117.90884', '28.44856'),
+(1365, 1362, '广丰', '广丰县', '中国,江西省,上饶市,广丰县', 3, 'guangfeng', '0793', '334600', 'G', '118.19158', '28.43766'),
+(1366, 1362, '玉山', '玉山县', '中国,江西省,上饶市,玉山县', 3, 'yushan', '0793', '334700', 'Y', '118.24462', '28.6818'),
+(1367, 1362, '铅山', '铅山县', '中国,江西省,上饶市,铅山县', 3, 'yanshan', '0793', '334500', 'Q', '117.70996', '28.31549'),
+(1368, 1362, '横峰', '横峰县', '中国,江西省,上饶市,横峰县', 3, 'hengfeng', '0793', '334300', 'H', '117.5964', '28.40716'),
+(1369, 1362, '弋阳', '弋阳县', '中国,江西省,上饶市,弋阳县', 3, 'yiyang', '0793', '334400', NULL, '117.45929', '28.37451'),
+(1370, 1362, '余干', '余干县', '中国,江西省,上饶市,余干县', 3, 'yugan', '0793', '335100', 'Y', '116.69555', '28.70206'),
+(1371, 1362, '鄱阳', '鄱阳县', '中国,江西省,上饶市,鄱阳县', 3, 'poyang', '0793', '333100', NULL, '116.69967', '29.0118'),
+(1372, 1362, '万年', '万年县', '中国,江西省,上饶市,万年县', 3, 'wannian', '0793', '335500', 'W', '117.06884', '28.69537'),
+(1373, 1362, '婺源', '婺源县', '中国,江西省,上饶市,婺源县', 3, 'wuyuan', '0793', '333200', NULL, '117.86105', '29.24841'),
+(1374, 1362, '德兴', '德兴市', '中国,江西省,上饶市,德兴市', 3, 'dexing', '0793', '334200', 'D', '117.57919', '28.94736'),
+(1375, 0, '山东', '山东省', '中国,山东省', 1, 'shandong', '', '', 'S', '117.000923', '36.675807'),
+(1376, 1375, '济南', '济南市', '中国,山东省,济南市', 2, 'jinan', '0531', '250001', 'J', '117.000923', '36.675807'),
+(1377, 1376, '历下', '历下区', '中国,山东省,济南市,历下区', 3, 'lixia', '0531', '250014', 'L', '117.0768', '36.66661'),
+(1378, 1376, '市中区', '市中区', '中国,山东省,济南市,市中区', 3, 'shizhongqu', '0531', '250001', 'S', '116.99741', '36.65101'),
+(1379, 1376, '槐荫', '槐荫区', '中国,山东省,济南市,槐荫区', 3, 'huaiyin', '0531', '250117', 'H', '116.90075', '36.65136'),
+(1380, 1376, '天桥', '天桥区', '中国,山东省,济南市,天桥区', 3, 'tianqiao', '0531', '250031', 'T', '116.98749', '36.67801'),
+(1381, 1376, '历城', '历城区', '中国,山东省,济南市,历城区', 3, 'licheng', '0531', '250100', 'L', '117.06509', '36.67995'),
+(1382, 1376, '长清', '长清区', '中国,山东省,济南市,长清区', 3, 'changqing', '0531', '250300', 'C', '116.75192', '36.55352'),
+(1383, 1376, '平阴', '平阴县', '中国,山东省,济南市,平阴县', 3, 'pingyin', '0531', '250400', 'P', '116.45587', '36.28955'),
+(1384, 1376, '济阳', '济阳县', '中国,山东省,济南市,济阳县', 3, 'jiyang', '0531', '251400', 'J', '117.17327', '36.97845'),
+(1385, 1376, '商河', '商河县', '中国,山东省,济南市,商河县', 3, 'shanghe', '0531', '251600', 'S', '117.15722', '37.31119'),
+(1386, 1376, '章丘', '章丘市', '中国,山东省,济南市,章丘市', 3, 'zhangqiu', '0531', '250200', 'Z', '117.53677', '36.71392'),
+(1387, 1375, '青岛', '青岛市', '中国,山东省,青岛市', 2, 'qingdao', '0532', '266001', 'Q', '120.369557', '36.094406'),
+(1388, 1387, '市南', '市南区', '中国,山东省,青岛市,市南区', 3, 'shinan', '0532', '266001', 'S', '120.38773', '36.06671'),
+(1389, 1387, '市北', '市北区', '中国,山东省,青岛市,市北区', 3, 'shibei', '0532', '266011', 'S', '120.37469', '36.08734'),
+(1390, 1387, '黄岛', '黄岛区', '中国,山东省,青岛市,黄岛区', 3, 'huangdao', '0532', '266500', 'H', '120.19775', '35.96065'),
+(1391, 1387, '崂山', '崂山区', '中国,山东省,青岛市,崂山区', 3, 'laoshan', '0532', '266100', NULL, '120.46923', '36.10717'),
+(1392, 1387, '李沧', '李沧区', '中国,山东省,青岛市,李沧区', 3, 'licang', '0532', '266021', 'L', '120.43286', '36.14502'),
+(1393, 1387, '城阳', '城阳区', '中国,山东省,青岛市,城阳区', 3, 'chengyang', '0532', '266041', 'C', '120.39621', '36.30735'),
+(1394, 1387, '胶州', '胶州市', '中国,山东省,青岛市,胶州市', 3, 'jiaozhou', '0532', '266300', 'J', '120.0335', '36.26442'),
+(1395, 1387, '即墨', '即墨市', '中国,山东省,青岛市,即墨市', 3, 'jimo', '0532', '266200', 'J', '120.44699', '36.38907'),
+(1396, 1387, '平度', '平度市', '中国,山东省,青岛市,平度市', 3, 'pingdu', '0532', '266700', 'P', '119.95996', '36.78688'),
+(1397, 1387, '莱西', '莱西市', '中国,山东省,青岛市,莱西市', 3, 'laixi', '0532', '266600', 'L', '120.51773', '36.88804'),
+(1398, 1387, '西海岸', '西海岸新区', '中国,山东省,青岛市,西海岸新区', 3, 'xihai''an', '0532', '266500', 'X', '120.19775', '35.96065'),
+(1399, 1375, '淄博', '淄博市', '中国,山东省,淄博市', 2, 'zibo', '0533', '255039', 'Z', '118.047648', '36.814939'),
+(1400, 1399, '淄川', '淄川区', '中国,山东省,淄博市,淄川区', 3, 'zichuan', '0533', '255100', 'Z', '117.96655', '36.64339'),
+(1401, 1399, '张店', '张店区', '中国,山东省,淄博市,张店区', 3, 'zhangdian', '0533', '255022', 'Z', '118.01788', '36.80676'),
+(1402, 1399, '博山', '博山区', '中国,山东省,淄博市,博山区', 3, 'boshan', '0533', '255200', 'B', '117.86166', '36.49469'),
+(1403, 1399, '临淄', '临淄区', '中国,山东省,淄博市,临淄区', 3, 'linzi', '0533', '255400', 'L', '118.30966', '36.8259'),
+(1404, 1399, '周村', '周村区', '中国,山东省,淄博市,周村区', 3, 'zhoucun', '0533', '255300', 'Z', '117.86969', '36.80322'),
+(1405, 1399, '桓台', '桓台县', '中国,山东省,淄博市,桓台县', 3, 'huantai', '0533', '256400', 'H', '118.09698', '36.96036'),
+(1406, 1399, '高青', '高青县', '中国,山东省,淄博市,高青县', 3, 'gaoqing', '0533', '256300', 'G', '117.82708', '37.17197'),
+(1407, 1399, '沂源', '沂源县', '中国,山东省,淄博市,沂源县', 3, 'yiyuan', '0533', '256100', 'Y', '118.17105', '36.18536'),
+(1408, 1375, '枣庄', '枣庄市', '中国,山东省,枣庄市', 2, 'zaozhuang', '0632', '277101', 'Z', '117.557964', '34.856424'),
+(1409, 1408, '市中区', '市中区', '中国,山东省,枣庄市,市中区', 3, 'shizhongqu', '0632', '277101', 'S', '117.55603', '34.86391'),
+(1410, 1408, '薛城', '薛城区', '中国,山东省,枣庄市,薛城区', 3, 'xuecheng', '0632', '277000', 'X', '117.26318', '34.79498'),
+(1411, 1408, '峄城', '峄城区', '中国,山东省,枣庄市,峄城区', 3, 'yicheng', '0632', '277300', NULL, '117.59057', '34.77225'),
+(1412, 1408, '台儿庄', '台儿庄区', '中国,山东省,枣庄市,台儿庄区', 3, 'taierzhuang', '0632', '277400', 'T', '117.73452', '34.56363'),
+(1413, 1408, '山亭', '山亭区', '中国,山东省,枣庄市,山亭区', 3, 'shanting', '0632', '277200', 'S', '117.4663', '35.09541'),
+(1414, 1408, '滕州', '滕州市', '中国,山东省,枣庄市,滕州市', 3, 'tengzhou', '0632', '277500', NULL, '117.165', '35.10534'),
+(1415, 1375, '东营', '东营市', '中国,山东省,东营市', 2, 'dongying', '0546', '257093', 'D', '118.4963', '37.461266'),
+(1416, 1415, '东营', '东营区', '中国,山东省,东营市,东营区', 3, 'dongying', '0546', '257029', 'D', '118.5816', '37.44875'),
+(1417, 1415, '河口', '河口区', '中国,山东省,东营市,河口区', 3, 'hekou', '0546', '257200', 'H', '118.5249', '37.88541'),
+(1418, 1415, '垦利', '垦利县', '中国,山东省,东营市,垦利县', 3, 'kenli', '0546', '257500', 'K', '118.54815', '37.58825'),
+(1419, 1415, '利津', '利津县', '中国,山东省,东营市,利津县', 3, 'lijin', '0546', '257400', 'L', '118.25637', '37.49157'),
+(1420, 1415, '广饶', '广饶县', '中国,山东省,东营市,广饶县', 3, 'guangrao', '0546', '257300', 'G', '118.40704', '37.05381'),
+(1421, 1375, '烟台', '烟台市', '中国,山东省,烟台市', 2, 'yantai', '0635', '264010', 'Y', '121.391382', '37.539297'),
+(1422, 1421, '芝罘', '芝罘区', '中国,山东省,烟台市,芝罘区', 3, 'zhifu', '0635', '264001', 'Z', '121.40023', '37.54064'),
+(1423, 1421, '福山', '福山区', '中国,山东省,烟台市,福山区', 3, 'fushan', '0635', '265500', 'F', '121.26812', '37.49841'),
+(1424, 1421, '牟平', '牟平区', '中国,山东省,烟台市,牟平区', 3, 'muping', '0635', '264100', 'M', '121.60067', '37.38846'),
+(1425, 1421, '莱山', '莱山区', '中国,山东省,烟台市,莱山区', 3, 'laishan', '0635', '264600', 'L', '121.44512', '37.51165'),
+(1426, 1421, '长岛', '长岛县', '中国,山东省,烟台市,长岛县', 3, 'changdao', '0635', '265800', 'C', '120.738', '37.91754'),
+(1427, 1421, '龙口', '龙口市', '中国,山东省,烟台市,龙口市', 3, 'longkou', '0635', '265700', 'L', '120.50634', '37.64064'),
+(1428, 1421, '莱阳', '莱阳市', '中国,山东省,烟台市,莱阳市', 3, 'laiyang', '0635', '265200', 'L', '120.71066', '36.98012'),
+(1429, 1421, '莱州', '莱州市', '中国,山东省,烟台市,莱州市', 3, 'laizhou', '0635', '261400', 'L', '119.94137', '37.17806'),
+(1430, 1421, '蓬莱', '蓬莱市', '中国,山东省,烟台市,蓬莱市', 3, 'penglai', '0635', '265600', 'P', '120.75988', '37.81119'),
+(1431, 1421, '招远', '招远市', '中国,山东省,烟台市,招远市', 3, 'zhaoyuan', '0635', '265400', 'Z', '120.40481', '37.36269'),
+(1432, 1421, '栖霞', '栖霞市', '中国,山东省,烟台市,栖霞市', 3, 'qixia', '0635', '265300', 'Q', '120.85025', '37.33571'),
+(1433, 1421, '海阳', '海阳市', '中国,山东省,烟台市,海阳市', 3, 'haiyang', '0635', '265100', 'H', '121.15976', '36.77622'),
+(1434, 1375, '潍坊', '潍坊市', '中国,山东省,潍坊市', 2, 'weifang', '0536', '261041', 'W', '119.107078', '36.70925'),
+(1435, 1434, '潍城', '潍城区', '中国,山东省,潍坊市,潍城区', 3, 'weicheng', '0536', '261021', 'W', '119.10582', '36.7139');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(1436, 1434, '寒亭', '寒亭区', '中国,山东省,潍坊市,寒亭区', 3, 'hanting', '0536', '261100', 'H', '119.21832', '36.77504'),
+(1437, 1434, '坊子', '坊子区', '中国,山东省,潍坊市,坊子区', 3, 'fangzi', '0536', '261200', 'F', '119.16476', '36.65218'),
+(1438, 1434, '奎文', '奎文区', '中国,山东省,潍坊市,奎文区', 3, 'kuiwen', '0536', '261031', 'K', '119.12532', '36.70723'),
+(1439, 1434, '临朐', '临朐县', '中国,山东省,潍坊市,临朐县', 3, 'linqu', '0536', '262600', 'L', '118.544', '36.51216'),
+(1440, 1434, '昌乐', '昌乐县', '中国,山东省,潍坊市,昌乐县', 3, 'changle', '0536', '262400', 'C', '118.83017', '36.7078'),
+(1441, 1434, '青州', '青州市', '中国,山东省,潍坊市,青州市', 3, 'qingzhou', '0536', '262500', 'Q', '118.47915', '36.68505'),
+(1442, 1434, '诸城', '诸城市', '中国,山东省,潍坊市,诸城市', 3, 'zhucheng', '0536', '262200', 'Z', '119.40988', '35.99662'),
+(1443, 1434, '寿光', '寿光市', '中国,山东省,潍坊市,寿光市', 3, 'shouguang', '0536', '262700', 'S', '118.74047', '36.88128'),
+(1444, 1434, '安丘', '安丘市', '中国,山东省,潍坊市,安丘市', 3, 'anqiu', '0536', '262100', 'A', '119.2189', '36.47847'),
+(1445, 1434, '高密', '高密市', '中国,山东省,潍坊市,高密市', 3, 'gaomi', '0536', '261500', 'G', '119.75701', '36.38397'),
+(1446, 1434, '昌邑', '昌邑市', '中国,山东省,潍坊市,昌邑市', 3, 'changyi', '0536', '261300', 'C', '119.39767', '36.86008'),
+(1447, 1375, '济宁', '济宁市', '中国,山东省,济宁市', 2, 'jining', '0537', '272119', 'J', '116.587245', '35.415393'),
+(1448, 1447, '任城', '任城区', '中国,山东省,济宁市,任城区', 3, 'rencheng', '0537', '272113', 'R', '116.59504', '35.40659'),
+(1449, 1447, '兖州', '兖州区', '中国,山东省,济宁市,兖州区', 3, 'yanzhou', '0537', '272000', NULL, '116.826546', '35.552305'),
+(1450, 1447, '微山', '微山县', '中国,山东省,济宁市,微山县', 3, 'weishan', '0537', '277600', 'W', '117.12875', '34.80712'),
+(1451, 1447, '鱼台', '鱼台县', '中国,山东省,济宁市,鱼台县', 3, 'yutai', '0537', '272300', 'Y', '116.64761', '34.99674'),
+(1452, 1447, '金乡', '金乡县', '中国,山东省,济宁市,金乡县', 3, 'jinxiang', '0537', '272200', 'J', '116.31146', '35.065'),
+(1453, 1447, '嘉祥', '嘉祥县', '中国,山东省,济宁市,嘉祥县', 3, 'jiaxiang', '0537', '272400', 'J', '116.34249', '35.40836'),
+(1454, 1447, '汶上', '汶上县', '中国,山东省,济宁市,汶上县', 3, 'wenshang', '0537', '272501', NULL, '116.48742', '35.73295'),
+(1455, 1447, '泗水', '泗水县', '中国,山东省,济宁市,泗水县', 3, 'sishui', '0537', '273200', NULL, '117.27948', '35.66113'),
+(1456, 1447, '梁山', '梁山县', '中国,山东省,济宁市,梁山县', 3, 'liangshan', '0537', '272600', 'L', '116.09683', '35.80322'),
+(1457, 1447, '曲阜', '曲阜市', '中国,山东省,济宁市,曲阜市', 3, 'qufu', '0537', '273100', 'Q', '116.98645', '35.58091'),
+(1458, 1447, '邹城', '邹城市', '中国,山东省,济宁市,邹城市', 3, 'zoucheng', '0537', '273500', 'Z', '116.97335', '35.40531'),
+(1459, 1375, '泰安', '泰安市', '中国,山东省,泰安市', 2, 'tai''an', '0538', '271000', 'T', '117.129063', '36.194968'),
+(1460, 1459, '泰山', '泰山区', '中国,山东省,泰安市,泰山区', 3, 'taishan', '0538', '271000', 'T', '117.13446', '36.19411'),
+(1461, 1459, '岱岳', '岱岳区', '中国,山东省,泰安市,岱岳区', 3, 'daiyue', '0538', '271000', NULL, '117.04174', '36.1875'),
+(1462, 1459, '宁阳', '宁阳县', '中国,山东省,泰安市,宁阳县', 3, 'ningyang', '0538', '271400', 'N', '116.80542', '35.7599'),
+(1463, 1459, '东平', '东平县', '中国,山东省,泰安市,东平县', 3, 'dongping', '0538', '271500', 'D', '116.47113', '35.93792'),
+(1464, 1459, '新泰', '新泰市', '中国,山东省,泰安市,新泰市', 3, 'xintai', '0538', '271200', 'X', '117.76959', '35.90887'),
+(1465, 1459, '肥城', '肥城市', '中国,山东省,泰安市,肥城市', 3, 'feicheng', '0538', '271600', 'F', '116.76815', '36.18247'),
+(1466, 1375, '威海', '威海市', '中国,山东省,威海市', 2, 'weihai', '0631', '264200', 'W', '122.116394', '37.509691'),
+(1467, 1466, '环翠', '环翠区', '中国,山东省,威海市,环翠区', 3, 'huancui', '0631', '264200', 'H', '122.12344', '37.50199'),
+(1468, 1466, '文登', '文登区', '中国,山东省,威海市,文登区', 3, 'wendeng', '0631', '266440', 'W', '122.057139', '37.196211'),
+(1469, 1466, '荣成', '荣成市', '中国,山东省,威海市,荣成市', 3, 'rongcheng', '0631', '264300', 'R', '122.48773', '37.1652'),
+(1470, 1466, '乳山', '乳山市', '中国,山东省,威海市,乳山市', 3, 'rushan', '0631', '264500', 'R', '121.53814', '36.91918'),
+(1471, 1375, '日照', '日照市', '中国,山东省,日照市', 2, 'rizhao', '0633', '276800', 'R', '119.461208', '35.428588'),
+(1472, 1471, '东港', '东港区', '中国,山东省,日照市,东港区', 3, 'donggang', '0633', '276800', 'D', '119.46237', '35.42541'),
+(1473, 1471, '岚山', '岚山区', '中国,山东省,日照市,岚山区', 3, 'lanshan', '0633', '276808', NULL, '119.31884', '35.12203'),
+(1474, 1471, '五莲', '五莲县', '中国,山东省,日照市,五莲县', 3, 'wulian', '0633', '262300', 'W', '119.207', '35.75004'),
+(1475, 1471, '莒县', '莒县', '中国,山东省,日照市,莒县', 3, 'juxian', '0633', '276500', NULL, '118.83789', '35.58054'),
+(1476, 1375, '莱芜', '莱芜市', '中国,山东省,莱芜市', 2, 'laiwu', '0634', '271100', 'L', '117.677736', '36.214397'),
+(1477, 1476, '莱城', '莱城区', '中国,山东省,莱芜市,莱城区', 3, 'laicheng', '0634', '271199', 'L', '117.65986', '36.2032'),
+(1478, 1476, '钢城', '钢城区', '中国,山东省,莱芜市,钢城区', 3, 'gangcheng', '0634', '271100', 'G', '117.8049', '36.06319'),
+(1479, 1375, '临沂', '临沂市', '中国,山东省,临沂市', 2, 'linyi', '0539', '253000', 'L', '118.326443', '35.065282'),
+(1480, 1479, '兰山', '兰山区', '中国,山东省,临沂市,兰山区', 3, 'lanshan', '0539', '276002', 'L', '118.34817', '35.06872'),
+(1481, 1479, '罗庄', '罗庄区', '中国,山东省,临沂市,罗庄区', 3, 'luozhuang', '0539', '276022', 'L', '118.28466', '34.99627'),
+(1482, 1479, '河东', '河东区', '中国,山东省,临沂市,河东区', 3, 'hedong', '0539', '276034', 'H', '118.41055', '35.08803'),
+(1483, 1479, '沂南', '沂南县', '中国,山东省,临沂市,沂南县', 3, 'yinan', '0539', '276300', 'Y', '118.47061', '35.55131'),
+(1484, 1479, '郯城', '郯城县', '中国,山东省,临沂市,郯城县', 3, 'tancheng', '0539', '276100', NULL, '118.36712', '34.61354'),
+(1485, 1479, '沂水', '沂水县', '中国,山东省,临沂市,沂水县', 3, 'yishui', '0539', '276400', 'Y', '118.63009', '35.78731'),
+(1486, 1479, '兰陵', '兰陵县', '中国,山东省,临沂市,兰陵县', 3, 'lanling', '0539', '277700', 'L', '117.856592', '34.738315'),
+(1487, 1479, '费县', '费县', '中国,山东省,临沂市,费县', 3, 'feixian', '0539', '273400', 'F', '117.97836', '35.26562'),
+(1488, 1479, '平邑', '平邑县', '中国,山东省,临沂市,平邑县', 3, 'pingyi', '0539', '273300', 'P', '117.63867', '35.50573'),
+(1489, 1479, '莒南', '莒南县', '中国,山东省,临沂市,莒南县', 3, 'junan', '0539', '276600', NULL, '118.83227', '35.17539'),
+(1490, 1479, '蒙阴', '蒙阴县', '中国,山东省,临沂市,蒙阴县', 3, 'mengyin', '0539', '276200', 'M', '117.94592', '35.70996'),
+(1491, 1479, '临沭', '临沭县', '中国,山东省,临沂市,临沭县', 3, 'linshu', '0539', '276700', 'L', '118.65267', '34.92091'),
+(1492, 1375, '德州', '德州市', '中国,山东省,德州市', 2, 'dezhou', '0534', '253000', 'D', '116.307428', '37.453968'),
+(1493, 1492, '德城', '德城区', '中国,山东省,德州市,德城区', 3, 'decheng', '0534', '253012', 'D', '116.29943', '37.45126'),
+(1494, 1492, '陵城', '陵城区', '中国,山东省,德州市,陵城区', 3, 'lingcheng', '0534', '253500', 'L', '116.57601', '37.33571'),
+(1495, 1492, '宁津', '宁津县', '中国,山东省,德州市,宁津县', 3, 'ningjin', '0534', '253400', 'N', '116.79702', '37.65301'),
+(1496, 1492, '庆云', '庆云县', '中国,山东省,德州市,庆云县', 3, 'qingyun', '0534', '253700', 'Q', '117.38635', '37.77616'),
+(1497, 1492, '临邑', '临邑县', '中国,山东省,德州市,临邑县', 3, 'linyi', '0534', '251500', 'L', '116.86547', '37.19053'),
+(1498, 1492, '齐河', '齐河县', '中国,山东省,德州市,齐河县', 3, 'qihe', '0534', '251100', 'Q', '116.75515', '36.79532'),
+(1499, 1492, '平原', '平原县', '中国,山东省,德州市,平原县', 3, 'pingyuan', '0534', '253100', 'P', '116.43432', '37.16632'),
+(1500, 1492, '夏津', '夏津县', '中国,山东省,德州市,夏津县', 3, 'xiajin', '0534', '253200', 'X', '116.0017', '36.94852'),
+(1501, 1492, '武城', '武城县', '中国,山东省,德州市,武城县', 3, 'wucheng', '0534', '253300', 'W', '116.07009', '37.21403'),
+(1502, 1492, '乐陵', '乐陵市', '中国,山东省,德州市,乐陵市', 3, 'leling', '0534', '253600', 'L', '117.23141', '37.73164'),
+(1503, 1492, '禹城', '禹城市', '中国,山东省,德州市,禹城市', 3, 'yucheng', '0534', '251200', 'Y', '116.64309', '36.93444'),
+(1504, 1375, '聊城', '聊城市', '中国,山东省,聊城市', 2, 'liaocheng', '0635', '252052', 'L', '115.980367', '36.456013'),
+(1505, 1504, '东昌府', '东昌府区', '中国,山东省,聊城市,东昌府区', 3, 'dongchangfu', '0635', '252000', 'D', '115.97383', '36.44458'),
+(1506, 1504, '阳谷', '阳谷县', '中国,山东省,聊城市,阳谷县', 3, 'yanggu', '0635', '252300', 'Y', '115.79126', '36.11444'),
+(1507, 1504, '莘县', '莘县', '中国,山东省,聊城市,莘县', 3, 'shenxian', '0635', '252400', NULL, '115.6697', '36.23423'),
+(1508, 1504, '茌平', '茌平县', '中国,山东省,聊城市,茌平县', 3, 'chiping', '0635', '252100', NULL, '116.25491', '36.57969'),
+(1509, 1504, '东阿', '东阿县', '中国,山东省,聊城市,东阿县', 3, 'dong''e', '0635', '252200', 'D', '116.25012', '36.33209'),
+(1510, 1504, '冠县', '冠县', '中国,山东省,聊城市,冠县', 3, 'guanxian', '0635', '252500', 'G', '115.44195', '36.48429'),
+(1511, 1504, '高唐', '高唐县', '中国,山东省,聊城市,高唐县', 3, 'gaotang', '0635', '252800', 'G', '116.23172', '36.86535'),
+(1512, 1504, '临清', '临清市', '中国,山东省,聊城市,临清市', 3, 'linqing', '0635', '252600', 'L', '115.70629', '36.83945'),
+(1513, 1375, '滨州', '滨州市', '中国,山东省,滨州市', 2, 'binzhou', '0543', '256619', 'B', '118.016974', '37.383542'),
+(1514, 1513, '滨城', '滨城区', '中国,山东省,滨州市,滨城区', 3, 'bincheng', '0543', '256613', 'B', '118.02026', '37.38524'),
+(1515, 1513, '沾化', '沾化区', '中国,山东省,滨州市,沾化区', 3, 'zhanhua', '0543', '256800', 'Z', '118.13214', '37.69832'),
+(1516, 1513, '惠民', '惠民县', '中国,山东省,滨州市,惠民县', 3, 'huimin', '0543', '251700', 'H', '117.51113', '37.49013'),
+(1517, 1513, '阳信', '阳信县', '中国,山东省,滨州市,阳信县', 3, 'yangxin', '0543', '251800', 'Y', '117.58139', '37.64198'),
+(1518, 1513, '无棣', '无棣县', '中国,山东省,滨州市,无棣县', 3, 'wudi', '0543', '251900', 'W', '117.61395', '37.74009'),
+(1519, 1513, '博兴', '博兴县', '中国,山东省,滨州市,博兴县', 3, 'boxing', '0543', '256500', 'B', '118.1336', '37.14316'),
+(1520, 1513, '邹平', '邹平县', '中国,山东省,滨州市,邹平县', 3, 'zouping', '0543', '256200', 'Z', '117.74307', '36.86295'),
+(1521, 1513, '北海新区', '北海新区', '中国,山东省,滨州市,北海新区', 3, 'beihaixinqu', '0543', '256200', 'B', '118.016974', '37.383542'),
+(1522, 1375, '菏泽', '菏泽市', '中国,山东省,菏泽市', 2, 'heze', '0530', '274020', 'H', '115.469381', '35.246531'),
+(1523, 1522, '牡丹', '牡丹区', '中国,山东省,菏泽市,牡丹区', 3, 'mudan', '0530', '274009', 'M', '115.41662', '35.25091'),
+(1524, 1522, '曹县', '曹县', '中国,山东省,菏泽市,曹县', 3, 'caoxian', '0530', '274400', 'C', '115.54226', '34.82659'),
+(1525, 1522, '单县', '单县', '中国,山东省,菏泽市,单县', 3, 'shanxian', '0530', '273700', 'D', '116.08703', '34.79514'),
+(1526, 1522, '成武', '成武县', '中国,山东省,菏泽市,成武县', 3, 'chengwu', '0530', '274200', 'C', '115.8897', '34.95332'),
+(1527, 1522, '巨野', '巨野县', '中国,山东省,菏泽市,巨野县', 3, 'juye', '0530', '274900', 'J', '116.09497', '35.39788'),
+(1528, 1522, '郓城', '郓城县', '中国,山东省,菏泽市,郓城县', 3, 'yuncheng', '0530', '274700', NULL, '115.94439', '35.60044'),
+(1529, 1522, '鄄城', '鄄城县', '中国,山东省,菏泽市,鄄城县', 3, 'juancheng', '0530', '274600', NULL, '115.50997', '35.56412'),
+(1530, 1522, '定陶', '定陶县', '中国,山东省,菏泽市,定陶县', 3, 'dingtao', '0530', '274100', 'D', '115.57287', '35.07118'),
+(1531, 1522, '东明', '东明县', '中国,山东省,菏泽市,东明县', 3, 'dongming', '0530', '274500', 'D', '115.09079', '35.28906'),
+(1532, 0, '河南', '河南省', '中国,河南省', 1, 'henan', '', '', 'H', '113.665412', '34.757975'),
+(1533, 1532, '郑州', '郑州市', '中国,河南省,郑州市', 2, 'zhengzhou', '0371', '450000', 'Z', '113.665412', '34.757975'),
+(1534, 1533, '中原', '中原区', '中国,河南省,郑州市,中原区', 3, 'zhongyuan', '0371', '450007', 'Z', '113.61333', '34.74827'),
+(1535, 1533, '二七', '二七区', '中国,河南省,郑州市,二七区', 3, 'erqi', '0371', '450052', 'E', '113.63931', '34.72336'),
+(1536, 1533, '管城', '管城回族区', '中国,河南省,郑州市,管城回族区', 3, 'guancheng', '0371', '450000', 'G', '113.67734', '34.75383'),
+(1537, 1533, '金水', '金水区', '中国,河南省,郑州市,金水区', 3, 'jinshui', '0371', '450003', 'J', '113.66057', '34.80028'),
+(1538, 1533, '上街', '上街区', '中国,河南省,郑州市,上街区', 3, 'shangjie', '0371', '450041', 'S', '113.30897', '34.80276'),
+(1539, 1533, '惠济', '惠济区', '中国,河南省,郑州市,惠济区', 3, 'huiji', '0371', '450053', 'H', '113.61688', '34.86735'),
+(1540, 1533, '中牟', '中牟县', '中国,河南省,郑州市,中牟县', 3, 'zhongmu', '0371', '451450', 'Z', '113.97619', '34.71899'),
+(1541, 1533, '巩义', '巩义市', '中国,河南省,郑州市,巩义市', 3, 'gongyi', '0371', '451200', 'G', '113.022', '34.74794'),
+(1542, 1533, '荥阳', '荥阳市', '中国,河南省,郑州市,荥阳市', 3, 'xingyang', '0371', '450100', NULL, '113.38345', '34.78759'),
+(1543, 1533, '新密', '新密市', '中国,河南省,郑州市,新密市', 3, 'xinmi', '0371', '452300', 'X', '113.3869', '34.53704'),
+(1544, 1533, '新郑', '新郑市', '中国,河南省,郑州市,新郑市', 3, 'xinzheng', '0371', '451100', 'X', '113.73645', '34.3955'),
+(1545, 1533, '登封', '登封市', '中国,河南省,郑州市,登封市', 3, 'dengfeng', '0371', '452470', 'D', '113.05023', '34.45345'),
+(1546, 1532, '开封', '开封市', '中国,河南省,开封市', 2, 'kaifeng', '0378', '475001', 'K', '114.341447', '34.797049'),
+(1547, 1546, '龙亭', '龙亭区', '中国,河南省,开封市,龙亭区', 3, 'longting', '0378', '475100', 'L', '114.35484', '34.79995'),
+(1548, 1546, '顺河', '顺河回族区', '中国,河南省,开封市,顺河回族区', 3, 'shunhe', '0378', '475000', 'S', '114.36123', '34.79586'),
+(1549, 1546, '鼓楼', '鼓楼区', '中国,河南省,开封市,鼓楼区', 3, 'gulou', '0378', '475000', 'G', '114.35559', '34.79517'),
+(1550, 1546, '禹王台', '禹王台区', '中国,河南省,开封市,禹王台区', 3, 'yuwangtai', '0378', '475003', 'Y', '114.34787', '34.77693'),
+(1551, 1546, '祥符', '祥符区', '中国,河南省,开封市,祥符区', 3, 'xiangfu', '0378', '475100', 'X', '114.43859', '34.75874'),
+(1552, 1546, '杞县', '杞县', '中国,河南省,开封市,杞县', 3, 'qixian', '0378', '475200', NULL, '114.7828', '34.55033'),
+(1553, 1546, '通许', '通许县', '中国,河南省,开封市,通许县', 3, 'tongxu', '0378', '475400', 'T', '114.46716', '34.47522'),
+(1554, 1546, '尉氏', '尉氏县', '中国,河南省,开封市,尉氏县', 3, 'weishi', '0378', '475500', 'W', '114.19284', '34.41223'),
+(1555, 1546, '兰考', '兰考县', '中国,河南省,开封市,兰考县', 3, 'lankao', '0378', '475300', 'L', '114.81961', '34.8235'),
+(1556, 1532, '洛阳', '洛阳市', '中国,河南省,洛阳市', 2, 'luoyang', '0379', '471000', 'L', '112.434468', '34.663041'),
+(1557, 1556, '老城', '老城区', '中国,河南省,洛阳市,老城区', 3, 'laocheng', '0379', '471002', 'L', '112.46902', '34.68364'),
+(1558, 1556, '西工', '西工区', '中国,河南省,洛阳市,西工区', 3, 'xigong', '0379', '471000', 'X', '112.4371', '34.67'),
+(1559, 1556, '瀍河', '瀍河回族区', '中国,河南省,洛阳市,瀍河回族区', 3, 'chanhe', '0379', '471002', NULL, '112.50018', '34.67985'),
+(1560, 1556, '涧西', '涧西区', '中国,河南省,洛阳市,涧西区', 3, 'jianxi', '0379', '471003', 'J', '112.39588', '34.65823'),
+(1561, 1556, '吉利', '吉利区', '中国,河南省,洛阳市,吉利区', 3, 'jili', '0379', '471012', 'J', '112.58905', '34.90088'),
+(1562, 1556, '洛龙', '洛龙区', '中国,河南省,洛阳市,洛龙区', 3, 'luolong', '0379', '471000', 'L', '112.46412', '34.61866'),
+(1563, 1556, '孟津', '孟津县', '中国,河南省,洛阳市,孟津县', 3, 'mengjin', '0379', '471100', 'M', '112.44351', '34.826'),
+(1564, 1556, '新安', '新安县', '中国,河南省,洛阳市,新安县', 3, 'xin''an', '0379', '471800', 'X', '112.13238', '34.72814'),
+(1565, 1556, '栾川', '栾川县', '中国,河南省,洛阳市,栾川县', 3, 'luanchuan', '0379', '471500', NULL, '111.61779', '33.78576'),
+(1566, 1556, '嵩县', '嵩县', '中国,河南省,洛阳市,嵩县', 3, 'songxian', '0379', '471400', NULL, '112.08526', '34.13466'),
+(1567, 1556, '汝阳', '汝阳县', '中国,河南省,洛阳市,汝阳县', 3, 'ruyang', '0379', '471200', 'R', '112.47314', '34.15387'),
+(1568, 1556, '宜阳', '宜阳县', '中国,河南省,洛阳市,宜阳县', 3, 'yiyang', '0379', '471600', 'Y', '112.17907', '34.51523'),
+(1569, 1556, '洛宁', '洛宁县', '中国,河南省,洛阳市,洛宁县', 3, 'luoning', '0379', '471700', 'L', '111.65087', '34.38913'),
+(1570, 1556, '伊川', '伊川县', '中国,河南省,洛阳市,伊川县', 3, 'yichuan', '0379', '471300', 'Y', '112.42947', '34.42205'),
+(1571, 1556, '偃师', '偃师市', '中国,河南省,洛阳市,偃师市', 3, 'yanshi', '0379', '471900', NULL, '112.7922', '34.7281'),
+(1572, 1532, '平顶山', '平顶山市', '中国,河南省,平顶山市', 2, 'pingdingshan', '0375', '467000', 'P', '113.307718', '33.735241'),
+(1573, 1572, '新华', '新华区', '中国,河南省,平顶山市,新华区', 3, 'xinhua', '0375', '467002', 'X', '113.29402', '33.7373'),
+(1574, 1572, '卫东', '卫东区', '中国,河南省,平顶山市,卫东区', 3, 'weidong', '0375', '467021', 'W', '113.33511', '33.73472'),
+(1575, 1572, '石龙', '石龙区', '中国,河南省,平顶山市,石龙区', 3, 'shilong', '0375', '467045', 'S', '112.89879', '33.89878'),
+(1576, 1572, '湛河', '湛河区', '中国,河南省,平顶山市,湛河区', 3, 'zhanhe', '0375', '467000', 'Z', '113.29252', '33.7362'),
+(1577, 1572, '宝丰', '宝丰县', '中国,河南省,平顶山市,宝丰县', 3, 'baofeng', '0375', '467400', 'B', '113.05493', '33.86916'),
+(1578, 1572, '叶县', '叶县', '中国,河南省,平顶山市,叶县', 3, 'yexian', '0375', '467200', 'Y', '113.35104', '33.62225'),
+(1579, 1572, '鲁山', '鲁山县', '中国,河南省,平顶山市,鲁山县', 3, 'lushan', '0375', '467300', 'L', '112.9057', '33.73879'),
+(1580, 1572, '郏县', '郏县', '中国,河南省,平顶山市,郏县', 3, 'jiaxian', '0375', '467100', NULL, '113.21588', '33.97072'),
+(1581, 1572, '舞钢', '舞钢市', '中国,河南省,平顶山市,舞钢市', 3, 'wugang', '0375', '462500', 'W', '113.52417', '33.2938'),
+(1582, 1572, '汝州', '汝州市', '中国,河南省,平顶山市,汝州市', 3, 'ruzhou', '0375', '467500', 'R', '112.84301', '34.16135'),
+(1583, 1532, '安阳', '安阳市', '中国,河南省,安阳市', 2, 'anyang', '0372', '455000', 'A', '114.352482', '36.103442'),
+(1584, 1583, '文峰', '文峰区', '中国,河南省,安阳市,文峰区', 3, 'wenfeng', '0372', '455000', 'W', '114.35708', '36.09046'),
+(1585, 1583, '北关', '北关区', '中国,河南省,安阳市,北关区', 3, 'beiguan', '0372', '455001', 'B', '114.35735', '36.11872'),
+(1586, 1583, '殷都', '殷都区', '中国,河南省,安阳市,殷都区', 3, 'yindu', '0372', '455004', 'Y', '114.3034', '36.1099'),
+(1587, 1583, '龙安', '龙安区', '中国,河南省,安阳市,龙安区', 3, 'long''an', '0372', '455001', 'L', '114.34814', '36.11904'),
+(1588, 1583, '安阳', '安阳县', '中国,河南省,安阳市,安阳县', 3, 'anyang', '0372', '455000', 'A', '114.36605', '36.06695'),
+(1589, 1583, '汤阴', '汤阴县', '中国,河南省,安阳市,汤阴县', 3, 'tangyin', '0372', '456150', 'T', '114.35839', '35.92152'),
+(1590, 1583, '滑县', '滑县', '中国,河南省,安阳市,滑县', 3, 'huaxian', '0372', '456400', 'H', '114.52066', '35.5807'),
+(1591, 1583, '内黄', '内黄县', '中国,河南省,安阳市,内黄县', 3, 'neihuang', '0372', '456350', 'N', '114.90673', '35.95269'),
+(1592, 1583, '林州', '林州市', '中国,河南省,安阳市,林州市', 3, 'linzhou', '0372', '456550', 'L', '113.81558', '36.07804'),
+(1593, 1532, '鹤壁', '鹤壁市', '中国,河南省,鹤壁市', 2, 'hebi', '0392', '458030', 'H', '114.295444', '35.748236'),
+(1594, 1593, '鹤山', '鹤山区', '中国,河南省,鹤壁市,鹤山区', 3, 'heshan', '0392', '458010', 'H', '114.16336', '35.95458'),
+(1595, 1593, '山城', '山城区', '中国,河南省,鹤壁市,山城区', 3, 'shancheng', '0392', '458000', 'S', '114.18443', '35.89773'),
+(1596, 1593, '淇滨', '淇滨区', '中国,河南省,鹤壁市,淇滨区', 3, 'qibin', '0392', '458000', NULL, '114.29867', '35.74127'),
+(1597, 1593, '浚县', '浚县', '中国,河南省,鹤壁市,浚县', 3, 'xunxian', '0392', '456250', 'J', '114.54879', '35.67085'),
+(1598, 1593, '淇县', '淇县', '中国,河南省,鹤壁市,淇县', 3, 'qixian', '0392', '456750', NULL, '114.1976', '35.60782'),
+(1599, 1532, '新乡', '新乡市', '中国,河南省,新乡市', 2, 'xinxiang', '0373', '453000', 'X', '113.883991', '35.302616'),
+(1600, 1599, '红旗', '红旗区', '中国,河南省,新乡市,红旗区', 3, 'hongqi', '0373', '453000', 'H', '113.87523', '35.30367'),
+(1601, 1599, '卫滨', '卫滨区', '中国,河南省,新乡市,卫滨区', 3, 'weibin', '0373', '453000', 'W', '113.86578', '35.30211'),
+(1602, 1599, '凤泉', '凤泉区', '中国,河南省,新乡市,凤泉区', 3, 'fengquan', '0373', '453011', 'F', '113.91507', '35.38399'),
+(1603, 1599, '牧野', '牧野区', '中国,河南省,新乡市,牧野区', 3, 'muye', '0373', '453002', 'M', '113.9086', '35.3149'),
+(1604, 1599, '新乡', '新乡县', '中国,河南省,新乡市,新乡县', 3, 'xinxiang', '0373', '453700', 'X', '113.80511', '35.19075'),
+(1605, 1599, '获嘉', '获嘉县', '中国,河南省,新乡市,获嘉县', 3, 'huojia', '0373', '453800', 'H', '113.66159', '35.26521'),
+(1606, 1599, '原阳', '原阳县', '中国,河南省,新乡市,原阳县', 3, 'yuanyang', '0373', '453500', 'Y', '113.93994', '35.06565'),
+(1607, 1599, '延津', '延津县', '中国,河南省,新乡市,延津县', 3, 'yanjin', '0373', '453200', 'Y', '114.20266', '35.14327'),
+(1608, 1599, '封丘', '封丘县', '中国,河南省,新乡市,封丘县', 3, 'fengqiu', '0373', '453300', 'F', '114.41915', '35.04166'),
+(1609, 1599, '长垣', '长垣县', '中国,河南省,新乡市,长垣县', 3, 'changyuan', '0373', '453400', 'C', '114.66882', '35.20046'),
+(1610, 1599, '卫辉', '卫辉市', '中国,河南省,新乡市,卫辉市', 3, 'weihui', '0373', '453100', 'W', '114.06454', '35.39843'),
+(1611, 1599, '辉县', '辉县市', '中国,河南省,新乡市,辉县市', 3, 'huixian', '0373', '453600', 'H', '113.8067', '35.46307'),
+(1612, 1532, '焦作', '焦作市', '中国,河南省,焦作市', 2, 'jiaozuo', '0391', '454002', 'J', '113.238266', '35.23904'),
+(1613, 1612, '解放', '解放区', '中国,河南省,焦作市,解放区', 3, 'jiefang', '0391', '454000', 'J', '113.22933', '35.24023'),
+(1614, 1612, '中站', '中站区', '中国,河南省,焦作市,中站区', 3, 'zhongzhan', '0391', '454191', 'Z', '113.18315', '35.23665'),
+(1615, 1612, '马村', '马村区', '中国,河南省,焦作市,马村区', 3, 'macun', '0391', '454171', 'M', '113.3187', '35.26908'),
+(1616, 1612, '山阳', '山阳区', '中国,河南省,焦作市,山阳区', 3, 'shanyang', '0391', '454002', 'S', '113.25464', '35.21436'),
+(1617, 1612, '修武', '修武县', '中国,河南省,焦作市,修武县', 3, 'xiuwu', '0391', '454350', 'X', '113.44775', '35.22357'),
+(1618, 1612, '博爱', '博爱县', '中国,河南省,焦作市,博爱县', 3, 'boai', '0391', '454450', 'B', '113.06698', '35.16943'),
+(1619, 1612, '武陟', '武陟县', '中国,河南省,焦作市,武陟县', 3, 'wuzhi', '0391', '454950', 'W', '113.39718', '35.09505'),
+(1620, 1612, '温县', '温县', '中国,河南省,焦作市,温县', 3, 'wenxian', '0391', '454850', 'W', '113.08065', '34.94022'),
+(1621, 1612, '沁阳', '沁阳市', '中国,河南省,焦作市,沁阳市', 3, 'qinyang', '0391', '454550', 'Q', '112.94494', '35.08935'),
+(1622, 1612, '孟州', '孟州市', '中国,河南省,焦作市,孟州市', 3, 'mengzhou', '0391', '454750', 'M', '112.79138', '34.9071'),
+(1623, 1532, '濮阳', '濮阳市', '中国,河南省,濮阳市', 2, 'puyang', '0393', '457000', NULL, '115.041299', '35.768234'),
+(1624, 1623, '华龙', '华龙区', '中国,河南省,濮阳市,华龙区', 3, 'hualong', '0393', '457001', 'H', '115.07446', '35.77736'),
+(1625, 1623, '清丰', '清丰县', '中国,河南省,濮阳市,清丰县', 3, 'qingfeng', '0393', '457300', 'Q', '115.10415', '35.88507'),
+(1626, 1623, '南乐', '南乐县', '中国,河南省,濮阳市,南乐县', 3, 'nanle', '0393', '457400', 'N', '115.20639', '36.07686'),
+(1627, 1623, '范县', '范县', '中国,河南省,濮阳市,范县', 3, 'fanxian', '0393', '457500', 'F', '115.50405', '35.85178'),
+(1628, 1623, '台前', '台前县', '中国,河南省,濮阳市,台前县', 3, 'taiqian', '0393', '457600', 'T', '115.87158', '35.96923'),
+(1629, 1623, '濮阳', '濮阳县', '中国,河南省,濮阳市,濮阳县', 3, 'puyang', '0393', '457100', NULL, '115.03057', '35.70745'),
+(1630, 1532, '许昌', '许昌市', '中国,河南省,许昌市', 2, 'xuchang', '0374', '461000', 'X', '113.826063', '34.022956'),
+(1631, 1630, '魏都', '魏都区', '中国,河南省,许昌市,魏都区', 3, 'weidu', '0374', '461000', 'W', '113.8227', '34.02544'),
+(1632, 1630, '许昌', '许昌县', '中国,河南省,许昌市,许昌县', 3, 'xuchang', '0374', '461100', 'X', '113.84707', '34.00406'),
+(1633, 1630, '鄢陵', '鄢陵县', '中国,河南省,许昌市,鄢陵县', 3, 'yanling', '0374', '461200', NULL, '114.18795', '34.10317'),
+(1634, 1630, '襄城', '襄城县', '中国,河南省,许昌市,襄城县', 3, 'xiangcheng', '0374', '461700', 'X', '113.48196', '33.84928'),
+(1635, 1630, '禹州', '禹州市', '中国,河南省,许昌市,禹州市', 3, 'yuzhou', '0374', '461670', 'Y', '113.48803', '34.14054'),
+(1636, 1630, '长葛', '长葛市', '中国,河南省,许昌市,长葛市', 3, 'changge', '0374', '461500', 'C', '113.77328', '34.21846'),
+(1637, 1532, '漯河', '漯河市', '中国,河南省,漯河市', 2, 'luohe', '0395', '462000', NULL, '114.026405', '33.575855'),
+(1638, 1637, '源汇', '源汇区', '中国,河南省,漯河市,源汇区', 3, 'yuanhui', '0395', '462000', 'Y', '114.00647', '33.55627'),
+(1639, 1637, '郾城', '郾城区', '中国,河南省,漯河市,郾城区', 3, 'yancheng', '0395', '462300', NULL, '114.00694', '33.58723'),
+(1640, 1637, '召陵', '召陵区', '中国,河南省,漯河市,召陵区', 3, 'zhaoling', '0395', '462300', 'Z', '114.09399', '33.58601'),
+(1641, 1637, '舞阳', '舞阳县', '中国,河南省,漯河市,舞阳县', 3, 'wuyang', '0395', '462400', 'W', '113.59848', '33.43243'),
+(1642, 1637, '临颍', '临颍县', '中国,河南省,漯河市,临颍县', 3, 'linying', '0395', '462600', 'L', '113.93661', '33.81123'),
+(1643, 1532, '三门峡', '三门峡市', '中国,河南省,三门峡市', 2, 'sanmenxia', '0398', '472000', 'S', '111.194099', '34.777338'),
+(1644, 1643, '湖滨', '湖滨区', '中国,河南省,三门峡市,湖滨区', 3, 'hubin', '0398', '472000', 'H', '111.20006', '34.77872'),
+(1645, 1643, '渑池', '渑池县', '中国,河南省,三门峡市,渑池县', 3, 'mianchi', '0398', '472400', NULL, '111.76184', '34.76725'),
+(1646, 1643, '陕县', '陕县', '中国,河南省,三门峡市,陕县', 3, 'shanxian', '0398', '472100', 'S', '111.10333', '34.72052'),
+(1647, 1643, '卢氏', '卢氏县', '中国,河南省,三门峡市,卢氏县', 3, 'lushi', '0398', '472200', 'L', '111.04782', '34.05436'),
+(1648, 1643, '义马', '义马市', '中国,河南省,三门峡市,义马市', 3, 'yima', '0398', '472300', 'Y', '111.87445', '34.74721'),
+(1649, 1643, '灵宝', '灵宝市', '中国,河南省,三门峡市,灵宝市', 3, 'lingbao', '0398', '472500', 'L', '110.8945', '34.51682'),
+(1650, 1532, '南阳', '南阳市', '中国,河南省,南阳市', 2, 'nanyang', '0377', '473002', 'N', '112.540918', '32.999082'),
+(1651, 1650, '宛城', '宛城区', '中国,河南省,南阳市,宛城区', 3, 'wancheng', '0377', '473001', 'W', '112.53955', '33.00378'),
+(1652, 1650, '卧龙', '卧龙区', '中国,河南省,南阳市,卧龙区', 3, 'wolong', '0377', '473003', 'W', '112.53479', '32.98615'),
+(1653, 1650, '南召', '南召县', '中国,河南省,南阳市,南召县', 3, 'nanzhao', '0377', '474650', 'N', '112.43194', '33.49098'),
+(1654, 1650, '方城', '方城县', '中国,河南省,南阳市,方城县', 3, 'fangcheng', '0377', '473200', 'F', '113.01269', '33.25453'),
+(1655, 1650, '西峡', '西峡县', '中国,河南省,南阳市,西峡县', 3, 'xixia', '0377', '474550', 'X', '111.48187', '33.29772'),
+(1656, 1650, '镇平', '镇平县', '中国,河南省,南阳市,镇平县', 3, 'zhenping', '0377', '474250', 'Z', '112.2398', '33.03629'),
+(1657, 1650, '内乡', '内乡县', '中国,河南省,南阳市,内乡县', 3, 'neixiang', '0377', '474350', 'N', '111.84957', '33.04671'),
+(1658, 1650, '淅川', '淅川县', '中国,河南省,南阳市,淅川县', 3, 'xichuan', '0377', '474450', NULL, '111.48663', '33.13708'),
+(1659, 1650, '社旗', '社旗县', '中国,河南省,南阳市,社旗县', 3, 'sheqi', '0377', '473300', 'S', '112.94656', '33.05503'),
+(1660, 1650, '唐河', '唐河县', '中国,河南省,南阳市,唐河县', 3, 'tanghe', '0377', '473400', 'T', '112.83609', '32.69453'),
+(1661, 1650, '新野', '新野县', '中国,河南省,南阳市,新野县', 3, 'xinye', '0377', '473500', 'X', '112.36151', '32.51698'),
+(1662, 1650, '桐柏', '桐柏县', '中国,河南省,南阳市,桐柏县', 3, 'tongbai', '0377', '474750', 'T', '113.42886', '32.37917'),
+(1663, 1650, '邓州', '邓州市', '中国,河南省,南阳市,邓州市', 3, 'dengzhou', '0377', '474150', 'D', '112.0896', '32.68577'),
+(1664, 1532, '商丘', '商丘市', '中国,河南省,商丘市', 2, 'shangqiu', '0370', '476000', 'S', '115.650497', '34.437054'),
+(1665, 1664, '梁园', '梁园区', '中国,河南省,商丘市,梁园区', 3, 'liangyuan', '0370', '476000', 'L', '115.64487', '34.44341'),
+(1666, 1664, '睢阳', '睢阳区', '中国,河南省,商丘市,睢阳区', 3, 'suiyang', '0370', '476100', NULL, '115.65338', '34.38804'),
+(1667, 1664, '民权', '民权县', '中国,河南省,商丘市,民权县', 3, 'minquan', '0370', '476800', 'M', '115.14621', '34.64931'),
+(1668, 1664, '睢县', '睢县', '中国,河南省,商丘市,睢县', 3, 'suixian', '0370', '476900', NULL, '115.07168', '34.44539'),
+(1669, 1664, '宁陵', '宁陵县', '中国,河南省,商丘市,宁陵县', 3, 'ningling', '0370', '476700', 'N', '115.30511', '34.45463'),
+(1670, 1664, '柘城', '柘城县', '中国,河南省,商丘市,柘城县', 3, 'zhecheng', '0370', '476200', NULL, '115.30538', '34.0911'),
+(1671, 1664, '虞城', '虞城县', '中国,河南省,商丘市,虞城县', 3, 'yucheng', '0370', '476300', 'Y', '115.86337', '34.40189'),
+(1672, 1664, '夏邑', '夏邑县', '中国,河南省,商丘市,夏邑县', 3, 'xiayi', '0370', '476400', 'X', '116.13348', '34.23242'),
+(1673, 1664, '永城', '永城市', '中国,河南省,商丘市,永城市', 3, 'yongcheng', '0370', '476600', 'Y', '116.44943', '33.92911'),
+(1674, 1532, '信阳', '信阳市', '中国,河南省,信阳市', 2, 'xinyang', '0376', '464000', 'X', '114.075031', '32.123274'),
+(1675, 1674, '浉河', '浉河区', '中国,河南省,信阳市,浉河区', 3, 'shihe', '0376', '464000', NULL, '114.05871', '32.1168'),
+(1676, 1674, '平桥', '平桥区', '中国,河南省,信阳市,平桥区', 3, 'pingqiao', '0376', '464100', 'P', '114.12435', '32.10095'),
+(1677, 1674, '罗山', '罗山县', '中国,河南省,信阳市,罗山县', 3, 'luoshan', '0376', '464200', 'L', '114.5314', '32.20277'),
+(1678, 1674, '光山', '光山县', '中国,河南省,信阳市,光山县', 3, 'guangshan', '0376', '465450', 'G', '114.91873', '32.00992'),
+(1679, 1674, '新县', '新县', '中国,河南省,信阳市,新县', 3, 'xinxian', '0376', '465550', 'X', '114.87924', '31.64386'),
+(1680, 1674, '商城', '商城县', '中国,河南省,信阳市,商城县', 3, 'shangcheng', '0376', '465350', 'S', '115.40856', '31.79986'),
+(1681, 1674, '固始', '固始县', '中国,河南省,信阳市,固始县', 3, 'gushi', '0376', '465250', 'G', '115.68298', '32.18011'),
+(1682, 1674, '潢川', '潢川县', '中国,河南省,信阳市,潢川县', 3, 'huangchuan', '0376', '465150', NULL, '115.04696', '32.13763'),
+(1683, 1674, '淮滨', '淮滨县', '中国,河南省,信阳市,淮滨县', 3, 'huaibin', '0376', '464400', 'H', '115.4205', '32.46614'),
+(1684, 1674, '息县', '息县', '中国,河南省,信阳市,息县', 3, 'xixian', '0376', '464300', 'X', '114.7402', '32.34279'),
+(1685, 1532, '周口', '周口市', '中国,河南省,周口市', 2, 'zhoukou', '0394', '466000', 'Z', '114.649653', '33.620357'),
+(1686, 1685, '川汇', '川汇区', '中国,河南省,周口市,川汇区', 3, 'chuanhui', '0394', '466000', 'C', '114.64202', '33.6256'),
+(1687, 1685, '扶沟', '扶沟县', '中国,河南省,周口市,扶沟县', 3, 'fugou', '0394', '461300', 'F', '114.39477', '34.05999'),
+(1688, 1685, '西华', '西华县', '中国,河南省,周口市,西华县', 3, 'xihua', '0394', '466600', 'X', '114.52279', '33.78548'),
+(1689, 1685, '商水', '商水县', '中国,河南省,周口市,商水县', 3, 'shangshui', '0394', '466100', 'S', '114.60604', '33.53912'),
+(1690, 1685, '沈丘', '沈丘县', '中国,河南省,周口市,沈丘县', 3, 'shenqiu', '0394', '466300', 'S', '115.09851', '33.40936'),
+(1691, 1685, '郸城', '郸城县', '中国,河南省,周口市,郸城县', 3, 'dancheng', '0394', '477150', 'D', '115.17715', '33.64485'),
+(1692, 1685, '淮阳', '淮阳县', '中国,河南省,周口市,淮阳县', 3, 'huaiyang', '0394', '466700', 'H', '114.88848', '33.73211'),
+(1693, 1685, '太康', '太康县', '中国,河南省,周口市,太康县', 3, 'taikang', '0394', '461400', 'T', '114.83773', '34.06376'),
+(1694, 1685, '鹿邑', '鹿邑县', '中国,河南省,周口市,鹿邑县', 3, 'luyi', '0394', '477200', 'L', '115.48553', '33.85931'),
+(1695, 1685, '项城', '项城市', '中国,河南省,周口市,项城市', 3, 'xiangcheng', '0394', '466200', 'X', '114.87558', '33.4672'),
+(1696, 1532, '驻马店', '驻马店市', '中国,河南省,驻马店市', 2, 'zhumadian', '0396', '463000', 'Z', '114.024736', '32.980169'),
+(1697, 1696, '驿城', '驿城区', '中国,河南省,驻马店市,驿城区', 3, 'yicheng', '0396', '463000', NULL, '113.99377', '32.97316'),
+(1698, 1696, '西平', '西平县', '中国,河南省,驻马店市,西平县', 3, 'xiping', '0396', '463900', 'X', '114.02322', '33.3845'),
+(1699, 1696, '上蔡', '上蔡县', '中国,河南省,驻马店市,上蔡县', 3, 'shangcai', '0396', '463800', 'S', '114.26825', '33.26825'),
+(1700, 1696, '平舆', '平舆县', '中国,河南省,驻马店市,平舆县', 3, 'pingyu', '0396', '463400', 'P', '114.63552', '32.95727'),
+(1701, 1696, '正阳', '正阳县', '中国,河南省,驻马店市,正阳县', 3, 'zhengyang', '0396', '463600', 'Z', '114.38952', '32.6039'),
+(1702, 1696, '确山', '确山县', '中国,河南省,驻马店市,确山县', 3, 'queshan', '0396', '463200', 'Q', '114.02917', '32.80281'),
+(1703, 1696, '泌阳', '泌阳县', '中国,河南省,驻马店市,泌阳县', 3, 'biyang', '0396', '463700', 'M', '113.32681', '32.71781'),
+(1704, 1696, '汝南', '汝南县', '中国,河南省,驻马店市,汝南县', 3, 'runan', '0396', '463300', 'R', '114.36138', '33.00461'),
+(1705, 1696, '遂平', '遂平县', '中国,河南省,驻马店市,遂平县', 3, 'suiping', '0396', '463100', 'S', '114.01297', '33.14571'),
+(1706, 1696, '新蔡', '新蔡县', '中国,河南省,驻马店市,新蔡县', 3, 'xincai', '0396', '463500', 'X', '114.98199', '32.7502'),
+(1707, 1532, ' ', '直辖县级', '中国,河南省,直辖县级', 2, '', '', '', 'Z', '113.665412', '34.757975'),
+(1708, 1707, '济源', '济源市', '中国,河南省,直辖县级,济源市', 3, 'jiyuan', '0391', '454650', 'J', '112.590047', '35.090378'),
+(1709, 0, '湖北', '湖北省', '中国,湖北省', 1, 'hubei', '', '', 'H', '114.298572', '30.584355'),
+(1710, 1709, '武汉', '武汉市', '中国,湖北省,武汉市', 2, 'wuhan', '', '430014', 'W', '114.298572', '30.584355'),
+(1711, 1710, '江岸', '江岸区', '中国,湖北省,武汉市,江岸区', 3, 'jiang''an', '027', '430014', 'J', '114.30943', '30.59982'),
+(1712, 1710, '江汉', '江汉区', '中国,湖北省,武汉市,江汉区', 3, 'jianghan', '027', '430021', 'J', '114.27093', '30.60146'),
+(1713, 1710, '硚口', '硚口区', '中国,湖北省,武汉市,硚口区', 3, 'qiaokou', '027', '430033', NULL, '114.26422', '30.56945'),
+(1714, 1710, '汉阳', '汉阳区', '中国,湖北省,武汉市,汉阳区', 3, 'hanyang', '027', '430050', 'H', '114.27478', '30.54915'),
+(1715, 1710, '武昌', '武昌区', '中国,湖北省,武汉市,武昌区', 3, 'wuchang', '027', '430061', 'W', '114.31589', '30.55389'),
+(1716, 1710, '青山', '青山区', '中国,湖北省,武汉市,青山区', 3, 'qingshan', '027', '430080', 'Q', '114.39117', '30.63427'),
+(1717, 1710, '洪山', '洪山区', '中国,湖北省,武汉市,洪山区', 3, 'hongshan', '027', '430070', 'H', '114.34375', '30.49989'),
+(1718, 1710, '东西湖', '东西湖区', '中国,湖北省,武汉市,东西湖区', 3, 'dongxihu', '027', '430040', 'D', '114.13708', '30.61989'),
+(1719, 1710, '汉南', '汉南区', '中国,湖北省,武汉市,汉南区', 3, 'hannan', '027', '430090', 'H', '114.08462', '30.30879'),
+(1720, 1710, '蔡甸', '蔡甸区', '中国,湖北省,武汉市,蔡甸区', 3, 'caidian', '027', '430100', 'C', '114.02929', '30.58197'),
+(1721, 1710, '江夏', '江夏区', '中国,湖北省,武汉市,江夏区', 3, 'jiangxia', '027', '430200', 'J', '114.31301', '30.34653'),
+(1722, 1710, '黄陂', '黄陂区', '中国,湖北省,武汉市,黄陂区', 3, 'huangpi', '027', '432200', 'H', '114.37512', '30.88151'),
+(1723, 1710, '新洲', '新洲区', '中国,湖北省,武汉市,新洲区', 3, 'xinzhou', '027', '431400', 'X', '114.80136', '30.84145'),
+(1724, 1709, '黄石', '黄石市', '中国,湖北省,黄石市', 2, 'huangshi', '0714', '435003', 'H', '115.077048', '30.220074'),
+(1725, 1724, '黄石港', '黄石港区', '中国,湖北省,黄石市,黄石港区', 3, 'huangshigang', '0714', '435000', 'H', '115.06604', '30.22279'),
+(1726, 1724, '西塞山', '西塞山区', '中国,湖北省,黄石市,西塞山区', 3, 'xisaishan', '0714', '435001', 'X', '115.11016', '30.20487'),
+(1727, 1724, '下陆', '下陆区', '中国,湖北省,黄石市,下陆区', 3, 'xialu', '0714', '435005', 'X', '114.96112', '30.17368'),
+(1728, 1724, '铁山', '铁山区', '中国,湖北省,黄石市,铁山区', 3, 'tieshan', '0714', '435006', 'T', '114.90109', '30.20678'),
+(1729, 1724, '阳新', '阳新县', '中国,湖北省,黄石市,阳新县', 3, 'yangxin', '0714', '435200', 'Y', '115.21527', '29.83038'),
+(1730, 1724, '大冶', '大冶市', '中国,湖北省,黄石市,大冶市', 3, 'daye', '0714', '435100', 'D', '114.97174', '30.09438'),
+(1731, 1709, '十堰', '十堰市', '中国,湖北省,十堰市', 2, 'shiyan', '0719', '442000', 'S', '110.785239', '32.647017'),
+(1732, 1731, '茅箭', '茅箭区', '中国,湖北省,十堰市,茅箭区', 3, 'maojian', '0719', '442012', 'M', '110.81341', '32.59153'),
+(1733, 1731, '张湾', '张湾区', '中国,湖北省,十堰市,张湾区', 3, 'zhangwan', '0719', '442001', 'Z', '110.77067', '32.65195'),
+(1734, 1731, '郧阳', '郧阳区', '中国,湖北省,十堰市,郧阳区', 3, 'yunyang', '0719', '442500', 'Y', '110.81854', '32.83593'),
+(1735, 1731, '郧西', '郧西县', '中国,湖北省,十堰市,郧西县', 3, 'yunxi', '0719', '442600', 'Y', '110.42556', '32.99349'),
+(1736, 1731, '竹山', '竹山县', '中国,湖北省,十堰市,竹山县', 3, 'zhushan', '0719', '442200', 'Z', '110.23071', '32.22536'),
+(1737, 1731, '竹溪', '竹溪县', '中国,湖北省,十堰市,竹溪县', 3, 'zhuxi', '0719', '442300', 'Z', '109.71798', '32.31901'),
+(1738, 1731, '房县', '房县', '中国,湖北省,十堰市,房县', 3, 'fangxian', '0719', '442100', 'F', '110.74386', '32.05794'),
+(1739, 1731, '丹江口', '丹江口市', '中国,湖北省,十堰市,丹江口市', 3, 'danjiangkou', '0719', '442700', 'D', '111.51525', '32.54085'),
+(1740, 1709, '宜昌', '宜昌市', '中国,湖北省,宜昌市', 2, 'yichang', '0717', '443000', 'Y', '111.290843', '30.702636'),
+(1741, 1740, '西陵', '西陵区', '中国,湖北省,宜昌市,西陵区', 3, 'xiling', '0717', '443000', 'X', '111.28573', '30.71077'),
+(1742, 1740, '伍家岗', '伍家岗区', '中国,湖北省,宜昌市,伍家岗区', 3, 'wujiagang', '0717', '443001', 'W', '111.3609', '30.64434'),
+(1743, 1740, '点军', '点军区', '中国,湖北省,宜昌市,点军区', 3, 'dianjun', '0717', '443006', 'D', '111.26828', '30.6934'),
+(1744, 1740, '猇亭', '猇亭区', '中国,湖北省,宜昌市,猇亭区', 3, 'xiaoting', '0717', '443007', NULL, '111.44079', '30.52663'),
+(1745, 1740, '夷陵', '夷陵区', '中国,湖北省,宜昌市,夷陵区', 3, 'yiling', '0717', '443100', 'Y', '111.3262', '30.76881'),
+(1746, 1740, '远安', '远安县', '中国,湖北省,宜昌市,远安县', 3, 'yuan''an', '0717', '444200', 'Y', '111.6416', '31.05989'),
+(1747, 1740, '兴山', '兴山县', '中国,湖北省,宜昌市,兴山县', 3, 'xingshan', '0717', '443711', 'X', '110.74951', '31.34686'),
+(1748, 1740, '秭归', '秭归县', '中国,湖北省,宜昌市,秭归县', 3, 'zigui', '0717', '443600', NULL, '110.98156', '30.82702'),
+(1749, 1740, '长阳', '长阳土家族自治县', '中国,湖北省,宜昌市,长阳土家族自治县', 3, 'changyang', '0717', '443500', 'C', '111.20105', '30.47052'),
+(1750, 1740, '五峰', '五峰土家族自治县', '中国,湖北省,宜昌市,五峰土家族自治县', 3, 'wufeng', '0717', '443413', 'W', '110.6748', '30.19856'),
+(1751, 1740, '宜都', '宜都市', '中国,湖北省,宜昌市,宜都市', 3, 'yidu', '0717', '443300', 'Y', '111.45025', '30.37807'),
+(1752, 1740, '当阳', '当阳市', '中国,湖北省,宜昌市,当阳市', 3, 'dangyang', '0717', '444100', 'D', '111.78912', '30.8208'),
+(1753, 1740, '枝江', '枝江市', '中国,湖北省,宜昌市,枝江市', 3, 'zhijiang', '0717', '443200', 'Z', '111.76855', '30.42612'),
+(1754, 1709, '襄阳', '襄阳市', '中国,湖北省,襄阳市', 2, 'xiangyang', '0710', '441021', 'X', '112.144146', '32.042426'),
+(1755, 1754, '襄城', '襄城区', '中国,湖北省,襄阳市,襄城区', 3, 'xiangcheng', '0710', '441021', 'X', '112.13372', '32.01017'),
+(1756, 1754, '樊城', '樊城区', '中国,湖北省,襄阳市,樊城区', 3, 'fancheng', '0710', '441001', 'F', '112.13546', '32.04482'),
+(1757, 1754, '襄州', '襄州区', '中国,湖北省,襄阳市,襄州区', 3, 'xiangzhou', '0710', '441100', 'X', '112.150327', '32.015088'),
+(1758, 1754, '南漳', '南漳县', '中国,湖北省,襄阳市,南漳县', 3, 'nanzhang', '0710', '441500', 'N', '111.84603', '31.77653'),
+(1759, 1754, '谷城', '谷城县', '中国,湖北省,襄阳市,谷城县', 3, 'gucheng', '0710', '441700', 'G', '111.65267', '32.26377'),
+(1760, 1754, '保康', '保康县', '中国,湖北省,襄阳市,保康县', 3, 'baokang', '0710', '441600', 'B', '111.26138', '31.87874'),
+(1761, 1754, '老河口', '老河口市', '中国,湖北省,襄阳市,老河口市', 3, 'laohekou', '0710', '441800', 'L', '111.67117', '32.38476'),
+(1762, 1754, '枣阳', '枣阳市', '中国,湖北省,襄阳市,枣阳市', 3, 'zaoyang', '0710', '441200', 'Z', '112.77444', '32.13142'),
+(1763, 1754, '宜城', '宜城市', '中国,湖北省,襄阳市,宜城市', 3, 'yicheng', '0710', '441400', 'Y', '112.25772', '31.71972'),
+(1764, 1709, '鄂州', '鄂州市', '中国,湖北省,鄂州市', 2, 'ezhou', '0711', '436000', 'E', '114.890593', '30.396536'),
+(1765, 1764, '梁子湖', '梁子湖区', '中国,湖北省,鄂州市,梁子湖区', 3, 'liangzihu', '0711', '436064', 'L', '114.68463', '30.10003'),
+(1766, 1764, '华容', '华容区', '中国,湖北省,鄂州市,华容区', 3, 'huarong', '0711', '436030', 'H', '114.73568', '30.53328'),
+(1767, 1764, '鄂城', '鄂城区', '中国,湖北省,鄂州市,鄂城区', 3, 'echeng', '0711', '436000', 'E', '114.89158', '30.40024'),
+(1768, 1709, '荆门', '荆门市', '中国,湖北省,荆门市', 2, 'jingmen', '0724', '448000', 'J', '112.204251', '31.03542'),
+(1769, 1768, '东宝', '东宝区', '中国,湖北省,荆门市,东宝区', 3, 'dongbao', '0724', '448004', 'D', '112.20147', '31.05192'),
+(1770, 1768, '掇刀', '掇刀区', '中国,湖北省,荆门市,掇刀区', 3, 'duodao', '0724', '448124', 'D', '112.208', '30.97316'),
+(1771, 1768, '京山', '京山县', '中国,湖北省,荆门市,京山县', 3, 'jingshan', '0724', '431800', 'J', '113.11074', '31.0224'),
+(1772, 1768, '沙洋', '沙洋县', '中国,湖北省,荆门市,沙洋县', 3, 'shayang', '0724', '448200', 'S', '112.58853', '30.70916'),
+(1773, 1768, '钟祥', '钟祥市', '中国,湖北省,荆门市,钟祥市', 3, 'zhongxiang', '0724', '431900', 'Z', '112.58932', '31.1678'),
+(1774, 1709, '孝感', '孝感市', '中国,湖北省,孝感市', 2, 'xiaogan', '0712', '432100', 'X', '113.926655', '30.926423'),
+(1775, 1774, '孝南', '孝南区', '中国,湖北省,孝感市,孝南区', 3, 'xiaonan', '0712', '432100', 'X', '113.91111', '30.9168'),
+(1776, 1774, '孝昌', '孝昌县', '中国,湖北省,孝感市,孝昌县', 3, 'xiaochang', '0712', '432900', 'X', '113.99795', '31.25799'),
+(1777, 1774, '大悟', '大悟县', '中国,湖北省,孝感市,大悟县', 3, 'dawu', '0712', '432800', 'D', '114.12564', '31.56176'),
+(1778, 1774, '云梦', '云梦县', '中国,湖北省,孝感市,云梦县', 3, 'yunmeng', '0712', '432500', 'Y', '113.75289', '31.02093'),
+(1779, 1774, '应城', '应城市', '中国,湖北省,孝感市,应城市', 3, 'yingcheng', '0712', '432400', 'Y', '113.57287', '30.92834'),
+(1780, 1774, '安陆', '安陆市', '中国,湖北省,孝感市,安陆市', 3, 'anlu', '0712', '432600', 'A', '113.68557', '31.25693'),
+(1781, 1774, '汉川', '汉川市', '中国,湖北省,孝感市,汉川市', 3, 'hanchuan', '0712', '432300', 'H', '113.83898', '30.66117'),
+(1782, 1709, '荆州', '荆州市', '中国,湖北省,荆州市', 2, 'jingzhou', '0716', '434000', 'J', '112.23813', '30.326857'),
+(1783, 1782, '沙市', '沙市区', '中国,湖北省,荆州市,沙市区', 3, 'shashi', '0716', '434000', 'S', '112.25543', '30.31107'),
+(1784, 1782, '荆州', '荆州区', '中国,湖北省,荆州市,荆州区', 3, 'jingzhou', '0716', '434020', 'J', '112.19006', '30.35264'),
+(1785, 1782, '公安', '公安县', '中国,湖北省,荆州市,公安县', 3, 'gong''an', '0716', '434300', 'G', '112.23242', '30.05902'),
+(1786, 1782, '监利', '监利县', '中国,湖北省,荆州市,监利县', 3, 'jianli', '0716', '433300', 'J', '112.89462', '29.81494'),
+(1787, 1782, '江陵', '江陵县', '中国,湖北省,荆州市,江陵县', 3, 'jiangling', '0716', '434101', 'J', '112.42468', '30.04174'),
+(1788, 1782, '石首', '石首市', '中国,湖北省,荆州市,石首市', 3, 'shishou', '0716', '434400', 'S', '112.42636', '29.72127'),
+(1789, 1782, '洪湖', '洪湖市', '中国,湖北省,荆州市,洪湖市', 3, 'honghu', '0716', '433200', 'H', '113.47598', '29.827'),
+(1790, 1782, '松滋', '松滋市', '中国,湖北省,荆州市,松滋市', 3, 'songzi', '0716', '434200', 'S', '111.76739', '30.16965'),
+(1791, 1709, '黄冈', '黄冈市', '中国,湖北省,黄冈市', 2, 'huanggang', '0713', '438000', 'H', '114.879365', '30.447711'),
+(1792, 1791, '黄州', '黄州区', '中国,湖北省,黄冈市,黄州区', 3, 'huangzhou', '0713', '438000', 'H', '114.88008', '30.43436'),
+(1793, 1791, '团风', '团风县', '中国,湖北省,黄冈市,团风县', 3, 'tuanfeng', '0713', '438800', 'T', '114.87228', '30.64359'),
+(1794, 1791, '红安', '红安县', '中国,湖北省,黄冈市,红安县', 3, 'hong''an', '0713', '438401', 'H', '114.6224', '31.28668'),
+(1795, 1791, '罗田', '罗田县', '中国,湖北省,黄冈市,罗田县', 3, 'luotian', '0713', '438600', 'L', '115.39971', '30.78255'),
+(1796, 1791, '英山', '英山县', '中国,湖北省,黄冈市,英山县', 3, 'yingshan', '0713', '438700', 'Y', '115.68142', '30.73516'),
+(1797, 1791, '浠水', '浠水县', '中国,湖北省,黄冈市,浠水县', 3, 'xishui', '0713', '438200', NULL, '115.26913', '30.45265'),
+(1798, 1791, '蕲春', '蕲春县', '中国,湖北省,黄冈市,蕲春县', 3, 'qichun', '0713', '435300', NULL, '115.43615', '30.22613'),
+(1799, 1791, '黄梅', '黄梅县', '中国,湖北省,黄冈市,黄梅县', 3, 'huangmei', '0713', '435500', 'H', '115.94427', '30.07033'),
+(1800, 1791, '麻城', '麻城市', '中国,湖北省,黄冈市,麻城市', 3, 'macheng', '0713', '438300', 'M', '115.00988', '31.17228'),
+(1801, 1791, '武穴', '武穴市', '中国,湖北省,黄冈市,武穴市', 3, 'wuxue', '0713', '435400', 'W', '115.55975', '29.84446'),
+(1802, 1709, '咸宁', '咸宁市', '中国,湖北省,咸宁市', 2, 'xianning', '0715', '437000', 'X', '114.328963', '29.832798'),
+(1803, 1802, '咸安', '咸安区', '中国,湖北省,咸宁市,咸安区', 3, 'xian''an', '0715', '437000', 'X', '114.29872', '29.8529'),
+(1804, 1802, '嘉鱼', '嘉鱼县', '中国,湖北省,咸宁市,嘉鱼县', 3, 'jiayu', '0715', '437200', 'J', '113.93927', '29.97054'),
+(1805, 1802, '通城', '通城县', '中国,湖北省,咸宁市,通城县', 3, 'tongcheng', '0715', '437400', 'T', '113.81582', '29.24568'),
+(1806, 1802, '崇阳', '崇阳县', '中国,湖北省,咸宁市,崇阳县', 3, 'chongyang', '0715', '437500', 'C', '114.03982', '29.55564'),
+(1807, 1802, '通山', '通山县', '中国,湖北省,咸宁市,通山县', 3, 'tongshan', '0715', '437600', 'T', '114.48239', '29.6063'),
+(1808, 1802, '赤壁', '赤壁市', '中国,湖北省,咸宁市,赤壁市', 3, 'chibi', '0715', '437300', 'C', '113.90039', '29.72454'),
+(1809, 1709, '随州', '随州市', '中国,湖北省,随州市', 2, 'suizhou', '0722', '441300', 'S', '113.37377', '31.717497'),
+(1810, 1809, '曾都', '曾都区', '中国,湖北省,随州市,曾都区', 3, 'zengdu', '0722', '441300', 'Z', '113.37128', '31.71614'),
+(1811, 1809, '随县', '随县', '中国,湖北省,随州市,随县', 3, 'suixian', '0722', '441309', 'S', '113.82663', '31.6179'),
+(1812, 1809, '广水', '广水市', '中国,湖北省,随州市,广水市', 3, 'guangshui', '0722', '432700', 'G', '113.82663', '31.6179'),
+(1813, 1709, '恩施', '恩施土家族苗族自治州', '中国,湖北省,恩施土家族苗族自治州', 2, 'enshi', '0718', '445000', 'E', '109.48699', '30.283114'),
+(1814, 1813, '恩施', '恩施市', '中国,湖北省,恩施土家族苗族自治州,恩施市', 3, 'enshi', '0718', '445000', 'E', '109.47942', '30.29502'),
+(1815, 1813, '利川', '利川市', '中国,湖北省,恩施土家族苗族自治州,利川市', 3, 'lichuan', '0718', '445400', 'L', '108.93591', '30.29117'),
+(1816, 1813, '建始', '建始县', '中国,湖北省,恩施土家族苗族自治州,建始县', 3, 'jianshi', '0718', '445300', 'J', '109.72207', '30.60209'),
+(1817, 1813, '巴东', '巴东县', '中国,湖北省,恩施土家族苗族自治州,巴东县', 3, 'badong', '0718', '444300', 'B', '110.34066', '31.04233'),
+(1818, 1813, '宣恩', '宣恩县', '中国,湖北省,恩施土家族苗族自治州,宣恩县', 3, 'xuanen', '0718', '445500', 'X', '109.49179', '29.98714'),
+(1819, 1813, '咸丰', '咸丰县', '中国,湖北省,恩施土家族苗族自治州,咸丰县', 3, 'xianfeng', '0718', '445600', 'X', '109.152', '29.67983'),
+(1820, 1813, '来凤', '来凤县', '中国,湖北省,恩施土家族苗族自治州,来凤县', 3, 'laifeng', '0718', '445700', 'L', '109.40716', '29.49373'),
+(1821, 1813, '鹤峰', '鹤峰县', '中国,湖北省,恩施土家族苗族自治州,鹤峰县', 3, 'hefeng', '0718', '445800', 'H', '110.03091', '29.89072'),
+(1822, 1709, ' ', '直辖县级', '中国,湖北省,直辖县级', 2, '', '', '', 'Z', '114.298572', '30.584355'),
+(1823, 1822, '仙桃', '仙桃市', '中国,湖北省,直辖县级,仙桃市', 3, 'xiantao', '0728', '433000', 'X', '113.453974', '30.364953'),
+(1824, 1822, '潜江', '潜江市', '中国,湖北省,直辖县级,潜江市', 3, 'qianjiang', '0728', '433100', 'Q', '112.896866', '30.421215'),
+(1825, 1822, '天门', '天门市', '中国,湖北省,直辖县级,天门市', 3, 'tianmen', '0728', '431700', 'T', '113.165862', '30.653061'),
+(1826, 1822, '神农架', '神农架林区', '中国,湖北省,直辖县级,神农架林区', 3, 'shennongjia', '0719', '442400', 'S', '110.671525', '31.744449'),
+(1827, 0, '湖南', '湖南省', '中国,湖南省', 1, 'hunan', '', '', 'H', '112.982279', '28.19409'),
+(1828, 1827, '长沙', '长沙市', '中国,湖南省,长沙市', 2, 'changsha', '0731', '410005', 'C', '112.982279', '28.19409'),
+(1829, 1828, '芙蓉', '芙蓉区', '中国,湖南省,长沙市,芙蓉区', 3, 'furong', '0731', '410011', NULL, '113.03176', '28.1844'),
+(1830, 1828, '天心', '天心区', '中国,湖南省,长沙市,天心区', 3, 'tianxin', '0731', '410004', 'T', '112.98991', '28.1127'),
+(1831, 1828, '岳麓', '岳麓区', '中国,湖南省,长沙市,岳麓区', 3, 'yuelu', '0731', '410013', 'Y', '112.93133', '28.2351'),
+(1832, 1828, '开福', '开福区', '中国,湖南省,长沙市,开福区', 3, 'kaifu', '0731', '410008', 'K', '112.98623', '28.25585'),
+(1833, 1828, '雨花', '雨花区', '中国,湖南省,长沙市,雨花区', 3, 'yuhua', '0731', '410011', 'Y', '113.03567', '28.13541'),
+(1834, 1828, '望城', '望城区', '中国,湖南省,长沙市,望城区', 3, 'wangcheng', '0731', '410200', 'W', '112.819549', '28.347458'),
+(1835, 1828, '长沙', '长沙县', '中国,湖南省,长沙市,长沙县', 3, 'changsha', '0731', '410100', 'C', '113.08071', '28.24595'),
+(1836, 1828, '宁乡', '宁乡县', '中国,湖南省,长沙市,宁乡县', 3, 'ningxiang', '0731', '410600', 'N', '112.55749', '28.25358'),
+(1837, 1828, '浏阳', '浏阳市', '中国,湖南省,长沙市,浏阳市', 3, 'liuyang', '0731', '410300', NULL, '113.64312', '28.16375'),
+(1838, 1827, '株洲', '株洲市', '中国,湖南省,株洲市', 2, 'zhuzhou', '0731', '412000', 'Z', '113.151737', '27.835806'),
+(1839, 1838, '荷塘', '荷塘区', '中国,湖南省,株洲市,荷塘区', 3, 'hetang', '0731', '412000', 'H', '113.17315', '27.85569'),
+(1840, 1838, '芦淞', '芦淞区', '中国,湖南省,株洲市,芦淞区', 3, 'lusong', '0731', '412000', 'L', '113.15562', '27.78525'),
+(1841, 1838, '石峰', '石峰区', '中国,湖南省,株洲市,石峰区', 3, 'shifeng', '0731', '412005', 'S', '113.11776', '27.87552'),
+(1842, 1838, '天元', '天元区', '中国,湖南省,株洲市,天元区', 3, 'tianyuan', '0731', '412007', 'T', '113.12335', '27.83103'),
+(1843, 1838, '株洲', '株洲县', '中国,湖南省,株洲市,株洲县', 3, 'zhuzhou', '0731', '412100', 'Z', '113.14428', '27.69826'),
+(1844, 1838, '攸县', '攸县', '中国,湖南省,株洲市,攸县', 3, 'youxian', '0731', '412300', NULL, '113.34365', '27.00352'),
+(1845, 1838, '茶陵', '茶陵县', '中国,湖南省,株洲市,茶陵县', 3, 'chaling', '0731', '412400', 'C', '113.54364', '26.7915'),
+(1846, 1838, '炎陵', '炎陵县', '中国,湖南省,株洲市,炎陵县', 3, 'yanling', '0731', '412500', 'Y', '113.77163', '26.48818'),
+(1847, 1838, '醴陵', '醴陵市', '中国,湖南省,株洲市,醴陵市', 3, 'liling', '0731', '412200', NULL, '113.49704', '27.64615'),
+(1848, 1827, '湘潭', '湘潭市', '中国,湖南省,湘潭市', 2, 'xiangtan', '0731', '411100', 'X', '112.925083', '27.846725'),
+(1849, 1848, '雨湖', '雨湖区', '中国,湖南省,湘潭市,雨湖区', 3, 'yuhu', '0731', '411100', 'Y', '112.90399', '27.86859'),
+(1850, 1848, '岳塘', '岳塘区', '中国,湖南省,湘潭市,岳塘区', 3, 'yuetang', '0731', '411101', 'Y', '112.9606', '27.85784'),
+(1851, 1848, '湘潭', '湘潭县', '中国,湖南省,湘潭市,湘潭县', 3, 'xiangtan', '0731', '411228', 'X', '112.9508', '27.77893'),
+(1852, 1848, '湘乡', '湘乡市', '中国,湖南省,湘潭市,湘乡市', 3, 'xiangxiang', '0731', '411400', 'X', '112.53512', '27.73543'),
+(1853, 1848, '韶山', '韶山市', '中国,湖南省,湘潭市,韶山市', 3, 'shaoshan', '0731', '411300', 'S', '112.52655', '27.91503'),
+(1854, 1827, '衡阳', '衡阳市', '中国,湖南省,衡阳市', 2, 'hengyang', '0734', '421001', 'H', '112.607693', '26.900358'),
+(1855, 1854, '珠晖', '珠晖区', '中国,湖南省,衡阳市,珠晖区', 3, 'zhuhui', '0734', '421002', 'Z', '112.62054', '26.89361'),
+(1856, 1854, '雁峰', '雁峰区', '中国,湖南省,衡阳市,雁峰区', 3, 'yanfeng', '0734', '421001', 'Y', '112.61654', '26.88866'),
+(1857, 1854, '石鼓', '石鼓区', '中国,湖南省,衡阳市,石鼓区', 3, 'shigu', '0734', '421005', 'S', '112.61069', '26.90232'),
+(1858, 1854, '蒸湘', '蒸湘区', '中国,湖南省,衡阳市,蒸湘区', 3, 'zhengxiang', '0734', '421001', 'Z', '112.6033', '26.89651'),
+(1859, 1854, '南岳', '南岳区', '中国,湖南省,衡阳市,南岳区', 3, 'nanyue', '0734', '421900', 'N', '112.7384', '27.23262'),
+(1860, 1854, '衡阳', '衡阳县', '中国,湖南省,衡阳市,衡阳县', 3, 'hengyang', '0734', '421200', 'H', '112.37088', '26.9706'),
+(1861, 1854, '衡南', '衡南县', '中国,湖南省,衡阳市,衡南县', 3, 'hengnan', '0734', '421131', 'H', '112.67788', '26.73828'),
+(1862, 1854, '衡山', '衡山县', '中国,湖南省,衡阳市,衡山县', 3, 'hengshan', '0734', '421300', 'H', '112.86776', '27.23134'),
+(1863, 1854, '衡东', '衡东县', '中国,湖南省,衡阳市,衡东县', 3, 'hengdong', '0734', '421400', 'H', '112.94833', '27.08093'),
+(1864, 1854, '祁东', '祁东县', '中国,湖南省,衡阳市,祁东县', 3, 'qidong', '0734', '421600', 'Q', '112.09039', '26.79964'),
+(1865, 1854, '耒阳', '耒阳市', '中国,湖南省,衡阳市,耒阳市', 3, 'leiyang', '0734', '421800', NULL, '112.85998', '26.42132'),
+(1866, 1854, '常宁', '常宁市', '中国,湖南省,衡阳市,常宁市', 3, 'changning', '0734', '421500', 'C', '112.4009', '26.40692'),
+(1867, 1827, '邵阳', '邵阳市', '中国,湖南省,邵阳市', 2, 'shaoyang', '0739', '422000', 'S', '111.46923', '27.237842'),
+(1868, 1867, '双清', '双清区', '中国,湖南省,邵阳市,双清区', 3, 'shuangqing', '0739', '422001', 'S', '111.49715', '27.23291'),
+(1869, 1867, '大祥', '大祥区', '中国,湖南省,邵阳市,大祥区', 3, 'daxiang', '0739', '422000', 'D', '111.45412', '27.23332'),
+(1870, 1867, '北塔', '北塔区', '中国,湖南省,邵阳市,北塔区', 3, 'beita', '0739', '422007', 'B', '111.45219', '27.24648'),
+(1871, 1867, '邵东', '邵东县', '中国,湖南省,邵阳市,邵东县', 3, 'shaodong', '0739', '422800', 'S', '111.74441', '27.2584'),
+(1872, 1867, '新邵', '新邵县', '中国,湖南省,邵阳市,新邵县', 3, 'xinshao', '0739', '422900', 'X', '111.46066', '27.32169'),
+(1873, 1867, '邵阳', '邵阳县', '中国,湖南省,邵阳市,邵阳县', 3, 'shaoyang', '0739', '422100', 'S', '111.27459', '26.99143'),
+(1874, 1867, '隆回', '隆回县', '中国,湖南省,邵阳市,隆回县', 3, 'longhui', '0739', '422200', 'L', '111.03216', '27.10937'),
+(1875, 1867, '洞口', '洞口县', '中国,湖南省,邵阳市,洞口县', 3, 'dongkou', '0739', '422300', 'D', '110.57388', '27.05462'),
+(1876, 1867, '绥宁', '绥宁县', '中国,湖南省,邵阳市,绥宁县', 3, 'suining', '0739', '422600', 'S', '110.15576', '26.58636'),
+(1877, 1867, '新宁', '新宁县', '中国,湖南省,邵阳市,新宁县', 3, 'xinning', '0739', '422700', 'X', '110.85131', '26.42936'),
+(1878, 1867, '城步', '城步苗族自治县', '中国,湖南省,邵阳市,城步苗族自治县', 3, 'chengbu', '0739', '422500', 'C', '110.3222', '26.39048'),
+(1879, 1867, '武冈', '武冈市', '中国,湖南省,邵阳市,武冈市', 3, 'wugang', '0739', '422400', 'W', '110.63281', '26.72817'),
+(1880, 1827, '岳阳', '岳阳市', '中国,湖南省,岳阳市', 2, 'yueyang', '0730', '414000', 'Y', '113.132855', '29.37029'),
+(1881, 1880, '岳阳楼', '岳阳楼区', '中国,湖南省,岳阳市,岳阳楼区', 3, 'yueyanglou', '0730', '414000', 'Y', '113.12942', '29.3719'),
+(1882, 1880, '云溪', '云溪区', '中国,湖南省,岳阳市,云溪区', 3, 'yunxi', '0730', '414009', 'Y', '113.27713', '29.47357'),
+(1883, 1880, '君山', '君山区', '中国,湖南省,岳阳市,君山区', 3, 'junshan', '0730', '414005', 'J', '113.00439', '29.45941'),
+(1884, 1880, '岳阳', '岳阳县', '中国,湖南省,岳阳市,岳阳县', 3, 'yueyang', '0730', '414100', 'Y', '113.11987', '29.14314'),
+(1885, 1880, '华容', '华容县', '中国,湖南省,岳阳市,华容县', 3, 'huarong', '0730', '414200', 'H', '112.54089', '29.53019'),
+(1886, 1880, '湘阴', '湘阴县', '中国,湖南省,岳阳市,湘阴县', 3, 'xiangyin', '0730', '414600', 'X', '112.90911', '28.68922'),
+(1887, 1880, '平江', '平江县', '中国,湖南省,岳阳市,平江县', 3, 'pingjiang', '0730', '414500', 'P', '113.58105', '28.70664'),
+(1888, 1880, '汨罗', '汨罗市', '中国,湖南省,岳阳市,汨罗市', 3, 'miluo', '0730', '414400', NULL, '113.06707', '28.80631'),
+(1889, 1880, '临湘', '临湘市', '中国,湖南省,岳阳市,临湘市', 3, 'linxiang', '0730', '414300', 'L', '113.4501', '29.47701'),
+(1890, 1827, '常德', '常德市', '中国,湖南省,常德市', 2, 'changde', '0736', '415000', 'C', '111.691347', '29.040225'),
+(1891, 1890, '武陵', '武陵区', '中国,湖南省,常德市,武陵区', 3, 'wuling', '0736', '415000', 'W', '111.69791', '29.02876'),
+(1892, 1890, '鼎城', '鼎城区', '中国,湖南省,常德市,鼎城区', 3, 'dingcheng', '0736', '415101', 'D', '111.68078', '29.01859'),
+(1893, 1890, '安乡', '安乡县', '中国,湖南省,常德市,安乡县', 3, 'anxiang', '0736', '415600', 'A', '112.16732', '29.41326'),
+(1894, 1890, '汉寿', '汉寿县', '中国,湖南省,常德市,汉寿县', 3, 'hanshou', '0736', '415900', 'H', '111.96691', '28.90299'),
+(1895, 1890, '澧县', '澧县', '中国,湖南省,常德市,澧县', 3, 'lixian', '0736', '415500', NULL, '111.75866', '29.63317'),
+(1896, 1890, '临澧', '临澧县', '中国,湖南省,常德市,临澧县', 3, 'linli', '0736', '415200', 'L', '111.65161', '29.44163'),
+(1897, 1890, '桃源', '桃源县', '中国,湖南省,常德市,桃源县', 3, 'taoyuan', '0736', '415700', 'T', '111.48892', '28.90474'),
+(1898, 1890, '石门', '石门县', '中国,湖南省,常德市,石门县', 3, 'shimen', '0736', '415300', 'S', '111.37966', '29.58424'),
+(1899, 1890, '津市', '津市市', '中国,湖南省,常德市,津市市', 3, 'jinshi', '0736', '415400', 'J', '111.87756', '29.60563'),
+(1900, 1827, '张家界', '张家界市', '中国,湖南省,张家界市', 2, 'zhangjiajie', '0744', '427000', 'Z', '110.479921', '29.127401'),
+(1901, 1900, '永定', '永定区', '中国,湖南省,张家界市,永定区', 3, 'yongding', '0744', '427000', 'Y', '110.47464', '29.13387'),
+(1902, 1900, '武陵源', '武陵源区', '中国,湖南省,张家界市,武陵源区', 3, 'wulingyuan', '0744', '427400', 'W', '110.55026', '29.34574'),
+(1903, 1900, '慈利', '慈利县', '中国,湖南省,张家界市,慈利县', 3, 'cili', '0744', '427200', 'C', '111.13946', '29.42989'),
+(1904, 1900, '桑植', '桑植县', '中国,湖南省,张家界市,桑植县', 3, 'sangzhi', '0744', '427100', 'S', '110.16308', '29.39815'),
+(1905, 1827, '益阳', '益阳市', '中国,湖南省,益阳市', 2, 'yiyang', '0737', '413000', 'Y', '112.355042', '28.570066'),
+(1906, 1905, '资阳', '资阳区', '中国,湖南省,益阳市,资阳区', 3, 'ziyang', '0737', '413001', 'Z', '112.32447', '28.59095'),
+(1907, 1905, '赫山', '赫山区', '中国,湖南省,益阳市,赫山区', 3, 'heshan', '0737', '413002', 'H', '112.37265', '28.57425'),
+(1908, 1905, '南县', '南县', '中国,湖南省,益阳市,南县', 3, 'nanxian', '0737', '413200', 'N', '112.3963', '29.36159'),
+(1909, 1905, '桃江', '桃江县', '中国,湖南省,益阳市,桃江县', 3, 'taojiang', '0737', '413400', 'T', '112.1557', '28.51814'),
+(1910, 1905, '安化', '安化县', '中国,湖南省,益阳市,安化县', 3, 'anhua', '0737', '413500', 'A', '111.21298', '28.37424');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(1911, 1905, '沅江', '沅江市', '中国,湖南省,益阳市,沅江市', 3, 'yuanjiang', '0737', '413100', NULL, '112.35427', '28.84403'),
+(1912, 1827, '郴州', '郴州市', '中国,湖南省,郴州市', 2, 'chenzhou', '0735', '423000', 'C', '113.032067', '25.793589'),
+(1913, 1912, '北湖', '北湖区', '中国,湖南省,郴州市,北湖区', 3, 'beihu', '0735', '423000', 'B', '113.01103', '25.78405'),
+(1914, 1912, '苏仙', '苏仙区', '中国,湖南省,郴州市,苏仙区', 3, 'suxian', '0735', '423000', 'S', '113.04226', '25.80045'),
+(1915, 1912, '桂阳', '桂阳县', '中国,湖南省,郴州市,桂阳县', 3, 'guiyang', '0735', '424400', 'G', '112.73364', '25.75406'),
+(1916, 1912, '宜章', '宜章县', '中国,湖南省,郴州市,宜章县', 3, 'yizhang', '0735', '424200', 'Y', '112.95147', '25.39931'),
+(1917, 1912, '永兴', '永兴县', '中国,湖南省,郴州市,永兴县', 3, 'yongxing', '0735', '423300', 'Y', '113.11242', '26.12646'),
+(1918, 1912, '嘉禾', '嘉禾县', '中国,湖南省,郴州市,嘉禾县', 3, 'jiahe', '0735', '424500', 'J', '112.36935', '25.58795'),
+(1919, 1912, '临武', '临武县', '中国,湖南省,郴州市,临武县', 3, 'linwu', '0735', '424300', 'L', '112.56369', '25.27602'),
+(1920, 1912, '汝城', '汝城县', '中国,湖南省,郴州市,汝城县', 3, 'rucheng', '0735', '424100', 'R', '113.68582', '25.55204'),
+(1921, 1912, '桂东', '桂东县', '中国,湖南省,郴州市,桂东县', 3, 'guidong', '0735', '423500', 'G', '113.9468', '26.07987'),
+(1922, 1912, '安仁', '安仁县', '中国,湖南省,郴州市,安仁县', 3, 'anren', '0735', '423600', 'A', '113.26944', '26.70931'),
+(1923, 1912, '资兴', '资兴市', '中国,湖南省,郴州市,资兴市', 3, 'zixing', '0735', '423400', 'Z', '113.23724', '25.97668'),
+(1924, 1827, '永州', '永州市', '中国,湖南省,永州市', 2, 'yongzhou', '0746', '425000', 'Y', '111.608019', '26.434516'),
+(1925, 1924, '零陵', '零陵区', '中国,湖南省,永州市,零陵区', 3, 'lingling', '0746', '425100', 'L', '111.62103', '26.22109'),
+(1926, 1924, '冷水滩', '冷水滩区', '中国,湖南省,永州市,冷水滩区', 3, 'lengshuitan', '0746', '425100', 'L', '111.59214', '26.46107'),
+(1927, 1924, '祁阳', '祁阳县', '中国,湖南省,永州市,祁阳县', 3, 'qiyang', '0746', '426100', 'Q', '111.84011', '26.58009'),
+(1928, 1924, '东安', '东安县', '中国,湖南省,永州市,东安县', 3, 'dong''an', '0746', '425900', 'D', '111.3164', '26.39202'),
+(1929, 1924, '双牌', '双牌县', '中国,湖南省,永州市,双牌县', 3, 'shuangpai', '0746', '425200', 'S', '111.65927', '25.95988'),
+(1930, 1924, '道县', '道县', '中国,湖南省,永州市,道县', 3, 'daoxian', '0746', '425300', 'D', '111.60195', '25.52766'),
+(1931, 1924, '江永', '江永县', '中国,湖南省,永州市,江永县', 3, 'jiangyong', '0746', '425400', 'J', '111.34082', '25.27233'),
+(1932, 1924, '宁远', '宁远县', '中国,湖南省,永州市,宁远县', 3, 'ningyuan', '0746', '425600', 'N', '111.94625', '25.56913'),
+(1933, 1924, '蓝山', '蓝山县', '中国,湖南省,永州市,蓝山县', 3, 'lanshan', '0746', '425800', 'L', '112.19363', '25.36794'),
+(1934, 1924, '新田', '新田县', '中国,湖南省,永州市,新田县', 3, 'xintian', '0746', '425700', 'X', '112.22103', '25.9095'),
+(1935, 1924, '江华', '江华瑶族自治县', '中国,湖南省,永州市,江华瑶族自治县', 3, 'jianghua', '0746', '425500', 'J', '111.58847', '25.1845'),
+(1936, 1827, '怀化', '怀化市', '中国,湖南省,怀化市', 2, 'huaihua', '0745', '418000', 'H', '109.97824', '27.550082'),
+(1937, 1936, '鹤城', '鹤城区', '中国,湖南省,怀化市,鹤城区', 3, 'hecheng', '0745', '418000', 'H', '109.96509', '27.54942'),
+(1938, 1936, '中方', '中方县', '中国,湖南省,怀化市,中方县', 3, 'zhongfang', '0745', '418005', 'Z', '109.94497', '27.43988'),
+(1939, 1936, '沅陵', '沅陵县', '中国,湖南省,怀化市,沅陵县', 3, 'yuanling', '0745', '419600', NULL, '110.39633', '28.45548'),
+(1940, 1936, '辰溪', '辰溪县', '中国,湖南省,怀化市,辰溪县', 3, 'chenxi', '0745', '419500', 'C', '110.18942', '28.00406'),
+(1941, 1936, '溆浦', '溆浦县', '中国,湖南省,怀化市,溆浦县', 3, 'xupu', '0745', '419300', NULL, '110.59384', '27.90836'),
+(1942, 1936, '会同', '会同县', '中国,湖南省,怀化市,会同县', 3, 'huitong', '0745', '418300', 'H', '109.73568', '26.88716'),
+(1943, 1936, '麻阳', '麻阳苗族自治县', '中国,湖南省,怀化市,麻阳苗族自治县', 3, 'mayang', '0745', '419400', 'M', '109.80194', '27.866'),
+(1944, 1936, '新晃', '新晃侗族自治县', '中国,湖南省,怀化市,新晃侗族自治县', 3, 'xinhuang', '0745', '419200', 'X', '109.17166', '27.35937'),
+(1945, 1936, '芷江', '芷江侗族自治县', '中国,湖南省,怀化市,芷江侗族自治县', 3, 'zhijiang', '0745', '419100', NULL, '109.6849', '27.44297'),
+(1946, 1936, '靖州', '靖州苗族侗族自治县', '中国,湖南省,怀化市,靖州苗族侗族自治县', 3, 'jingzhou', '0745', '418400', 'J', '109.69821', '26.57651'),
+(1947, 1936, '通道', '通道侗族自治县', '中国,湖南省,怀化市,通道侗族自治县', 3, 'tongdao', '0745', '418500', 'T', '109.78515', '26.1571'),
+(1948, 1936, '洪江', '洪江市', '中国,湖南省,怀化市,洪江市', 3, 'hongjiang', '0745', '418100', 'H', '109.83651', '27.20922'),
+(1949, 1827, '娄底', '娄底市', '中国,湖南省,娄底市', 2, 'loudi', '0738', '417000', 'L', '112.008497', '27.728136'),
+(1950, 1949, '娄星', '娄星区', '中国,湖南省,娄底市,娄星区', 3, 'louxing', '0738', '417000', 'L', '112.00193', '27.72992'),
+(1951, 1949, '双峰', '双峰县', '中国,湖南省,娄底市,双峰县', 3, 'shuangfeng', '0738', '417700', 'S', '112.19921', '27.45418'),
+(1952, 1949, '新化', '新化县', '中国,湖南省,娄底市,新化县', 3, 'xinhua', '0738', '417600', 'X', '111.32739', '27.7266'),
+(1953, 1949, '冷水江', '冷水江市', '中国,湖南省,娄底市,冷水江市', 3, 'lengshuijiang', '0738', '417500', 'L', '111.43554', '27.68147'),
+(1954, 1949, '涟源', '涟源市', '中国,湖南省,娄底市,涟源市', 3, 'lianyuan', '0738', '417100', 'L', '111.67233', '27.68831'),
+(1955, 1827, '湘西', '湘西土家族苗族自治州', '中国,湖南省,湘西土家族苗族自治州', 2, 'xiangxi', '0743', '416000', 'X', '109.739735', '28.314296'),
+(1956, 1955, '吉首', '吉首市', '中国,湖南省,湘西土家族苗族自治州,吉首市', 3, 'jishou', '0743', '416000', 'J', '109.69799', '28.26247'),
+(1957, 1955, '泸溪', '泸溪县', '中国,湖南省,湘西土家族苗族自治州,泸溪县', 3, 'luxi', '0743', '416100', NULL, '110.21682', '28.2205'),
+(1958, 1955, '凤凰', '凤凰县', '中国,湖南省,湘西土家族苗族自治州,凤凰县', 3, 'fenghuang', '0743', '416200', 'F', '109.60156', '27.94822'),
+(1959, 1955, '花垣', '花垣县', '中国,湖南省,湘西土家族苗族自治州,花垣县', 3, 'huayuan', '0743', '416400', 'H', '109.48217', '28.5721'),
+(1960, 1955, '保靖', '保靖县', '中国,湖南省,湘西土家族苗族自治州,保靖县', 3, 'baojing', '0743', '416500', 'B', '109.66049', '28.69997'),
+(1961, 1955, '古丈', '古丈县', '中国,湖南省,湘西土家族苗族自治州,古丈县', 3, 'guzhang', '0743', '416300', 'G', '109.94812', '28.61944'),
+(1962, 1955, '永顺', '永顺县', '中国,湖南省,湘西土家族苗族自治州,永顺县', 3, 'yongshun', '0743', '416700', 'Y', '109.85266', '29.00103'),
+(1963, 1955, '龙山', '龙山县', '中国,湖南省,湘西土家族苗族自治州,龙山县', 3, 'longshan', '0743', '416800', 'L', '109.4432', '29.45693'),
+(1964, 0, '广东', '广东省', '中国,广东省', 1, 'guangdong', '', '', 'G', '113.280637', '23.125178'),
+(1965, 1964, '广州', '广州市', '中国,广东省,广州市', 2, 'guangzhou', '020', '510032', 'G', '113.280637', '23.125178'),
+(1966, 1965, '荔湾', '荔湾区', '中国,广东省,广州市,荔湾区', 3, 'liwan', '020', '510170', 'L', '113.2442', '23.12592'),
+(1967, 1965, '越秀', '越秀区', '中国,广东省,广州市,越秀区', 3, 'yuexiu', '020', '510030', 'Y', '113.26683', '23.12897'),
+(1968, 1965, '海珠', '海珠区', '中国,广东省,广州市,海珠区', 3, 'haizhu', '020', '510300', 'H', '113.26197', '23.10379'),
+(1969, 1965, '天河', '天河区', '中国,广东省,广州市,天河区', 3, 'tianhe', '020', '510665', 'T', '113.36112', '23.12467'),
+(1970, 1965, '白云', '白云区', '中国,广东省,广州市,白云区', 3, 'baiyun', '020', '510405', 'B', '113.27307', '23.15787'),
+(1971, 1965, '黄埔', '黄埔区', '中国,广东省,广州市,黄埔区', 3, 'huangpu', '020', '510700', 'H', '113.45895', '23.10642'),
+(1972, 1965, '番禺', '番禺区', '中国,广东省,广州市,番禺区', 3, 'panyu', '020', '511400', 'F', '113.38397', '22.93599'),
+(1973, 1965, '花都', '花都区', '中国,广东省,广州市,花都区', 3, 'huadu', '020', '510800', 'H', '113.22033', '23.40358'),
+(1974, 1965, '南沙', '南沙区', '中国,广东省,广州市,南沙区', 3, 'nansha', '020', '511458', 'N', '113.60845', '22.77144'),
+(1975, 1965, '从化', '从化区', '中国,广东省,广州市,从化区', 3, 'conghua', '020', '510900', 'C', '113.587386', '23.545283'),
+(1976, 1965, '增城', '增城区', '中国,广东省,广州市,增城区', 3, 'zengcheng', '020', '511300', 'Z', '113.829579', '23.290497'),
+(1977, 1964, '韶关', '韶关市', '中国,广东省,韶关市', 2, 'shaoguan', '0751', '512002', 'S', '113.591544', '24.801322'),
+(1978, 1977, '武江', '武江区', '中国,广东省,韶关市,武江区', 3, 'wujiang', '0751', '512026', 'W', '113.58767', '24.79264'),
+(1979, 1977, '浈江', '浈江区', '中国,广东省,韶关市,浈江区', 3, 'zhenjiang', '0751', '512023', NULL, '113.61109', '24.80438'),
+(1980, 1977, '曲江', '曲江区', '中国,广东省,韶关市,曲江区', 3, 'qujiang', '0751', '512101', 'Q', '113.60165', '24.67915'),
+(1981, 1977, '始兴', '始兴县', '中国,广东省,韶关市,始兴县', 3, 'shixing', '0751', '512500', 'S', '114.06799', '24.94759'),
+(1982, 1977, '仁化', '仁化县', '中国,广东省,韶关市,仁化县', 3, 'renhua', '0751', '512300', 'R', '113.74737', '25.08742'),
+(1983, 1977, '翁源', '翁源县', '中国,广东省,韶关市,翁源县', 3, 'wengyuan', '0751', '512600', 'W', '114.13385', '24.3495'),
+(1984, 1977, '乳源', '乳源瑶族自治县', '中国,广东省,韶关市,乳源瑶族自治县', 3, 'ruyuan', '0751', '512700', 'R', '113.27734', '24.77803'),
+(1985, 1977, '新丰', '新丰县', '中国,广东省,韶关市,新丰县', 3, 'xinfeng', '0751', '511100', 'X', '114.20788', '24.05924'),
+(1986, 1977, '乐昌', '乐昌市', '中国,广东省,韶关市,乐昌市', 3, 'lechang', '0751', '512200', 'L', '113.35653', '25.12799'),
+(1987, 1977, '南雄', '南雄市', '中国,广东省,韶关市,南雄市', 3, 'nanxiong', '0751', '512400', 'N', '114.30966', '25.11706'),
+(1988, 1964, '深圳', '深圳市', '中国,广东省,深圳市', 2, 'shenzhen', '0755', '518035', 'S', '114.085947', '22.547'),
+(1989, 1988, '罗湖', '罗湖区', '中国,广东省,深圳市,罗湖区', 3, 'luohu', '0755', '518021', 'L', '114.13116', '22.54836'),
+(1990, 1988, '福田', '福田区', '中国,广东省,深圳市,福田区', 3, 'futian', '0755', '518048', 'F', '114.05571', '22.52245'),
+(1991, 1988, '南山', '南山区', '中国,广东省,深圳市,南山区', 3, 'nanshan', '0755', '518051', 'N', '113.93029', '22.53291'),
+(1992, 1988, '宝安', '宝安区', '中国,广东省,深圳市,宝安区', 3, 'bao''an', '0755', '518101', 'B', '113.88311', '22.55371'),
+(1993, 1988, '龙岗', '龙岗区', '中国,广东省,深圳市,龙岗区', 3, 'longgang', '0755', '518172', 'L', '114.24771', '22.71986'),
+(1994, 1988, '盐田', '盐田区', '中国,广东省,深圳市,盐田区', 3, 'yantian', '0755', '518081', 'Y', '114.23733', '22.5578'),
+(1995, 1988, '光明新区', '光明新区', '中国,广东省,深圳市,光明新区', 3, 'guangmingxinqu', '0755', '518100', 'G', '113.896026', '22.777292'),
+(1996, 1988, '坪山新区', '坪山新区', '中国,广东省,深圳市,坪山新区', 3, 'pingshanxinqu', '0755', '518000', 'P', '114.34637', '22.690529'),
+(1997, 1988, '大鹏新区', '大鹏新区', '中国,广东省,深圳市,大鹏新区', 3, 'dapengxinqu', '0755', '518000', 'D', '114.479901', '22.587862'),
+(1998, 1988, '龙华新区', '龙华新区', '中国,广东省,深圳市,龙华新区', 3, 'longhuaxinqu', '0755', '518100', 'L', '114.036585', '22.68695'),
+(1999, 1964, '珠海', '珠海市', '中国,广东省,珠海市', 2, 'zhuhai', '0756', '519000', 'Z', '113.552724', '22.255899'),
+(2000, 1999, '香洲', '香洲区', '中国,广东省,珠海市,香洲区', 3, 'xiangzhou', '0756', '519000', 'X', '113.5435', '22.26654'),
+(2001, 1999, '斗门', '斗门区', '中国,广东省,珠海市,斗门区', 3, 'doumen', '0756', '519110', 'D', '113.29644', '22.20898'),
+(2002, 1999, '金湾', '金湾区', '中国,广东省,珠海市,金湾区', 3, 'jinwan', '0756', '519040', 'J', '113.36361', '22.14691'),
+(2003, 1964, '汕头', '汕头市', '中国,广东省,汕头市', 2, 'shantou', '0754', '515041', 'S', '116.708463', '23.37102'),
+(2004, 2003, '龙湖', '龙湖区', '中国,广东省,汕头市,龙湖区', 3, 'longhu', '0754', '515041', 'L', '116.71641', '23.37166'),
+(2005, 2003, '金平', '金平区', '中国,广东省,汕头市,金平区', 3, 'jinping', '0754', '515041', 'J', '116.70364', '23.36637'),
+(2006, 2003, '濠江', '濠江区', '中国,广东省,汕头市,濠江区', 3, 'haojiang', '0754', '515071', NULL, '116.72659', '23.28588'),
+(2007, 2003, '潮阳', '潮阳区', '中国,广东省,汕头市,潮阳区', 3, 'chaoyang', '0754', '515100', 'C', '116.6015', '23.26485'),
+(2008, 2003, '潮南', '潮南区', '中国,广东省,汕头市,潮南区', 3, 'chaonan', '0754', '515144', 'C', '116.43188', '23.25'),
+(2009, 2003, '澄海', '澄海区', '中国,广东省,汕头市,澄海区', 3, 'chenghai', '0754', '515800', 'C', '116.75589', '23.46728'),
+(2010, 2003, '南澳', '南澳县', '中国,广东省,汕头市,南澳县', 3, 'nanao', '0754', '515900', 'N', '117.01889', '23.4223'),
+(2011, 1964, '佛山', '佛山市', '中国,广东省,佛山市', 2, 'foshan', '0757', '528000', 'F', '113.122717', '23.028762'),
+(2012, 2011, '禅城', '禅城区', '中国,广东省,佛山市,禅城区', 3, 'chancheng', '0757', '528000', NULL, '113.1228', '23.00842'),
+(2013, 2011, '南海', '南海区', '中国,广东省,佛山市,南海区', 3, 'nanhai', '0757', '528251', 'N', '113.14299', '23.02877'),
+(2014, 2011, '顺德', '顺德区', '中国,广东省,佛山市,顺德区', 3, 'shunde', '0757', '528300', 'S', '113.29394', '22.80452'),
+(2015, 2011, '三水', '三水区', '中国,广东省,佛山市,三水区', 3, 'sanshui', '0757', '528133', 'S', '112.89703', '23.15564'),
+(2016, 2011, '高明', '高明区', '中国,广东省,佛山市,高明区', 3, 'gaoming', '0757', '528500', 'G', '112.89254', '22.90022'),
+(2017, 1964, '江门', '江门市', '中国,广东省,江门市', 2, 'jiangmen', '0750', '529000', 'J', '113.094942', '22.590431'),
+(2018, 2017, '蓬江', '蓬江区', '中国,广东省,江门市,蓬江区', 3, 'pengjiang', '0750', '529000', 'P', '113.07849', '22.59515'),
+(2019, 2017, '江海', '江海区', '中国,广东省,江门市,江海区', 3, 'jianghai', '0750', '529040', 'J', '113.11099', '22.56024'),
+(2020, 2017, '新会', '新会区', '中国,广东省,江门市,新会区', 3, 'xinhui', '0750', '529100', 'X', '113.03225', '22.45876'),
+(2021, 2017, '台山', '台山市', '中国,广东省,江门市,台山市', 3, 'taishan', '0750', '529200', 'T', '112.79382', '22.2515'),
+(2022, 2017, '开平', '开平市', '中国,广东省,江门市,开平市', 3, 'kaiping', '0750', '529337', 'K', '112.69842', '22.37622'),
+(2023, 2017, '鹤山', '鹤山市', '中国,广东省,江门市,鹤山市', 3, 'heshan', '0750', '529700', 'H', '112.96429', '22.76523'),
+(2024, 2017, '恩平', '恩平市', '中国,广东省,江门市,恩平市', 3, 'enping', '0750', '529400', 'E', '112.30496', '22.18288'),
+(2025, 1964, '湛江', '湛江市', '中国,广东省,湛江市', 2, 'zhanjiang', '0759', '524047', 'Z', '110.405529', '21.195338'),
+(2026, 2025, '赤坎', '赤坎区', '中国,广东省,湛江市,赤坎区', 3, 'chikan', '0759', '524033', 'C', '110.36592', '21.26606'),
+(2027, 2025, '霞山', '霞山区', '中国,广东省,湛江市,霞山区', 3, 'xiashan', '0759', '524011', 'X', '110.39822', '21.19181'),
+(2028, 2025, '坡头', '坡头区', '中国,广东省,湛江市,坡头区', 3, 'potou', '0759', '524057', 'P', '110.45533', '21.24472'),
+(2029, 2025, '麻章', '麻章区', '中国,广东省,湛江市,麻章区', 3, 'mazhang', '0759', '524094', 'M', '110.3342', '21.26333'),
+(2030, 2025, '遂溪', '遂溪县', '中国,广东省,湛江市,遂溪县', 3, 'suixi', '0759', '524300', 'S', '110.25003', '21.37721'),
+(2031, 2025, '徐闻', '徐闻县', '中国,广东省,湛江市,徐闻县', 3, 'xuwen', '0759', '524100', 'X', '110.17379', '20.32812'),
+(2032, 2025, '廉江', '廉江市', '中国,广东省,湛江市,廉江市', 3, 'lianjiang', '0759', '524400', 'L', '110.28442', '21.60917'),
+(2033, 2025, '雷州', '雷州市', '中国,广东省,湛江市,雷州市', 3, 'leizhou', '0759', '524200', 'L', '110.10092', '20.91428'),
+(2034, 2025, '吴川', '吴川市', '中国,广东省,湛江市,吴川市', 3, 'wuchuan', '0759', '524500', 'W', '110.77703', '21.44584'),
+(2035, 1964, '茂名', '茂名市', '中国,广东省,茂名市', 2, 'maoming', '0668', '525000', 'M', '110.919229', '21.659751'),
+(2036, 2035, '茂南', '茂南区', '中国,广东省,茂名市,茂南区', 3, 'maonan', '0668', '525000', 'M', '110.9187', '21.64103'),
+(2037, 2035, '电白', '电白区', '中国,广东省,茂名市,电白区', 3, 'dianbai', '0668', '525400', 'D', '111.007264', '21.507219'),
+(2038, 2035, '高州', '高州市', '中国,广东省,茂名市,高州市', 3, 'gaozhou', '0668', '525200', 'G', '110.85519', '21.92057'),
+(2039, 2035, '化州', '化州市', '中国,广东省,茂名市,化州市', 3, 'huazhou', '0668', '525100', 'H', '110.63949', '21.66394'),
+(2040, 2035, '信宜', '信宜市', '中国,广东省,茂名市,信宜市', 3, 'xinyi', '0668', '525300', 'X', '110.94647', '22.35351'),
+(2041, 1964, '肇庆', '肇庆市', '中国,广东省,肇庆市', 2, 'zhaoqing', '0758', '526040', 'Z', '112.472529', '23.051546'),
+(2042, 2041, '端州', '端州区', '中国,广东省,肇庆市,端州区', 3, 'duanzhou', '0758', '526060', 'D', '112.48495', '23.0519'),
+(2043, 2041, '鼎湖', '鼎湖区', '中国,广东省,肇庆市,鼎湖区', 3, 'dinghu', '0758', '526070', 'D', '112.56643', '23.15846'),
+(2044, 2041, '广宁', '广宁县', '中国,广东省,肇庆市,广宁县', 3, 'guangning', '0758', '526300', 'G', '112.44064', '23.6346'),
+(2045, 2041, '怀集', '怀集县', '中国,广东省,肇庆市,怀集县', 3, 'huaiji', '0758', '526400', 'H', '112.18396', '23.90918'),
+(2046, 2041, '封开', '封开县', '中国,广东省,肇庆市,封开县', 3, 'fengkai', '0758', '526500', 'F', '111.50332', '23.43571'),
+(2047, 2041, '德庆', '德庆县', '中国,广东省,肇庆市,德庆县', 3, 'deqing', '0758', '526600', 'D', '111.78555', '23.14371'),
+(2048, 2041, '高要', '高要市', '中国,广东省,肇庆市,高要市', 3, 'gaoyao', '0758', '526100', 'G', '112.45834', '23.02577'),
+(2049, 2041, '四会', '四会市', '中国,广东省,肇庆市,四会市', 3, 'sihui', '0758', '526200', 'S', '112.73416', '23.32686'),
+(2050, 1964, '惠州', '惠州市', '中国,广东省,惠州市', 2, 'huizhou', '0752', '516000', 'H', '114.412599', '23.079404'),
+(2051, 2050, '惠城', '惠城区', '中国,广东省,惠州市,惠城区', 3, 'huicheng', '0752', '516008', 'H', '114.3828', '23.08377'),
+(2052, 2050, '惠阳', '惠阳区', '中国,广东省,惠州市,惠阳区', 3, 'huiyang', '0752', '516211', 'H', '114.45639', '22.78845'),
+(2053, 2050, '博罗', '博罗县', '中国,广东省,惠州市,博罗县', 3, 'boluo', '0752', '516100', 'B', '114.28964', '23.17307'),
+(2054, 2050, '惠东', '惠东县', '中国,广东省,惠州市,惠东县', 3, 'huidong', '0752', '516300', 'H', '114.72009', '22.98484'),
+(2055, 2050, '龙门', '龙门县', '中国,广东省,惠州市,龙门县', 3, 'longmen', '0752', '516800', 'L', '114.25479', '23.72758'),
+(2056, 1964, '梅州', '梅州市', '中国,广东省,梅州市', 2, 'meizhou', '0753', '514021', 'M', '116.117582', '24.299112'),
+(2057, 2056, '梅江', '梅江区', '中国,广东省,梅州市,梅江区', 3, 'meijiang', '0753', '514000', 'M', '116.11663', '24.31062'),
+(2058, 2056, '梅县', '梅县区', '中国,广东省,梅州市,梅县区', 3, 'meixian', '0753', '514787', 'M', '116.097753', '24.286739'),
+(2059, 2056, '大埔', '大埔县', '中国,广东省,梅州市,大埔县', 3, 'dabu', '0753', '514200', 'D', '116.69662', '24.35325'),
+(2060, 2056, '丰顺', '丰顺县', '中国,广东省,梅州市,丰顺县', 3, 'fengshun', '0753', '514300', 'F', '116.18219', '23.74094'),
+(2061, 2056, '五华', '五华县', '中国,广东省,梅州市,五华县', 3, 'wuhua', '0753', '514400', 'W', '115.77893', '23.92417'),
+(2062, 2056, '平远', '平远县', '中国,广东省,梅州市,平远县', 3, 'pingyuan', '0753', '514600', 'P', '115.89556', '24.57116'),
+(2063, 2056, '蕉岭', '蕉岭县', '中国,广东省,梅州市,蕉岭县', 3, 'jiaoling', '0753', '514100', 'J', '116.17089', '24.65732'),
+(2064, 2056, '兴宁', '兴宁市', '中国,广东省,梅州市,兴宁市', 3, 'xingning', '0753', '514500', 'X', '115.73141', '24.14001'),
+(2065, 1964, '汕尾', '汕尾市', '中国,广东省,汕尾市', 2, 'shanwei', '0660', '516600', 'S', '115.364238', '22.774485'),
+(2066, 2065, '城区', '城区', '中国,广东省,汕尾市,城区', 3, 'chengqu', '0660', '516600', 'C', '115.36503', '22.7789'),
+(2067, 2065, '海丰', '海丰县', '中国,广东省,汕尾市,海丰县', 3, 'haifeng', '0660', '516400', 'H', '115.32336', '22.96653'),
+(2068, 2065, '陆河', '陆河县', '中国,广东省,汕尾市,陆河县', 3, 'luhe', '0660', '516700', 'L', '115.65597', '23.30365'),
+(2069, 2065, '陆丰', '陆丰市', '中国,广东省,汕尾市,陆丰市', 3, 'lufeng', '0660', '516500', 'L', '115.64813', '22.94335'),
+(2070, 1964, '河源', '河源市', '中国,广东省,河源市', 2, 'heyuan', '0762', '517000', 'H', '114.697802', '23.746266'),
+(2071, 2070, '源城', '源城区', '中国,广东省,河源市,源城区', 3, 'yuancheng', '0762', '517000', 'Y', '114.70242', '23.7341'),
+(2072, 2070, '紫金', '紫金县', '中国,广东省,河源市,紫金县', 3, 'zijin', '0762', '517400', 'Z', '115.18365', '23.63867'),
+(2073, 2070, '龙川', '龙川县', '中国,广东省,河源市,龙川县', 3, 'longchuan', '0762', '517300', 'L', '115.26025', '24.10142'),
+(2074, 2070, '连平', '连平县', '中国,广东省,河源市,连平县', 3, 'lianping', '0762', '517100', 'L', '114.49026', '24.37156'),
+(2075, 2070, '和平', '和平县', '中国,广东省,河源市,和平县', 3, 'heping', '0762', '517200', 'H', '114.93841', '24.44319'),
+(2076, 2070, '东源', '东源县', '中国,广东省,河源市,东源县', 3, 'dongyuan', '0762', '517583', 'D', '114.74633', '23.78835'),
+(2077, 1964, '阳江', '阳江市', '中国,广东省,阳江市', 2, 'yangjiang', '0662', '529500', 'Y', '111.975107', '21.859222'),
+(2078, 2077, '江城', '江城区', '中国,广东省,阳江市,江城区', 3, 'jiangcheng', '0662', '529500', 'J', '111.95488', '21.86193'),
+(2079, 2077, '阳东', '阳东区', '中国,广东省,阳江市,阳东区', 3, 'yangdong', '0662', '529900', 'Y', '112.01467', '21.87398'),
+(2080, 2077, '阳西', '阳西县', '中国,广东省,阳江市,阳西县', 3, 'yangxi', '0662', '529800', 'Y', '111.61785', '21.75234'),
+(2081, 2077, '阳春', '阳春市', '中国,广东省,阳江市,阳春市', 3, 'yangchun', '0662', '529600', 'Y', '111.78854', '22.17232'),
+(2082, 1964, '清远', '清远市', '中国,广东省,清远市', 2, 'qingyuan', '0763', '511500', 'Q', '113.036779', '23.704188'),
+(2083, 2082, '清城', '清城区', '中国,广东省,清远市,清城区', 3, 'qingcheng', '0763', '511515', 'Q', '113.06265', '23.69784'),
+(2084, 2082, '清新', '清新区', '中国,广东省,清远市,清新区', 3, 'qingxin', '0763', '511810', 'Q', '113.015203', '23.736949'),
+(2085, 2082, '佛冈', '佛冈县', '中国,广东省,清远市,佛冈县', 3, 'fogang', '0763', '511600', 'F', '113.53286', '23.87231'),
+(2086, 2082, '阳山', '阳山县', '中国,广东省,清远市,阳山县', 3, 'yangshan', '0763', '513100', 'Y', '112.64129', '24.46516'),
+(2087, 2082, '连山', '连山壮族瑶族自治县', '中国,广东省,清远市,连山壮族瑶族自治县', 3, 'lianshan', '0763', '513200', 'L', '112.0802', '24.56807'),
+(2088, 2082, '连南', '连南瑶族自治县', '中国,广东省,清远市,连南瑶族自治县', 3, 'liannan', '0763', '513300', 'L', '112.28842', '24.71726'),
+(2089, 2082, '英德', '英德市', '中国,广东省,清远市,英德市', 3, 'yingde', '0763', '513000', 'Y', '113.415', '24.18571'),
+(2090, 2082, '连州', '连州市', '中国,广东省,清远市,连州市', 3, 'lianzhou', '0763', '513400', 'L', '112.38153', '24.77913'),
+(2091, 1964, '东莞', '东莞市', '中国,广东省,东莞市', 2, 'dongguan', '0769', '523888', 'D', '113.760234', '23.048884'),
+(2092, 2091, '莞城', '莞城区', '中国,广东省,东莞市,莞城区', 3, 'guancheng', '0769', '523128', NULL, '113.751043', '23.053412'),
+(2093, 2091, '南城', '南城区', '中国,广东省,东莞市,南城区', 3, 'nancheng', '0769', '523617', 'N', '113.752125', '23.02018'),
+(2094, 2091, '万江', '万江区', '中国,广东省,东莞市,万江区', 3, 'wanjiang', '0769', '523039', 'W', '113.739053', '23.043842'),
+(2095, 2091, '石碣', '石碣镇', '中国,广东省,东莞市,石碣镇', 3, 'shijie', '0769', '523290', 'S', '113.80217', '23.09899'),
+(2096, 2091, '石龙', '石龙镇', '中国,广东省,东莞市,石龙镇', 3, 'shilong', '0769', '523326', 'S', '113.876381', '23.107444'),
+(2097, 2091, '茶山', '茶山镇', '中国,广东省,东莞市,茶山镇', 3, 'chashan', '0769', '523380', 'C', '113.883526', '23.062375'),
+(2098, 2091, '石排', '石排镇', '中国,广东省,东莞市,石排镇', 3, 'shipai', '0769', '523346', 'S', '113.919859', '23.0863'),
+(2099, 2091, '企石', '企石镇', '中国,广东省,东莞市,企石镇', 3, 'qishi', '0769', '523507', 'Q', '114.013233', '23.066044'),
+(2100, 2091, '横沥', '横沥镇', '中国,广东省,东莞市,横沥镇', 3, 'hengli', '0769', '523471', 'H', '113.957436', '23.025732'),
+(2101, 2091, '桥头', '桥头镇', '中国,广东省,东莞市,桥头镇', 3, 'qiaotou', '0769', '523520', 'Q', '114.01385', '22.939727'),
+(2102, 2091, '谢岗', '谢岗镇', '中国,广东省,东莞市,谢岗镇', 3, 'xiegang', '0769', '523592', 'X', '114.141396', '22.959664'),
+(2103, 2091, '东坑', '东坑镇', '中国,广东省,东莞市,东坑镇', 3, 'dongkeng', '0769', '523451', 'D', '113.939835', '22.992804'),
+(2104, 2091, '常平', '常平镇', '中国,广东省,东莞市,常平镇', 3, 'changping', '0769', '523560', 'C', '114.029627', '23.016116'),
+(2105, 2091, '寮步', '寮步镇', '中国,广东省,东莞市,寮步镇', 3, 'liaobu', '0769', '523411', NULL, '113.884745', '22.991738'),
+(2106, 2091, '大朗', '大朗镇', '中国,广东省,东莞市,大朗镇', 3, 'dalang', '0769', '523770', 'D', '113.9271', '22.965748'),
+(2107, 2091, '麻涌', '麻涌镇', '中国,广东省,东莞市,麻涌镇', 3, 'machong', '0769', '523143', 'M', '113.546177', '23.045315'),
+(2108, 2091, '中堂', '中堂镇', '中国,广东省,东莞市,中堂镇', 3, 'zhongtang', '0769', '523233', 'Z', '113.654422', '23.090164'),
+(2109, 2091, '高埗', '高埗镇', '中国,广东省,东莞市,高埗镇', 3, 'gaobu', '0769', '523282', NULL, '113.735917', '23.068415'),
+(2110, 2091, '樟木头', '樟木头镇', '中国,广东省,东莞市,樟木头镇', 3, 'zhangmutou', '0769', '523619', 'Z', '114.066298', '22.956682'),
+(2111, 2091, '大岭山', '大岭山镇', '中国,广东省,东莞市,大岭山镇', 3, 'dalingshan', '0769', '523835', 'D', '113.782955', '22.885366'),
+(2112, 2091, '望牛墩', '望牛墩镇', '中国,广东省,东莞市,望牛墩镇', 3, 'wangniudun', '0769', '523203', 'W', '113.658847', '23.055018'),
+(2113, 2091, '黄江', '黄江镇', '中国,广东省,东莞市,黄江镇', 3, 'huangjiang', '0769', '523755', 'H', '113.992635', '22.877536'),
+(2114, 2091, '洪梅', '洪梅镇', '中国,广东省,东莞市,洪梅镇', 3, 'hongmei', '0769', '523163', 'H', '113.613081', '22.992675'),
+(2115, 2091, '清溪', '清溪镇', '中国,广东省,东莞市,清溪镇', 3, 'qingxi', '0769', '523660', 'Q', '114.155796', '22.844456'),
+(2116, 2091, '沙田', '沙田镇', '中国,广东省,东莞市,沙田镇', 3, 'shatian', '0769', '523988', 'S', '113.760234', '23.048884'),
+(2117, 2091, '道滘', '道滘镇', '中国,广东省,东莞市,道滘镇', 3, 'daojiao', '0769', '523171', NULL, '113.760234', '23.048884'),
+(2118, 2091, '塘厦', '塘厦镇', '中国,广东省,东莞市,塘厦镇', 3, 'tangxia', '0769', '523713', 'T', '114.10765', '22.822862'),
+(2119, 2091, '虎门', '虎门镇', '中国,广东省,东莞市,虎门镇', 3, 'humen', '0769', '523932', 'H', '113.71118', '22.82615'),
+(2120, 2091, '厚街', '厚街镇', '中国,广东省,东莞市,厚街镇', 3, 'houjie', '0769', '523960', 'H', '113.67301', '22.940815'),
+(2121, 2091, '凤岗', '凤岗镇', '中国,广东省,东莞市,凤岗镇', 3, 'fenggang', '0769', '523690', 'F', '114.141194', '22.744598'),
+(2122, 2091, '长安', '长安镇', '中国,广东省,东莞市,长安镇', 3, 'chang''an', '0769', '523850', 'C', '113.803939', '22.816644'),
+(2123, 1964, '中山', '中山市', '中国,广东省,中山市', 2, 'zhongshan', '0760', '528403', 'Z', '113.382391', '22.521113'),
+(2124, 2123, '石岐', '石岐区', '中国,广东省,中山市,石岐区', 3, 'shiqi', '0760', '528400', 'S', '113.378835', '22.52522'),
+(2125, 2123, '南区', '南区', '中国,广东省,中山市,南区', 3, 'nanqu', '0760', '528400', 'N', '113.355896', '22.486568'),
+(2126, 2123, '五桂山', '五桂山区', '中国,广东省,中山市,五桂山区', 3, 'wuguishan', '0760', '528458', 'W', '113.41079', '22.51968'),
+(2127, 2123, '火炬', '火炬开发区', '中国,广东省,中山市,火炬开发区', 3, 'huoju', '0760', '528437', 'H', '113.480523', '22.566082'),
+(2128, 2123, '黄圃', '黄圃镇', '中国,广东省,中山市,黄圃镇', 3, 'huangpu', '0760', '528429', 'H', '113.342359', '22.715116'),
+(2129, 2123, '南头', '南头镇', '中国,广东省,中山市,南头镇', 3, 'nantou', '0760', '528421', 'N', '113.296358', '22.713907'),
+(2130, 2123, '东凤', '东凤镇', '中国,广东省,中山市,东凤镇', 3, 'dongfeng', '0760', '528425', 'D', '113.26114', '22.68775'),
+(2131, 2123, '阜沙', '阜沙镇', '中国,广东省,中山市,阜沙镇', 3, 'fusha', '0760', '528434', 'F', '113.353024', '22.666364'),
+(2132, 2123, '小榄', '小榄镇', '中国,广东省,中山市,小榄镇', 3, 'xiaolan', '0760', '528415', 'X', '113.244235', '22.666951'),
+(2133, 2123, '东升', '东升镇', '中国,广东省,中山市,东升镇', 3, 'dongsheng', '0760', '528400', 'D', '113.296298', '22.614003'),
+(2134, 2123, '古镇', '古镇镇', '中国,广东省,中山市,古镇镇', 3, 'guzhen', '0760', '528422', 'G', '113.179745', '22.611019'),
+(2135, 2123, '横栏', '横栏镇', '中国,广东省,中山市,横栏镇', 3, 'henglan', '0760', '528478', 'H', '113.265845', '22.523202'),
+(2136, 2123, '三角', '三角镇', '中国,广东省,中山市,三角镇', 3, 'sanjiao', '0760', '528422', 'S', '113.423624', '22.677033'),
+(2137, 2123, '民众', '民众镇', '中国,广东省,中山市,民众镇', 3, 'minzhong', '0760', '528441', 'M', '113.486025', '22.623468'),
+(2138, 2123, '南朗', '南朗镇', '中国,广东省,中山市,南朗镇', 3, 'nanlang', '0760', '528454', 'N', '113.533939', '22.492378'),
+(2139, 2123, '港口', '港口镇', '中国,广东省,中山市,港口镇', 3, 'gangkou', '0760', '528447', 'G', '113.382391', '22.521113'),
+(2140, 2123, '大涌', '大涌镇', '中国,广东省,中山市,大涌镇', 3, 'dayong', '0760', '528476', 'D', '113.291708', '22.467712'),
+(2141, 2123, '沙溪', '沙溪镇', '中国,广东省,中山市,沙溪镇', 3, 'shaxi', '0760', '528471', 'S', '113.328369', '22.526325'),
+(2142, 2123, '三乡', '三乡镇', '中国,广东省,中山市,三乡镇', 3, 'sanxiang', '0760', '528463', 'S', '113.4334', '22.352494'),
+(2143, 2123, '板芙', '板芙镇', '中国,广东省,中山市,板芙镇', 3, 'banfu', '0760', '528459', 'B', '113.320346', '22.415674'),
+(2144, 2123, '神湾', '神湾镇', '中国,广东省,中山市,神湾镇', 3, 'shenwan', '0760', '528462', 'S', '113.359387', '22.312476'),
+(2145, 2123, '坦洲', '坦洲镇', '中国,广东省,中山市,坦洲镇', 3, 'tanzhou', '0760', '528467', 'T', '113.485677', '22.261269'),
+(2146, 1964, '潮州', '潮州市', '中国,广东省,潮州市', 2, 'chaozhou', '0768', '521000', 'C', '116.632301', '23.661701'),
+(2147, 2146, '湘桥', '湘桥区', '中国,广东省,潮州市,湘桥区', 3, 'xiangqiao', '0768', '521000', 'X', '116.62805', '23.67451'),
+(2148, 2146, '潮安', '潮安区', '中国,广东省,潮州市,潮安区', 3, 'chao''an', '0768', '515638', 'C', '116.592895', '23.643656'),
+(2149, 2146, '饶平', '饶平县', '中国,广东省,潮州市,饶平县', 3, 'raoping', '0768', '515700', 'R', '117.00692', '23.66994'),
+(2150, 1964, '揭阳', '揭阳市', '中国,广东省,揭阳市', 2, 'jieyang', '0633', '522000', 'J', '116.355733', '23.543778'),
+(2151, 2150, '榕城', '榕城区', '中国,广东省,揭阳市,榕城区', 3, 'rongcheng', '0633', '522000', NULL, '116.3671', '23.52508'),
+(2152, 2150, '揭东', '揭东区', '中国,广东省,揭阳市,揭东区', 3, 'jiedong', '0633', '515500', 'J', '116.412947', '23.569887'),
+(2153, 2150, '揭西', '揭西县', '中国,广东省,揭阳市,揭西县', 3, 'jiexi', '0633', '515400', 'J', '115.83883', '23.42714'),
+(2154, 2150, '惠来', '惠来县', '中国,广东省,揭阳市,惠来县', 3, 'huilai', '0633', '515200', 'H', '116.29599', '23.03289'),
+(2155, 2150, '普宁', '普宁市', '中国,广东省,揭阳市,普宁市', 3, 'puning', '0633', '515300', 'P', '116.16564', '23.29732'),
+(2156, 1964, '云浮', '云浮市', '中国,广东省,云浮市', 2, 'yunfu', '0766', '527300', 'Y', '112.044439', '22.929801'),
+(2157, 2156, '云城', '云城区', '中国,广东省,云浮市,云城区', 3, 'yuncheng', '0766', '527300', 'Y', '112.03908', '22.92996'),
+(2158, 2156, '云安', '云安区', '中国,广东省,云浮市,云安区', 3, 'yun''an', '0766', '527500', 'Y', '112.00936', '23.07779'),
+(2159, 2156, '新兴', '新兴县', '中国,广东省,云浮市,新兴县', 3, 'xinxing', '0766', '527400', 'X', '112.23019', '22.69734'),
+(2160, 2156, '郁南', '郁南县', '中国,广东省,云浮市,郁南县', 3, 'yunan', '0766', '527100', 'Y', '111.53387', '23.23307'),
+(2161, 2156, '罗定', '罗定市', '中国,广东省,云浮市,罗定市', 3, 'luoding', '0766', '527200', 'L', '111.56979', '22.76967'),
+(2162, 0, '广西', '广西壮族自治区', '中国,广西壮族自治区', 1, 'guangxi', '', '', 'G', '108.320004', '22.82402'),
+(2163, 2162, '南宁', '南宁市', '中国,广西壮族自治区,南宁市', 2, 'nanning', '0771', '530028', 'N', '108.320004', '22.82402'),
+(2164, 2163, '兴宁', '兴宁区', '中国,广西壮族自治区,南宁市,兴宁区', 3, 'xingning', '0771', '530023', 'X', '108.36694', '22.85355'),
+(2165, 2163, '青秀', '青秀区', '中国,广西壮族自治区,南宁市,青秀区', 3, 'qingxiu', '0771', '530213', 'Q', '108.49545', '22.78511'),
+(2166, 2163, '江南', '江南区', '中国,广西壮族自治区,南宁市,江南区', 3, 'jiangnan', '0771', '530031', 'J', '108.27325', '22.78127'),
+(2167, 2163, '西乡塘', '西乡塘区', '中国,广西壮族自治区,南宁市,西乡塘区', 3, 'xixiangtang', '0771', '530001', 'X', '108.31347', '22.83386'),
+(2168, 2163, '良庆', '良庆区', '中国,广西壮族自治区,南宁市,良庆区', 3, 'liangqing', '0771', '530219', 'L', '108.41284', '22.74914'),
+(2169, 2163, '邕宁', '邕宁区', '中国,广西壮族自治区,南宁市,邕宁区', 3, 'yongning', '0771', '530200', NULL, '108.48684', '22.75628'),
+(2170, 2163, '武鸣', '武鸣县', '中国,广西壮族自治区,南宁市,武鸣县', 3, 'wuming', '0771', '530100', 'W', '108.27719', '23.15643'),
+(2171, 2163, '隆安', '隆安县', '中国,广西壮族自治区,南宁市,隆安县', 3, 'long''an', '0771', '532700', 'L', '107.69192', '23.17336'),
+(2172, 2163, '马山', '马山县', '中国,广西壮族自治区,南宁市,马山县', 3, 'mashan', '0771', '530600', 'M', '108.17697', '23.70931'),
+(2173, 2163, '上林', '上林县', '中国,广西壮族自治区,南宁市,上林县', 3, 'shanglin', '0771', '530500', 'S', '108.60522', '23.432'),
+(2174, 2163, '宾阳', '宾阳县', '中国,广西壮族自治区,南宁市,宾阳县', 3, 'binyang', '0771', '530400', 'B', '108.81185', '23.2196'),
+(2175, 2163, '横县', '横县', '中国,广西壮族自治区,南宁市,横县', 3, 'hengxian', '0771', '530300', 'H', '109.26608', '22.68448'),
+(2176, 2163, '埌东', '埌东新区', '中国,广西壮族自治区,南宁市,埌东新区', 3, 'langdong', '0771', '530000', NULL, '108.419094', '22.812976'),
+(2177, 2162, '柳州', '柳州市', '中国,广西壮族自治区,柳州市', 2, 'liuzhou', '0772', '545001', 'L', '109.411703', '24.314617'),
+(2178, 2177, '城中', '城中区', '中国,广西壮族自治区,柳州市,城中区', 3, 'chengzhong', '0772', '545001', 'C', '109.41082', '24.31543'),
+(2179, 2177, '鱼峰', '鱼峰区', '中国,广西壮族自治区,柳州市,鱼峰区', 3, 'yufeng', '0772', '545005', 'Y', '109.4533', '24.31868'),
+(2180, 2177, '柳南', '柳南区', '中国,广西壮族自治区,柳州市,柳南区', 3, 'liunan', '0772', '545007', 'L', '109.38548', '24.33599'),
+(2181, 2177, '柳北', '柳北区', '中国,广西壮族自治区,柳州市,柳北区', 3, 'liubei', '0772', '545002', 'L', '109.40202', '24.36267'),
+(2182, 2177, '柳江', '柳江县', '中国,广西壮族自治区,柳州市,柳江县', 3, 'liujiang', '0772', '545100', 'L', '109.33273', '24.25596'),
+(2183, 2177, '柳城', '柳城县', '中国,广西壮族自治区,柳州市,柳城县', 3, 'liucheng', '0772', '545200', 'L', '109.23877', '24.64951'),
+(2184, 2177, '鹿寨', '鹿寨县', '中国,广西壮族自治区,柳州市,鹿寨县', 3, 'luzhai', '0772', '545600', 'L', '109.75177', '24.47306'),
+(2185, 2177, '融安', '融安县', '中国,广西壮族自治区,柳州市,融安县', 3, 'rong''an', '0772', '545400', 'R', '109.39761', '25.22465'),
+(2186, 2177, '融水', '融水苗族自治县', '中国,广西壮族自治区,柳州市,融水苗族自治县', 3, 'rongshui', '0772', '545300', 'R', '109.25634', '25.06628'),
+(2187, 2177, '三江', '三江侗族自治县', '中国,广西壮族自治区,柳州市,三江侗族自治县', 3, 'sanjiang', '0772', '545500', 'S', '109.60446', '25.78428'),
+(2188, 2177, '柳东', '柳东新区', '中国,广西壮族自治区,柳州市,柳东新区', 3, 'liudong', '0772', '545000', 'L', '109.437053', '24.329204'),
+(2189, 2162, '桂林', '桂林市', '中国,广西壮族自治区,桂林市', 2, 'guilin', '0773', '541100', 'G', '110.299121', '25.274215'),
+(2190, 2189, '秀峰', '秀峰区', '中国,广西壮族自治区,桂林市,秀峰区', 3, 'xiufeng', '0773', '541001', 'X', '110.28915', '25.28249'),
+(2191, 2189, '叠彩', '叠彩区', '中国,广西壮族自治区,桂林市,叠彩区', 3, 'diecai', '0773', '541001', 'D', '110.30195', '25.31381'),
+(2192, 2189, '象山', '象山区', '中国,广西壮族自治区,桂林市,象山区', 3, 'xiangshan', '0773', '541002', 'X', '110.28108', '25.26168'),
+(2193, 2189, '七星', '七星区', '中国,广西壮族自治区,桂林市,七星区', 3, 'qixing', '0773', '541004', 'Q', '110.31793', '25.2525'),
+(2194, 2189, '雁山', '雁山区', '中国,广西壮族自治区,桂林市,雁山区', 3, 'yanshan', '0773', '541006', 'Y', '110.30911', '25.06038'),
+(2195, 2189, '临桂', '临桂区', '中国,广西壮族自治区,桂林市,临桂区', 3, 'lingui', '0773', '541100', 'L', '110.205487', '25.246257'),
+(2196, 2189, '阳朔', '阳朔县', '中国,广西壮族自治区,桂林市,阳朔县', 3, 'yangshuo', '0773', '541900', 'Y', '110.49475', '24.77579'),
+(2197, 2189, '灵川', '灵川县', '中国,广西壮族自治区,桂林市,灵川县', 3, 'lingchuan', '0773', '541200', 'L', '110.32949', '25.41292'),
+(2198, 2189, '全州', '全州县', '中国,广西壮族自治区,桂林市,全州县', 3, 'quanzhou', '0773', '541503', 'Q', '111.07211', '25.92799'),
+(2199, 2189, '兴安', '兴安县', '中国,广西壮族自治区,桂林市,兴安县', 3, 'xing''an', '0773', '541300', 'X', '110.67144', '25.61167'),
+(2200, 2189, '永福', '永福县', '中国,广西壮族自治区,桂林市,永福县', 3, 'yongfu', '0773', '541800', 'Y', '109.98333', '24.98004'),
+(2201, 2189, '灌阳', '灌阳县', '中国,广西壮族自治区,桂林市,灌阳县', 3, 'guanyang', '0773', '541600', 'G', '111.15954', '25.48803'),
+(2202, 2189, '龙胜', '龙胜各族自治县', '中国,广西壮族自治区,桂林市,龙胜各族自治县', 3, 'longsheng', '0773', '541700', 'L', '110.01226', '25.79614'),
+(2203, 2189, '资源', '资源县', '中国,广西壮族自治区,桂林市,资源县', 3, 'ziyuan', '0773', '541400', 'Z', '110.65255', '26.04237'),
+(2204, 2189, '平乐', '平乐县', '中国,广西壮族自治区,桂林市,平乐县', 3, 'pingle', '0773', '542400', 'P', '110.64175', '24.63242'),
+(2205, 2189, '荔浦', '荔浦县', '中国,广西壮族自治区,桂林市,荔浦县', 3, 'lipu', '0773', '546600', 'L', '110.3971', '24.49589'),
+(2206, 2189, '恭城', '恭城瑶族自治县', '中国,广西壮族自治区,桂林市,恭城瑶族自治县', 3, 'gongcheng', '0773', '542500', 'G', '110.83035', '24.83286'),
+(2207, 2162, '梧州', '梧州市', '中国,广西壮族自治区,梧州市', 2, 'wuzhou', '0774', '543002', 'W', '111.316229', '23.472309'),
+(2208, 2207, '万秀', '万秀区', '中国,广西壮族自治区,梧州市,万秀区', 3, 'wanxiu', '0774', '543000', 'W', '111.32052', '23.47298'),
+(2209, 2207, '长洲', '长洲区', '中国,广西壮族自治区,梧州市,长洲区', 3, 'changzhou', '0774', '543003', 'C', '111.27494', '23.48573'),
+(2210, 2207, '龙圩', '龙圩区', '中国,广西壮族自治区,梧州市,龙圩区', 3, 'longxu', '0774', '543002', 'L', '111.316229', '23.472309'),
+(2211, 2207, '苍梧', '苍梧县', '中国,广西壮族自治区,梧州市,苍梧县', 3, 'cangwu', '0774', '543100', 'C', '111.24533', '23.42049'),
+(2212, 2207, '藤县', '藤县', '中国,广西壮族自治区,梧州市,藤县', 3, 'tengxian', '0774', '543300', 'T', '110.91418', '23.37605'),
+(2213, 2207, '蒙山', '蒙山县', '中国,广西壮族自治区,梧州市,蒙山县', 3, 'mengshan', '0774', '546700', 'M', '110.52221', '24.20168'),
+(2214, 2207, '岑溪', '岑溪市', '中国,广西壮族自治区,梧州市,岑溪市', 3, 'cenxi', '0774', '543200', NULL, '110.99594', '22.9191'),
+(2215, 2162, '北海', '北海市', '中国,广西壮族自治区,北海市', 2, 'beihai', '0779', '536000', 'B', '109.119254', '21.473343'),
+(2216, 2215, '海城', '海城区', '中国,广西壮族自治区,北海市,海城区', 3, 'haicheng', '0779', '536000', 'H', '109.11744', '21.47501'),
+(2217, 2215, '银海', '银海区', '中国,广西壮族自治区,北海市,银海区', 3, 'yinhai', '0779', '536000', 'Y', '109.13029', '21.4783'),
+(2218, 2215, '铁山港', '铁山港区', '中国,广西壮族自治区,北海市,铁山港区', 3, 'tieshangang', '0779', '536017', 'T', '109.45578', '21.59661'),
+(2219, 2215, '合浦', '合浦县', '中国,广西壮族自治区,北海市,合浦县', 3, 'hepu', '0779', '536100', 'H', '109.20068', '21.66601'),
+(2220, 2162, '防城港', '防城港市', '中国,广西壮族自治区,防城港市', 2, 'fangchenggang', '0770', '538001', 'F', '108.345478', '21.614631'),
+(2221, 2220, '港口', '港口区', '中国,广西壮族自治区,防城港市,港口区', 3, 'gangkou', '0770', '538001', 'G', '108.38022', '21.64342'),
+(2222, 2220, '防城', '防城区', '中国,广西壮族自治区,防城港市,防城区', 3, 'fangcheng', '0770', '538021', 'F', '108.35726', '21.76464'),
+(2223, 2220, '上思', '上思县', '中国,广西壮族自治区,防城港市,上思县', 3, 'shangsi', '0770', '535500', 'S', '107.9823', '22.14957'),
+(2224, 2220, '东兴', '东兴市', '中国,广西壮族自治区,防城港市,东兴市', 3, 'dongxing', '0770', '538100', 'D', '107.97204', '21.54713'),
+(2225, 2162, '钦州', '钦州市', '中国,广西壮族自治区,钦州市', 2, 'qinzhou', '0777', '535099', 'Q', '108.624175', '21.967127'),
+(2226, 2225, '钦南', '钦南区', '中国,广西壮族自治区,钦州市,钦南区', 3, 'qinnan', '0777', '535099', 'Q', '108.61775', '21.95137'),
+(2227, 2225, '钦北', '钦北区', '中国,广西壮族自治区,钦州市,钦北区', 3, 'qinbei', '0777', '535099', 'Q', '108.63037', '21.95127'),
+(2228, 2225, '灵山', '灵山县', '中国,广西壮族自治区,钦州市,灵山县', 3, 'lingshan', '0777', '535099', 'L', '109.29153', '22.4165'),
+(2229, 2225, '浦北', '浦北县', '中国,广西壮族自治区,钦州市,浦北县', 3, 'pubei', '0777', '535099', 'P', '109.55572', '22.26888'),
+(2230, 2162, '贵港', '贵港市', '中国,广西壮族自治区,贵港市', 2, 'guigang', '0775', '537100', 'G', '109.602146', '23.0936'),
+(2231, 2230, '港北', '港北区', '中国,广西壮族自治区,贵港市,港北区', 3, 'gangbei', '0775', '537100', 'G', '109.57224', '23.11153'),
+(2232, 2230, '港南', '港南区', '中国,广西壮族自治区,贵港市,港南区', 3, 'gangnan', '0775', '537100', 'G', '109.60617', '23.07226'),
+(2233, 2230, '覃塘', '覃塘区', '中国,广西壮族自治区,贵港市,覃塘区', 3, 'qintang', '0775', '537121', NULL, '109.44293', '23.12677'),
+(2234, 2230, '平南', '平南县', '中国,广西壮族自治区,贵港市,平南县', 3, 'pingnan', '0775', '537300', 'P', '110.39062', '23.54201'),
+(2235, 2230, '桂平', '桂平市', '中国,广西壮族自治区,贵港市,桂平市', 3, 'guiping', '0775', '537200', 'G', '110.08105', '23.39339'),
+(2236, 2162, '玉林', '玉林市', '中国,广西壮族自治区,玉林市', 2, 'yulin', '0775', '537000', 'Y', '110.154393', '22.63136'),
+(2237, 2236, '玉州', '玉州区', '中国,广西壮族自治区,玉林市,玉州区', 3, 'yuzhou', '0775', '537000', 'Y', '110.15114', '22.6281'),
+(2238, 2236, '福绵', '福绵区', '中国,广西壮族自治区,玉林市,福绵区', 3, 'fumian', '0775', '537023', 'F', '110.064816', '22.583057'),
+(2239, 2236, '玉东', '玉东新区', '中国,广西壮族自治区,玉林市,玉东新区', 3, 'yudong', '0775', '537000', 'Y', '110.154393', '22.63136'),
+(2240, 2236, '容县', '容县', '中国,广西壮族自治区,玉林市,容县', 3, 'rongxian', '0775', '537500', 'R', '110.55593', '22.85701'),
+(2241, 2236, '陆川', '陆川县', '中国,广西壮族自治区,玉林市,陆川县', 3, 'luchuan', '0775', '537700', 'L', '110.26413', '22.32454'),
+(2242, 2236, '博白', '博白县', '中国,广西壮族自治区,玉林市,博白县', 3, 'bobai', '0775', '537600', 'B', '109.97744', '22.27286'),
+(2243, 2236, '兴业', '兴业县', '中国,广西壮族自治区,玉林市,兴业县', 3, 'xingye', '0775', '537800', 'X', '109.87612', '22.74237'),
+(2244, 2236, '北流', '北流市', '中国,广西壮族自治区,玉林市,北流市', 3, 'beiliu', '0775', '537400', 'B', '110.35302', '22.70817'),
+(2245, 2162, '百色', '百色市', '中国,广西壮族自治区,百色市', 2, 'baise', '0776', '533000', 'B', '106.616285', '23.897742'),
+(2246, 2245, '右江', '右江区', '中国,广西壮族自治区,百色市,右江区', 3, 'youjiang', '0776', '533000', 'Y', '106.61764', '23.9009'),
+(2247, 2245, '田阳', '田阳县', '中国,广西壮族自治区,百色市,田阳县', 3, 'tianyang', '0776', '533600', 'T', '106.91558', '23.73535'),
+(2248, 2245, '田东', '田东县', '中国,广西壮族自治区,百色市,田东县', 3, 'tiandong', '0776', '531500', 'T', '107.12432', '23.60003'),
+(2249, 2245, '平果', '平果县', '中国,广西壮族自治区,百色市,平果县', 3, 'pingguo', '0776', '531400', 'P', '107.59045', '23.32969'),
+(2250, 2245, '德保', '德保县', '中国,广西壮族自治区,百色市,德保县', 3, 'debao', '0776', '533700', 'D', '106.61917', '23.32515'),
+(2251, 2245, '靖西', '靖西县', '中国,广西壮族自治区,百色市,靖西县', 3, 'jingxi', '0776', '533800', 'J', '106.41766', '23.13425'),
+(2252, 2245, '那坡', '那坡县', '中国,广西壮族自治区,百色市,那坡县', 3, 'napo', '0776', '533900', 'N', '105.84191', '23.40649'),
+(2253, 2245, '凌云', '凌云县', '中国,广西壮族自治区,百色市,凌云县', 3, 'lingyun', '0776', '533100', 'L', '106.56155', '24.34747'),
+(2254, 2245, '乐业', '乐业县', '中国,广西壮族自治区,百色市,乐业县', 3, 'leye', '0776', '533200', 'L', '106.56124', '24.78295'),
+(2255, 2245, '田林', '田林县', '中国,广西壮族自治区,百色市,田林县', 3, 'tianlin', '0776', '533300', 'T', '106.22882', '24.29207'),
+(2256, 2245, '西林', '西林县', '中国,广西壮族自治区,百色市,西林县', 3, 'xilin', '0776', '533500', 'X', '105.09722', '24.48966'),
+(2257, 2245, '隆林', '隆林各族自治县', '中国,广西壮族自治区,百色市,隆林各族自治县', 3, 'longlin', '0776', '533400', 'L', '105.34295', '24.77036'),
+(2258, 2162, '贺州', '贺州市', '中国,广西壮族自治区,贺州市', 2, 'hezhou', '0774', '542800', 'H', '111.552056', '24.414141'),
+(2259, 2258, '八步', '八步区', '中国,广西壮族自治区,贺州市,八步区', 3, 'babu', '0774', '542800', 'B', '111.55225', '24.41179'),
+(2260, 2258, '昭平', '昭平县', '中国,广西壮族自治区,贺州市,昭平县', 3, 'zhaoping', '0774', '546800', 'Z', '110.81082', '24.1701'),
+(2261, 2258, '钟山', '钟山县', '中国,广西壮族自治区,贺州市,钟山县', 3, 'zhongshan', '0774', '542600', 'Z', '111.30459', '24.52482'),
+(2262, 2258, '富川', '富川瑶族自治县', '中国,广西壮族自治区,贺州市,富川瑶族自治县', 3, 'fuchuan', '0774', '542700', 'F', '111.27767', '24.81431'),
+(2263, 2258, '平桂', '平桂管理区', '中国,广西壮族自治区,贺州市,平桂管理区', 3, 'pingui', '0774', '542800', 'P', '111.485651', '24.458041'),
+(2264, 2162, '河池', '河池市', '中国,广西壮族自治区,河池市', 2, 'hechi', '0778', '547000', 'H', '108.062105', '24.695899'),
+(2265, 2264, '金城江', '金城江区', '中国,广西壮族自治区,河池市,金城江区', 3, 'jinchengjiang', '0779', '547000', 'J', '108.03727', '24.6897'),
+(2266, 2264, '南丹', '南丹县', '中国,广西壮族自治区,河池市,南丹县', 3, 'nandan', '0781', '547200', 'N', '107.54562', '24.9776'),
+(2267, 2264, '天峨', '天峨县', '中国,广西壮族自治区,河池市,天峨县', 3, 'tiane', '0782', '547300', 'T', '107.17205', '24.99593'),
+(2268, 2264, '凤山', '凤山县', '中国,广西壮族自治区,河池市,凤山县', 3, 'fengshan', '0783', '547600', 'F', '107.04892', '24.54215'),
+(2269, 2264, '东兰', '东兰县', '中国,广西壮族自治区,河池市,东兰县', 3, 'donglan', '0784', '547400', 'D', '107.37527', '24.51053'),
+(2270, 2264, '罗城', '罗城仫佬族自治县', '中国,广西壮族自治区,河池市,罗城仫佬族自治县', 3, 'luocheng', '0785', '546400', 'L', '108.90777', '24.77923'),
+(2271, 2264, '环江', '环江毛南族自治县', '中国,广西壮族自治区,河池市,环江毛南族自治县', 3, 'huanjiang', '0786', '547100', 'H', '108.26055', '24.82916'),
+(2272, 2264, '巴马', '巴马瑶族自治县', '中国,广西壮族自治区,河池市,巴马瑶族自治县', 3, 'bama', '0787', '547500', 'B', '107.25308', '24.14135'),
+(2273, 2264, '都安', '都安瑶族自治县', '中国,广西壮族自治区,河池市,都安瑶族自治县', 3, 'du''an', '0788', '530700', 'D', '108.10116', '23.93245'),
+(2274, 2264, '大化', '大化瑶族自治县', '中国,广西壮族自治区,河池市,大化瑶族自治县', 3, 'dahua', '0789', '530800', 'D', '107.9985', '23.74487'),
+(2275, 2264, '宜州', '宜州市', '中国,广西壮族自治区,河池市,宜州市', 3, 'yizhou', '0780', '546300', 'Y', '108.65304', '24.49391'),
+(2276, 2162, '来宾', '来宾市', '中国,广西壮族自治区,来宾市', 2, 'laibin', '0772', '546100', 'L', '109.229772', '23.733766'),
+(2277, 2276, '兴宾', '兴宾区', '中国,广西壮族自治区,来宾市,兴宾区', 3, 'xingbin', '0772', '546100', 'X', '109.23471', '23.72731'),
+(2278, 2276, '忻城', '忻城县', '中国,广西壮族自治区,来宾市,忻城县', 3, 'xincheng', '0772', '546200', 'X', '108.66357', '24.06862'),
+(2279, 2276, '象州', '象州县', '中国,广西壮族自治区,来宾市,象州县', 3, 'xiangzhou', '0772', '545800', 'X', '109.6994', '23.97355'),
+(2280, 2276, '武宣', '武宣县', '中国,广西壮族自治区,来宾市,武宣县', 3, 'wuxuan', '0772', '545900', 'W', '109.66284', '23.59474'),
+(2281, 2276, '金秀', '金秀瑶族自治县', '中国,广西壮族自治区,来宾市,金秀瑶族自治县', 3, 'jinxiu', '0772', '545799', 'J', '110.19079', '24.12929'),
+(2282, 2276, '合山', '合山市', '中国,广西壮族自治区,来宾市,合山市', 3, 'heshan', '0772', '546500', 'H', '108.88586', '23.80619'),
+(2283, 2162, '崇左', '崇左市', '中国,广西壮族自治区,崇左市', 2, 'chongzuo', '0771', '532299', 'C', '107.353926', '22.404108'),
+(2284, 2283, '江州', '江州区', '中国,广西壮族自治区,崇左市,江州区', 3, 'jiangzhou', '0771', '532299', 'J', '107.34747', '22.41135'),
+(2285, 2283, '扶绥', '扶绥县', '中国,广西壮族自治区,崇左市,扶绥县', 3, 'fusui', '0771', '532199', 'F', '107.90405', '22.63413'),
+(2286, 2283, '宁明', '宁明县', '中国,广西壮族自治区,崇左市,宁明县', 3, 'ningming', '0771', '532599', 'N', '107.07299', '22.13655'),
+(2287, 2283, '龙州', '龙州县', '中国,广西壮族自治区,崇左市,龙州县', 3, 'longzhou', '0771', '532499', 'L', '106.85415', '22.33937'),
+(2288, 2283, '大新', '大新县', '中国,广西壮族自治区,崇左市,大新县', 3, 'daxin', '0771', '532399', 'D', '107.19821', '22.83412'),
+(2289, 2283, '天等', '天等县', '中国,广西壮族自治区,崇左市,天等县', 3, 'tiandeng', '0771', '532899', 'T', '107.13998', '23.077'),
+(2290, 2283, '凭祥', '凭祥市', '中国,广西壮族自治区,崇左市,凭祥市', 3, 'pingxiang', '0771', '532699', 'P', '106.75534', '22.10573'),
+(2291, 0, '海南', '海南省', '中国,海南省', 1, 'hainan', '', '', 'H', '110.33119', '20.031971'),
+(2292, 2291, '海口', '海口市', '中国,海南省,海口市', 2, 'haikou', '0898', '570000', 'H', '110.33119', '20.031971'),
+(2293, 2292, '秀英', '秀英区', '中国,海南省,海口市,秀英区', 3, 'xiuying', '0898', '570311', 'X', '110.29345', '20.00752'),
+(2294, 2292, '龙华', '龙华区', '中国,海南省,海口市,龙华区', 3, 'longhua', '0898', '570145', 'L', '110.30194', '20.02866'),
+(2295, 2292, '琼山', '琼山区', '中国,海南省,海口市,琼山区', 3, 'qiongshan', '0898', '571100', 'Q', '110.35418', '20.00321'),
+(2296, 2292, '美兰', '美兰区', '中国,海南省,海口市,美兰区', 3, 'meilan', '0898', '570203', 'M', '110.36908', '20.02864'),
+(2297, 2291, '三亚', '三亚市', '中国,海南省,三亚市', 2, 'sanya', '0898', '572000', 'S', '109.508268', '18.247872'),
+(2298, 2297, '海棠', '海棠区', '中国,海南省,三亚市,海棠区', 3, 'haitang', '0898', '572000', 'H', '109.508268', '18.247872'),
+(2299, 2297, '吉阳', '吉阳区', '中国,海南省,三亚市,吉阳区', 3, 'jiyang', '0898', '572000', 'J', '109.508268', '18.247872'),
+(2300, 2297, '天涯', '天涯区', '中国,海南省,三亚市,天涯区', 3, 'tianya', '0898', '572000', 'T', '109.508268', '18.247872'),
+(2301, 2297, '崖州', '崖州区', '中国,海南省,三亚市,崖州区', 3, 'yazhou', '0898', '572000', 'Y', '109.508268', '18.247872'),
+(2302, 2291, '三沙', '三沙市', '中国,海南省,三沙市', 2, 'sansha', '0898', '573199', 'S', '112.34882', '16.831039'),
+(2303, 2302, '西沙', '西沙群岛', '中国,海南省,三沙市,西沙群岛', 3, 'xishaislands', '0898', '572000', 'X', '112.025528', '16.331342'),
+(2304, 2302, '南沙', '南沙群岛', '中国,海南省,三沙市,南沙群岛', 3, 'nanshaislands', '0898', '573100', 'N', '116.749998', '11.471888'),
+(2305, 2302, '中沙', '中沙群岛', '中国,海南省,三沙市,中沙群岛', 3, 'zhongshaislands', '0898', '573100', 'Z', '117.740071', '15.112856'),
+(2306, 2291, ' ', '直辖县级', '中国,海南省,直辖县级', 2, '', '', '', 'Z', '109.503479', '18.739906'),
+(2307, 2306, '五指山', '五指山市', '中国,海南省,直辖县级,五指山市', 3, 'wuzhishan', '0898', '572200', 'W', '109.516662', '18.776921'),
+(2308, 2306, '琼海', '琼海市', '中国,海南省,直辖县级,琼海市', 3, 'qionghai', '0898', '571400', 'Q', '110.466785', '19.246011'),
+(2309, 2306, '儋州', '儋州市', '中国,海南省,直辖县级,儋州市', 3, 'danzhou', '0898', '571700', NULL, '109.576782', '19.517486'),
+(2310, 2306, '文昌', '文昌市', '中国,海南省,直辖县级,文昌市', 3, 'wenchang', '0898', '571339', 'W', '110.753975', '19.612986'),
+(2311, 2306, '万宁', '万宁市', '中国,海南省,直辖县级,万宁市', 3, 'wanning', '0898', '571500', 'W', '110.388793', '18.796216'),
+(2312, 2306, '东方', '东方市', '中国,海南省,直辖县级,东方市', 3, 'dongfang', '0898', '572600', 'D', '108.653789', '19.10198'),
+(2313, 2306, '定安', '定安县', '中国,海南省,直辖县级,定安县', 3, 'ding''an', '0898', '571200', 'D', '110.323959', '19.699211'),
+(2314, 2306, '屯昌', '屯昌县', '中国,海南省,直辖县级,屯昌县', 3, 'tunchang', '0898', '571600', 'T', '110.102773', '19.362916'),
+(2315, 2306, '澄迈', '澄迈县', '中国,海南省,直辖县级,澄迈县', 3, 'chengmai', '0898', '571900', 'C', '110.007147', '19.737095'),
+(2316, 2306, '临高', '临高县', '中国,海南省,直辖县级,临高县', 3, 'lingao', '0898', '571800', 'L', '109.687697', '19.908293'),
+(2317, 2306, '白沙', '白沙黎族自治县', '中国,海南省,直辖县级,白沙黎族自治县', 3, 'baisha', '0898', '572800', 'B', '109.452606', '19.224584'),
+(2318, 2306, '昌江', '昌江黎族自治县', '中国,海南省,直辖县级,昌江黎族自治县', 3, 'changjiang', '0898', '572700', 'C', '109.053351', '19.260968'),
+(2319, 2306, '乐东', '乐东黎族自治县', '中国,海南省,直辖县级,乐东黎族自治县', 3, 'ledong', '0898', '572500', 'L', '109.175444', '18.74758'),
+(2320, 2306, '陵水', '陵水黎族自治县', '中国,海南省,直辖县级,陵水黎族自治县', 3, 'lingshui', '0898', '572400', 'L', '110.037218', '18.505006'),
+(2321, 2306, '保亭', '保亭黎族苗族自治县', '中国,海南省,直辖县级,保亭黎族苗族自治县', 3, 'baoting', '0898', '572300', 'B', '109.70245', '18.636371'),
+(2322, 2306, '琼中', '琼中黎族苗族自治县', '中国,海南省,直辖县级,琼中黎族苗族自治县', 3, 'qiongzhong', '0898', '572900', 'Q', '109.839996', '19.03557'),
+(2323, 0, '重庆', '重庆', '中国,重庆', 1, 'chongqing', '', '', 'Z', '106.504962', '29.533155'),
+(2324, 2323, '重庆', '重庆市', '中国,重庆,重庆市', 2, 'chongqing', '023', '400000', 'Z', '106.504962', '29.533155'),
+(2325, 2324, '万州', '万州区', '中国,重庆,重庆市,万州区', 3, 'wanzhou', '023', '404000', 'W', '108.40869', '30.80788'),
+(2326, 2324, '涪陵', '涪陵区', '中国,重庆,重庆市,涪陵区', 3, 'fuling', '023', '408000', 'F', '107.39007', '29.70292'),
+(2327, 2324, '渝中', '渝中区', '中国,重庆,重庆市,渝中区', 3, 'yuzhong', '023', '400010', 'Y', '106.56901', '29.55279'),
+(2328, 2324, '大渡口', '大渡口区', '中国,重庆,重庆市,大渡口区', 3, 'dadukou', '023', '400080', 'D', '106.48262', '29.48447'),
+(2329, 2324, '江北', '江北区', '中国,重庆,重庆市,江北区', 3, 'jiangbei', '023', '400020', 'J', '106.57434', '29.60658'),
+(2330, 2324, '沙坪坝', '沙坪坝区', '中国,重庆,重庆市,沙坪坝区', 3, 'shapingba', '023', '400030', 'S', '106.45752', '29.54113'),
+(2331, 2324, '九龙坡', '九龙坡区', '中国,重庆,重庆市,九龙坡区', 3, 'jiulongpo', '023', '400050', 'J', '106.51107', '29.50197'),
+(2332, 2324, '南岸', '南岸区', '中国,重庆,重庆市,南岸区', 3, 'nan''an', '023', '400064', 'N', '106.56347', '29.52311'),
+(2333, 2324, '北碚', '北碚区', '中国,重庆,重庆市,北碚区', 3, 'beibei', '023', '400700', 'B', '106.39614', '29.80574'),
+(2334, 2324, '綦江', '綦江区', '中国,重庆,重庆市,綦江区', 3, 'qijiang', '023', '400800', NULL, '106.926779', '28.960656'),
+(2335, 2324, '大足', '大足区', '中国,重庆,重庆市,大足区', 3, 'dazu', '023', '400900', 'D', '105.768121', '29.484025'),
+(2336, 2324, '渝北', '渝北区', '中国,重庆,重庆市,渝北区', 3, 'yubei', '023', '401120', 'Y', '106.6307', '29.7182'),
+(2337, 2324, '巴南', '巴南区', '中国,重庆,重庆市,巴南区', 3, 'banan', '023', '401320', 'B', '106.52365', '29.38311'),
+(2338, 2324, '黔江', '黔江区', '中国,重庆,重庆市,黔江区', 3, 'qianjiang', '023', '409700', 'Q', '108.7709', '29.5332'),
+(2339, 2324, '长寿', '长寿区', '中国,重庆,重庆市,长寿区', 3, 'changshou', '023', '401220', 'C', '107.08166', '29.85359'),
+(2340, 2324, '江津', '江津区', '中国,重庆,重庆市,江津区', 3, 'jiangjin', '023', '402260', 'J', '106.25912', '29.29008'),
+(2341, 2324, '合川', '合川区', '中国,重庆,重庆市,合川区', 3, 'hechuan', '023', '401520', 'H', '106.27633', '29.97227'),
+(2342, 2324, '永川', '永川区', '中国,重庆,重庆市,永川区', 3, 'yongchuan', '023', '402160', 'Y', '105.927', '29.35593'),
+(2343, 2324, '南川', '南川区', '中国,重庆,重庆市,南川区', 3, 'nanchuan', '023', '408400', 'N', '107.09936', '29.15751'),
+(2344, 2324, '璧山', '璧山区', '中国,重庆,重庆市,璧山区', 3, 'bishan', '023', '402760', NULL, '106.231126', '29.593581'),
+(2345, 2324, '铜梁', '铜梁区', '中国,重庆,重庆市,铜梁区', 3, 'tongliang', '023', '402560', 'T', '106.054948', '29.839944'),
+(2346, 2324, '潼南', '潼南县', '中国,重庆,重庆市,潼南县', 3, 'tongnan', '023', '402660', NULL, '105.84005', '30.1912'),
+(2347, 2324, '荣昌', '荣昌县', '中国,重庆,重庆市,荣昌县', 3, 'rongchang', '023', '402460', 'R', '105.59442', '29.40488'),
+(2348, 2324, '梁平', '梁平县', '中国,重庆,重庆市,梁平县', 3, 'liangping', '023', '405200', 'L', '107.79998', '30.67545'),
+(2349, 2324, '城口', '城口县', '中国,重庆,重庆市,城口县', 3, 'chengkou', '023', '405900', 'C', '108.66513', '31.94801'),
+(2350, 2324, '丰都', '丰都县', '中国,重庆,重庆市,丰都县', 3, 'fengdu', '023', '408200', 'F', '107.73098', '29.86348'),
+(2351, 2324, '垫江', '垫江县', '中国,重庆,重庆市,垫江县', 3, 'dianjiang', '023', '408300', 'D', '107.35446', '30.33359'),
+(2352, 2324, '武隆', '武隆县', '中国,重庆,重庆市,武隆县', 3, 'wulong', '023', '408500', 'W', '107.7601', '29.32548'),
+(2353, 2324, '忠县', '忠县', '中国,重庆,重庆市,忠县', 3, 'zhongxian', '023', '404300', 'Z', '108.03689', '30.28898'),
+(2354, 2324, '开县', '开县', '中国,重庆,重庆市,开县', 3, 'kaixian', '023', '405400', 'K', '108.39306', '31.16095'),
+(2355, 2324, '云阳', '云阳县', '中国,重庆,重庆市,云阳县', 3, 'yunyang', '023', '404500', 'Y', '108.69726', '30.93062'),
+(2356, 2324, '奉节', '奉节县', '中国,重庆,重庆市,奉节县', 3, 'fengjie', '023', '404600', 'F', '109.46478', '31.01825'),
+(2357, 2324, '巫山', '巫山县', '中国,重庆,重庆市,巫山县', 3, 'wushan', '023', '404700', 'W', '109.87814', '31.07458'),
+(2358, 2324, '巫溪', '巫溪县', '中国,重庆,重庆市,巫溪县', 3, 'wuxi', '023', '405800', 'W', '109.63128', '31.39756'),
+(2359, 2324, '石柱', '石柱土家族自治县', '中国,重庆,重庆市,石柱土家族自治县', 3, 'shizhu', '023', '409100', 'S', '108.11389', '30.00054'),
+(2360, 2324, '秀山', '秀山土家族苗族自治县', '中国,重庆,重庆市,秀山土家族苗族自治县', 3, 'xiushan', '023', '409900', 'X', '108.98861', '28.45062'),
+(2361, 2324, '酉阳', '酉阳土家族苗族自治县', '中国,重庆,重庆市,酉阳土家族苗族自治县', 3, 'youyang', '023', '409800', 'Y', '108.77212', '28.8446'),
+(2362, 2324, '彭水', '彭水苗族土家族自治县', '中国,重庆,重庆市,彭水苗族土家族自治县', 3, 'pengshui', '023', '409600', 'P', '108.16638', '29.29516'),
+(2363, 2323, '两江新区', '两江新区', '中国,重庆,两江新区', 2, 'liangjiangxinqu', '023', '400000', 'L', '106.463344', '29.729153'),
+(2364, 2363, '北部新区', '北部新区', '中国,重庆,两江新区,北部新区', 3, 'beibuxinqu', '023', '400000', 'B', '106.488841', '29.667062'),
+(2365, 2363, '保税港区', '保税港区', '中国,重庆,两江新区,保税港区', 3, 'baoshuigangqu', '023', '400000', 'B', '106.638184', '29.716311'),
+(2366, 2363, '工业园区', '工业园区', '中国,重庆,两江新区,工业园区', 3, 'gongyeyuanqu', '023', '400000', 'G', '106.626434', '29.55554'),
+(2367, 0, '四川', '四川省', '中国,四川省', 1, 'sichuan', '', '', 'S', '104.065735', '30.659462'),
+(2368, 2367, '成都', '成都市', '中国,四川省,成都市', 2, 'chengdu', '028', '610015', 'C', '104.065735', '30.659462'),
+(2369, 2368, '锦江', '锦江区', '中国,四川省,成都市,锦江区', 3, 'jinjiang', '028', '610021', 'J', '104.08347', '30.65614'),
+(2370, 2368, '青羊', '青羊区', '中国,四川省,成都市,青羊区', 3, 'qingyang', '028', '610031', 'Q', '104.06151', '30.67387'),
+(2371, 2368, '金牛', '金牛区', '中国,四川省,成都市,金牛区', 3, 'jinniu', '028', '610036', 'J', '104.05114', '30.69126'),
+(2372, 2368, '武侯', '武侯区', '中国,四川省,成都市,武侯区', 3, 'wuhou', '028', '610041', 'W', '104.04303', '30.64235'),
+(2373, 2368, '成华', '成华区', '中国,四川省,成都市,成华区', 3, 'chenghua', '028', '610066', 'C', '104.10193', '30.65993'),
+(2374, 2368, '龙泉驿', '龙泉驿区', '中国,四川省,成都市,龙泉驿区', 3, 'longquanyi', '028', '610100', 'L', '104.27462', '30.55658'),
+(2375, 2368, '青白江', '青白江区', '中国,四川省,成都市,青白江区', 3, 'qingbaijiang', '028', '610300', 'Q', '104.251', '30.87841'),
+(2376, 2368, '新都', '新都区', '中国,四川省,成都市,新都区', 3, 'xindu', '028', '610500', 'X', '104.15921', '30.82314');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(2377, 2368, '温江', '温江区', '中国,四川省,成都市,温江区', 3, 'wenjiang', '028', '611130', 'W', '103.84881', '30.68444'),
+(2378, 2368, '金堂', '金堂县', '中国,四川省,成都市,金堂县', 3, 'jintang', '028', '610400', 'J', '104.41195', '30.86195'),
+(2379, 2368, '双流', '双流县', '中国,四川省,成都市,双流县', 3, 'shuangliu', '028', '610200', 'S', '103.92373', '30.57444'),
+(2380, 2368, '郫县', '郫县', '中国,四川省,成都市,郫县', 3, 'pixian', '028', '611730', NULL, '103.88717', '30.81054'),
+(2381, 2368, '大邑', '大邑县', '中国,四川省,成都市,大邑县', 3, 'dayi', '028', '611330', 'D', '103.52075', '30.58738'),
+(2382, 2368, '蒲江', '蒲江县', '中国,四川省,成都市,蒲江县', 3, 'pujiang', '028', '611630', 'P', '103.50616', '30.19667'),
+(2383, 2368, '新津', '新津县', '中国,四川省,成都市,新津县', 3, 'xinjin', '028', '611430', 'X', '103.8114', '30.40983'),
+(2384, 2368, '都江堰', '都江堰市', '中国,四川省,成都市,都江堰市', 3, 'dujiangyan', '028', '611830', 'D', '103.61941', '30.99825'),
+(2385, 2368, '彭州', '彭州市', '中国,四川省,成都市,彭州市', 3, 'pengzhou', '028', '611930', 'P', '103.958', '30.99011'),
+(2386, 2368, '邛崃', '邛崃市', '中国,四川省,成都市,邛崃市', 3, 'qionglai', '028', '611530', NULL, '103.46283', '30.41489'),
+(2387, 2368, '崇州', '崇州市', '中国,四川省,成都市,崇州市', 3, 'chongzhou', '028', '611230', 'C', '103.67285', '30.63014'),
+(2388, 2367, '自贡', '自贡市', '中国,四川省,自贡市', 2, 'zigong', '0813', '643000', 'Z', '104.773447', '29.352765'),
+(2389, 2388, '自流井', '自流井区', '中国,四川省,自贡市,自流井区', 3, 'ziliujing', '0813', '643000', 'Z', '104.77719', '29.33745'),
+(2390, 2388, '贡井', '贡井区', '中国,四川省,自贡市,贡井区', 3, 'gongjing', '0813', '643020', 'G', '104.71536', '29.34576'),
+(2391, 2388, '大安', '大安区', '中国,四川省,自贡市,大安区', 3, 'da''an', '0813', '643010', 'D', '104.77383', '29.36364'),
+(2392, 2388, '沿滩', '沿滩区', '中国,四川省,自贡市,沿滩区', 3, 'yantan', '0813', '643030', 'Y', '104.88012', '29.26611'),
+(2393, 2388, '荣县', '荣县', '中国,四川省,自贡市,荣县', 3, 'rongxian', '0813', '643100', 'R', '104.4176', '29.44445'),
+(2394, 2388, '富顺', '富顺县', '中国,四川省,自贡市,富顺县', 3, 'fushun', '0813', '643200', 'F', '104.97491', '29.18123'),
+(2395, 2367, '攀枝花', '攀枝花市', '中国,四川省,攀枝花市', 2, 'panzhihua', '0812', '617000', 'P', '101.716007', '26.580446'),
+(2396, 2395, '东区', '东区', '中国,四川省,攀枝花市,东区', 3, 'dongqu', '0812', '617067', 'D', '101.7052', '26.54677'),
+(2397, 2395, '西区', '西区', '中国,四川省,攀枝花市,西区', 3, 'xiqu', '0812', '617068', 'X', '101.63058', '26.59753'),
+(2398, 2395, '仁和', '仁和区', '中国,四川省,攀枝花市,仁和区', 3, 'renhe', '0812', '617061', 'R', '101.73812', '26.49841'),
+(2399, 2395, '米易', '米易县', '中国,四川省,攀枝花市,米易县', 3, 'miyi', '0812', '617200', 'M', '102.11132', '26.88718'),
+(2400, 2395, '盐边', '盐边县', '中国,四川省,攀枝花市,盐边县', 3, 'yanbian', '0812', '617100', 'Y', '101.85446', '26.68847'),
+(2401, 2367, '泸州', '泸州市', '中国,四川省,泸州市', 2, 'luzhou', '0830', '646000', NULL, '105.443348', '28.889138'),
+(2402, 2401, '江阳', '江阳区', '中国,四川省,泸州市,江阳区', 3, 'jiangyang', '0830', '646000', 'J', '105.45336', '28.88934'),
+(2403, 2401, '纳溪', '纳溪区', '中国,四川省,泸州市,纳溪区', 3, 'naxi', '0830', '646300', 'N', '105.37255', '28.77343'),
+(2404, 2401, '龙马潭', '龙马潭区', '中国,四川省,泸州市,龙马潭区', 3, 'longmatan', '0830', '646000', 'L', '105.43774', '28.91308'),
+(2405, 2401, '泸县', '泸县', '中国,四川省,泸州市,泸县', 3, 'luxian', '0830', '646106', NULL, '105.38192', '29.15041'),
+(2406, 2401, '合江', '合江县', '中国,四川省,泸州市,合江县', 3, 'hejiang', '0830', '646200', 'H', '105.8352', '28.81005'),
+(2407, 2401, '叙永', '叙永县', '中国,四川省,泸州市,叙永县', 3, 'xuyong', '0830', '646400', 'X', '105.44473', '28.15586'),
+(2408, 2401, '古蔺', '古蔺县', '中国,四川省,泸州市,古蔺县', 3, 'gulin', '0830', '646500', 'G', '105.81347', '28.03867'),
+(2409, 2367, '德阳', '德阳市', '中国,四川省,德阳市', 2, 'deyang', '0838', '618000', 'D', '104.398651', '31.127991'),
+(2410, 2409, '旌阳', '旌阳区', '中国,四川省,德阳市,旌阳区', 3, 'jingyang', '0838', '618000', NULL, '104.39367', '31.13906'),
+(2411, 2409, '中江', '中江县', '中国,四川省,德阳市,中江县', 3, 'zhongjiang', '0838', '618100', 'Z', '104.67861', '31.03297'),
+(2412, 2409, '罗江', '罗江县', '中国,四川省,德阳市,罗江县', 3, 'luojiang', '0838', '618500', 'L', '104.51025', '31.31665'),
+(2413, 2409, '广汉', '广汉市', '中国,四川省,德阳市,广汉市', 3, 'guanghan', '0838', '618300', 'G', '104.28234', '30.97686'),
+(2414, 2409, '什邡', '什邡市', '中国,四川省,德阳市,什邡市', 3, 'shifang', '0838', '618400', 'S', '104.16754', '31.1264'),
+(2415, 2409, '绵竹', '绵竹市', '中国,四川省,德阳市,绵竹市', 3, 'mianzhu', '0838', '618200', 'M', '104.22076', '31.33772'),
+(2416, 2367, '绵阳', '绵阳市', '中国,四川省,绵阳市', 2, 'mianyang', '0816', '621000', 'M', '104.741722', '31.46402'),
+(2417, 2416, '涪城', '涪城区', '中国,四川省,绵阳市,涪城区', 3, 'fucheng', '0816', '621000', 'F', '104.75719', '31.45522'),
+(2418, 2416, '游仙', '游仙区', '中国,四川省,绵阳市,游仙区', 3, 'youxian', '0816', '621022', 'Y', '104.77092', '31.46574'),
+(2419, 2416, '三台', '三台县', '中国,四川省,绵阳市,三台县', 3, 'santai', '0816', '621100', 'S', '105.09079', '31.09179'),
+(2420, 2416, '盐亭', '盐亭县', '中国,四川省,绵阳市,盐亭县', 3, 'yanting', '0816', '621600', 'Y', '105.3898', '31.22176'),
+(2421, 2416, '安县', '安县', '中国,四川省,绵阳市,安县', 3, 'anxian', '0816', '622650', 'A', '104.56738', '31.53487'),
+(2422, 2416, '梓潼', '梓潼县', '中国,四川省,绵阳市,梓潼县', 3, 'zitong', '0816', '622150', NULL, '105.16183', '31.6359'),
+(2423, 2416, '北川', '北川羌族自治县', '中国,四川省,绵阳市,北川羌族自治县', 3, 'beichuan', '0816', '622750', 'B', '104.46408', '31.83286'),
+(2424, 2416, '平武', '平武县', '中国,四川省,绵阳市,平武县', 3, 'pingwu', '0816', '622550', 'P', '104.52862', '32.40791'),
+(2425, 2416, '江油', '江油市', '中国,四川省,绵阳市,江油市', 3, 'jiangyou', '0816', '621700', 'J', '104.74539', '31.77775'),
+(2426, 2367, '广元', '广元市', '中国,四川省,广元市', 2, 'guangyuan', '0839', '628000', 'G', '105.829757', '32.433668'),
+(2427, 2426, '利州', '利州区', '中国,四川省,广元市,利州区', 3, 'lizhou', '0839', '628017', 'L', '105.826194', '32.432276'),
+(2428, 2426, '昭化', '昭化区', '中国,四川省,广元市,昭化区', 3, 'zhaohua', '0839', '628017', 'Z', '105.640491', '32.386518'),
+(2429, 2426, '朝天', '朝天区', '中国,四川省,广元市,朝天区', 3, 'chaotian', '0839', '628017', 'C', '105.89273', '32.64398'),
+(2430, 2426, '旺苍', '旺苍县', '中国,四川省,广元市,旺苍县', 3, 'wangcang', '0839', '628200', 'W', '106.29022', '32.22845'),
+(2431, 2426, '青川', '青川县', '中国,四川省,广元市,青川县', 3, 'qingchuan', '0839', '628100', 'Q', '105.2391', '32.58563'),
+(2432, 2426, '剑阁', '剑阁县', '中国,四川省,广元市,剑阁县', 3, 'jiange', '0839', '628300', 'J', '105.5252', '32.28845'),
+(2433, 2426, '苍溪', '苍溪县', '中国,四川省,广元市,苍溪县', 3, 'cangxi', '0839', '628400', 'C', '105.936', '31.73209'),
+(2434, 2367, '遂宁', '遂宁市', '中国,四川省,遂宁市', 2, 'suining', '0825', '629000', 'S', '105.571331', '30.513311'),
+(2435, 2434, '船山', '船山区', '中国,四川省,遂宁市,船山区', 3, 'chuanshan', '0825', '629000', 'C', '105.5809', '30.49991'),
+(2436, 2434, '安居', '安居区', '中国,四川省,遂宁市,安居区', 3, 'anju', '0825', '629000', 'A', '105.46402', '30.35778'),
+(2437, 2434, '蓬溪', '蓬溪县', '中国,四川省,遂宁市,蓬溪县', 3, 'pengxi', '0825', '629100', 'P', '105.70752', '30.75775'),
+(2438, 2434, '射洪', '射洪县', '中国,四川省,遂宁市,射洪县', 3, 'shehong', '0825', '629200', 'S', '105.38922', '30.87203'),
+(2439, 2434, '大英', '大英县', '中国,四川省,遂宁市,大英县', 3, 'daying', '0825', '629300', 'D', '105.24346', '30.59434'),
+(2440, 2367, '内江', '内江市', '中国,四川省,内江市', 2, 'neijiang', '0832', '641000', 'N', '105.066138', '29.58708'),
+(2441, 2440, '市中区', '市中区', '中国,四川省,内江市,市中区', 3, 'shizhongqu', '0832', '641000', 'S', '105.0679', '29.58709'),
+(2442, 2440, '东兴', '东兴区', '中国,四川省,内江市,东兴区', 3, 'dongxing', '0832', '641100', 'D', '105.07554', '29.59278'),
+(2443, 2440, '威远', '威远县', '中国,四川省,内江市,威远县', 3, 'weiyuan', '0832', '642450', 'W', '104.66955', '29.52823'),
+(2444, 2440, '资中', '资中县', '中国,四川省,内江市,资中县', 3, 'zizhong', '0832', '641200', 'Z', '104.85205', '29.76409'),
+(2445, 2440, '隆昌', '隆昌县', '中国,四川省,内江市,隆昌县', 3, 'longchang', '0832', '642150', 'L', '105.28738', '29.33937'),
+(2446, 2367, '乐山', '乐山市', '中国,四川省,乐山市', 2, 'leshan', '0833', '614000', 'L', '103.761263', '29.582024'),
+(2447, 2446, '市中区', '市中区', '中国,四川省,乐山市,市中区', 3, 'shizhongqu', '0833', '614000', 'S', '103.76159', '29.55543'),
+(2448, 2446, '沙湾', '沙湾区', '中国,四川省,乐山市,沙湾区', 3, 'shawan', '0833', '614900', 'S', '103.54873', '29.41194'),
+(2449, 2446, '五通桥', '五通桥区', '中国,四川省,乐山市,五通桥区', 3, 'wutongqiao', '0833', '614800', 'W', '103.82345', '29.40344'),
+(2450, 2446, '金口河', '金口河区', '中国,四川省,乐山市,金口河区', 3, 'jinkouhe', '0833', '614700', 'J', '103.07858', '29.24578'),
+(2451, 2446, '犍为', '犍为县', '中国,四川省,乐山市,犍为县', 3, 'qianwei', '0833', '614400', NULL, '103.94989', '29.20973'),
+(2452, 2446, '井研', '井研县', '中国,四川省,乐山市,井研县', 3, 'jingyan', '0833', '613100', 'J', '104.07019', '29.65228'),
+(2453, 2446, '夹江', '夹江县', '中国,四川省,乐山市,夹江县', 3, 'jiajiang', '0833', '614100', 'J', '103.57199', '29.73868'),
+(2454, 2446, '沐川', '沐川县', '中国,四川省,乐山市,沐川县', 3, 'muchuan', '0833', '614500', NULL, '103.90353', '28.95646'),
+(2455, 2446, '峨边', '峨边彝族自治县', '中国,四川省,乐山市,峨边彝族自治县', 3, 'ebian', '0833', '614300', 'E', '103.26339', '29.23004'),
+(2456, 2446, '马边', '马边彝族自治县', '中国,四川省,乐山市,马边彝族自治县', 3, 'mabian', '0833', '614600', 'M', '103.54617', '28.83593'),
+(2457, 2446, '峨眉山', '峨眉山市', '中国,四川省,乐山市,峨眉山市', 3, 'emeishan', '0833', '614200', 'E', '103.4844', '29.60117'),
+(2458, 2367, '南充', '南充市', '中国,四川省,南充市', 2, 'nanchong', '0817', '637000', 'N', '106.082974', '30.795281'),
+(2459, 2458, '顺庆', '顺庆区', '中国,四川省,南充市,顺庆区', 3, 'shunqing', '0817', '637000', 'S', '106.09216', '30.79642'),
+(2460, 2458, '高坪', '高坪区', '中国,四川省,南充市,高坪区', 3, 'gaoping', '0817', '637100', 'G', '106.11894', '30.78162'),
+(2461, 2458, '嘉陵', '嘉陵区', '中国,四川省,南充市,嘉陵区', 3, 'jialing', '0817', '637100', 'J', '106.07141', '30.75848'),
+(2462, 2458, '南部', '南部县', '中国,四川省,南充市,南部县', 3, 'nanbu', '0817', '637300', 'N', '106.06738', '31.35451'),
+(2463, 2458, '营山', '营山县', '中国,四川省,南充市,营山县', 3, 'yingshan', '0817', '637700', 'Y', '106.56637', '31.07747'),
+(2464, 2458, '蓬安', '蓬安县', '中国,四川省,南充市,蓬安县', 3, 'peng''an', '0817', '637800', 'P', '106.41262', '31.02964'),
+(2465, 2458, '仪陇', '仪陇县', '中国,四川省,南充市,仪陇县', 3, 'yilong', '0817', '637600', 'Y', '106.29974', '31.27628'),
+(2466, 2458, '西充', '西充县', '中国,四川省,南充市,西充县', 3, 'xichong', '0817', '637200', 'X', '105.89996', '30.9969'),
+(2467, 2458, '阆中', '阆中市', '中国,四川省,南充市,阆中市', 3, 'langzhong', '0817', '637400', NULL, '106.00494', '31.55832'),
+(2468, 2367, '眉山', '眉山市', '中国,四川省,眉山市', 2, 'meishan', '028', '620020', 'M', '103.831788', '30.048318'),
+(2469, 2468, '东坡', '东坡区', '中国,四川省,眉山市,东坡区', 3, 'dongpo', '028', '620010', 'D', '103.832', '30.04219'),
+(2470, 2468, '彭山', '彭山区', '中国,四川省,眉山市,彭山区', 3, 'pengshan', '028', '620860', 'P', '103.87268', '30.19283'),
+(2471, 2468, '仁寿', '仁寿县', '中国,四川省,眉山市,仁寿县', 3, 'renshou', '028', '620500', 'R', '104.13412', '29.99599'),
+(2472, 2468, '洪雅', '洪雅县', '中国,四川省,眉山市,洪雅县', 3, 'hongya', '028', '620360', 'H', '103.37313', '29.90661'),
+(2473, 2468, '丹棱', '丹棱县', '中国,四川省,眉山市,丹棱县', 3, 'danling', '028', '620200', 'D', '103.51339', '30.01562'),
+(2474, 2468, '青神', '青神县', '中国,四川省,眉山市,青神县', 3, 'qingshen', '028', '620460', 'Q', '103.84771', '29.83235'),
+(2475, 2367, '宜宾', '宜宾市', '中国,四川省,宜宾市', 2, 'yibin', '0831', '644000', 'Y', '104.630825', '28.760189'),
+(2476, 2475, '翠屏', '翠屏区', '中国,四川省,宜宾市,翠屏区', 3, 'cuiping', '0831', '644000', 'C', '104.61978', '28.76566'),
+(2477, 2475, '南溪', '南溪区', '中国,四川省,宜宾市,南溪区', 3, 'nanxi', '0831', '644100', 'N', '104.981133', '28.839806'),
+(2478, 2475, '宜宾', '宜宾县', '中国,四川省,宜宾市,宜宾县', 3, 'yibin', '0831', '644600', 'Y', '104.53314', '28.68996'),
+(2479, 2475, '江安', '江安县', '中国,四川省,宜宾市,江安县', 3, 'jiang''an', '0831', '644200', 'J', '105.06683', '28.72385'),
+(2480, 2475, '长宁', '长宁县', '中国,四川省,宜宾市,长宁县', 3, 'changning', '0831', '644300', 'C', '104.9252', '28.57777'),
+(2481, 2475, '高县', '高县', '中国,四川省,宜宾市,高县', 3, 'gaoxian', '0831', '645150', 'G', '104.51754', '28.43619'),
+(2482, 2475, '珙县', '珙县', '中国,四川省,宜宾市,珙县', 3, 'gongxian', '0831', '644500', NULL, '104.71398', '28.44512'),
+(2483, 2475, '筠连', '筠连县', '中国,四川省,宜宾市,筠连县', 3, 'junlian', '0831', '645250', NULL, '104.51217', '28.16495'),
+(2484, 2475, '兴文', '兴文县', '中国,四川省,宜宾市,兴文县', 3, 'xingwen', '0831', '644400', 'X', '105.23675', '28.3044'),
+(2485, 2475, '屏山', '屏山县', '中国,四川省,宜宾市,屏山县', 3, 'pingshan', '0831', '645350', 'P', '104.16293', '28.64369'),
+(2486, 2367, '广安', '广安市', '中国,四川省,广安市', 2, 'guang''an', '0826', '638000', 'G', '106.633369', '30.456398'),
+(2487, 2486, '广安', '广安区', '中国,四川省,广安市,广安区', 3, 'guang''an', '0826', '638000', 'G', '106.64163', '30.47389'),
+(2488, 2486, '前锋', '前锋区', '中国,四川省,广安市,前锋区', 3, 'qianfeng', '0826', '638019', 'Q', '106.893537', '30.494572'),
+(2489, 2486, '岳池', '岳池县', '中国,四川省,广安市,岳池县', 3, 'yuechi', '0826', '638300', 'Y', '106.44079', '30.53918'),
+(2490, 2486, '武胜', '武胜县', '中国,四川省,广安市,武胜县', 3, 'wusheng', '0826', '638400', 'W', '106.29592', '30.34932'),
+(2491, 2486, '邻水', '邻水县', '中国,四川省,广安市,邻水县', 3, 'linshui', '0826', '638500', 'L', '106.92968', '30.33449'),
+(2492, 2486, '华蓥', '华蓥市', '中国,四川省,广安市,华蓥市', 3, 'huaying', '0826', '638600', 'H', '106.78466', '30.39007'),
+(2493, 2367, '达州', '达州市', '中国,四川省,达州市', 2, 'dazhou', '0818', '635000', 'D', '107.502262', '31.209484'),
+(2494, 2493, '通川', '通川区', '中国,四川省,达州市,通川区', 3, 'tongchuan', '0818', '635000', 'T', '107.50456', '31.21469'),
+(2495, 2493, '达川', '达川区', '中国,四川省,达州市,达川区', 3, 'dachuan', '0818', '635000', 'D', '107.502262', '31.209484'),
+(2496, 2493, '宣汉', '宣汉县', '中国,四川省,达州市,宣汉县', 3, 'xuanhan', '0818', '636150', 'X', '107.72775', '31.35516'),
+(2497, 2493, '开江', '开江县', '中国,四川省,达州市,开江县', 3, 'kaijiang', '0818', '636250', 'K', '107.86889', '31.0841'),
+(2498, 2493, '大竹', '大竹县', '中国,四川省,达州市,大竹县', 3, 'dazhu', '0818', '635100', 'D', '107.20855', '30.74147'),
+(2499, 2493, '渠县', '渠县', '中国,四川省,达州市,渠县', 3, 'quxian', '0818', '635200', 'Q', '106.97381', '30.8376'),
+(2500, 2493, '万源', '万源市', '中国,四川省,达州市,万源市', 3, 'wanyuan', '0818', '636350', 'W', '108.03598', '32.08091'),
+(2501, 2367, '雅安', '雅安市', '中国,四川省,雅安市', 2, 'ya''an', '0835', '625000', 'Y', '103.001033', '29.987722'),
+(2502, 2501, '雨城', '雨城区', '中国,四川省,雅安市,雨城区', 3, 'yucheng', '0835', '625000', 'Y', '103.03305', '30.00531'),
+(2503, 2501, '名山', '名山区', '中国,四川省,雅安市,名山区', 3, 'mingshan', '0835', '625100', 'M', '103.112214', '30.084718'),
+(2504, 2501, '荥经', '荥经县', '中国,四川省,雅安市,荥经县', 3, 'yingjing', '0835', '625200', NULL, '102.84652', '29.79402'),
+(2505, 2501, '汉源', '汉源县', '中国,四川省,雅安市,汉源县', 3, 'hanyuan', '0835', '625300', 'H', '102.6784', '29.35168'),
+(2506, 2501, '石棉', '石棉县', '中国,四川省,雅安市,石棉县', 3, 'shimian', '0835', '625400', 'S', '102.35943', '29.22796'),
+(2507, 2501, '天全', '天全县', '中国,四川省,雅安市,天全县', 3, 'tianquan', '0835', '625500', 'T', '102.75906', '30.06754'),
+(2508, 2501, '芦山', '芦山县', '中国,四川省,雅安市,芦山县', 3, 'lushan', '0835', '625600', 'L', '102.92791', '30.14369'),
+(2509, 2501, '宝兴', '宝兴县', '中国,四川省,雅安市,宝兴县', 3, 'baoxing', '0835', '625700', 'B', '102.81555', '30.36836'),
+(2510, 2367, '巴中', '巴中市', '中国,四川省,巴中市', 2, 'bazhong', '0827', '636000', 'B', '106.753669', '31.858809'),
+(2511, 2510, '巴州', '巴州区', '中国,四川省,巴中市,巴州区', 3, 'bazhou', '0827', '636001', 'B', '106.76889', '31.85125'),
+(2512, 2510, '恩阳', '恩阳区', '中国,四川省,巴中市,恩阳区', 3, 'enyang', '0827', '636064', 'E', '106.753669', '31.858809'),
+(2513, 2510, '通江', '通江县', '中国,四川省,巴中市,通江县', 3, 'tongjiang', '0827', '636700', 'T', '107.24398', '31.91294'),
+(2514, 2510, '南江', '南江县', '中国,四川省,巴中市,南江县', 3, 'nanjiang', '0827', '636600', 'N', '106.84164', '32.35335'),
+(2515, 2510, '平昌', '平昌县', '中国,四川省,巴中市,平昌县', 3, 'pingchang', '0827', '636400', 'P', '107.10424', '31.5594'),
+(2516, 2367, '资阳', '资阳市', '中国,四川省,资阳市', 2, 'ziyang', '028', '641300', 'Z', '104.641917', '30.122211'),
+(2517, 2516, '雁江', '雁江区', '中国,四川省,资阳市,雁江区', 3, 'yanjiang', '028', '641300', 'Y', '104.65216', '30.11525'),
+(2518, 2516, '安岳', '安岳县', '中国,四川省,资阳市,安岳县', 3, 'anyue', '028', '642350', 'A', '105.3363', '30.09786'),
+(2519, 2516, '乐至', '乐至县', '中国,四川省,资阳市,乐至县', 3, 'lezhi', '028', '641500', 'L', '105.03207', '30.27227'),
+(2520, 2516, '简阳', '简阳市', '中国,四川省,资阳市,简阳市', 3, 'jianyang', '028', '641400', 'J', '104.54864', '30.3904'),
+(2521, 2367, '阿坝', '阿坝藏族羌族自治州', '中国,四川省,阿坝藏族羌族自治州', 2, 'aba', '0837', '624000', 'A', '102.221374', '31.899792'),
+(2522, 2521, '汶川', '汶川县', '中国,四川省,阿坝藏族羌族自治州,汶川县', 3, 'wenchuan', '0837', '623000', NULL, '103.59079', '31.47326'),
+(2523, 2521, '理县', '理县', '中国,四川省,阿坝藏族羌族自治州,理县', 3, 'lixian', '0837', '623100', 'L', '103.17175', '31.43603'),
+(2524, 2521, '茂县', '茂县', '中国,四川省,阿坝藏族羌族自治州,茂县', 3, 'maoxian', '0837', '623200', 'M', '103.85372', '31.682'),
+(2525, 2521, '松潘', '松潘县', '中国,四川省,阿坝藏族羌族自治州,松潘县', 3, 'songpan', '0837', '623300', 'S', '103.59924', '32.63871'),
+(2526, 2521, '九寨沟', '九寨沟县', '中国,四川省,阿坝藏族羌族自治州,九寨沟县', 3, 'jiuzhaigou', '0837', '623400', 'J', '104.23672', '33.26318'),
+(2527, 2521, '金川', '金川县', '中国,四川省,阿坝藏族羌族自治州,金川县', 3, 'jinchuan', '0837', '624100', 'J', '102.06555', '31.47623'),
+(2528, 2521, '小金', '小金县', '中国,四川省,阿坝藏族羌族自治州,小金县', 3, 'xiaojin', '0837', '624200', 'X', '102.36499', '30.99934'),
+(2529, 2521, '黑水', '黑水县', '中国,四川省,阿坝藏族羌族自治州,黑水县', 3, 'heishui', '0837', '623500', 'H', '102.99176', '32.06184'),
+(2530, 2521, '马尔康', '马尔康县', '中国,四川省,阿坝藏族羌族自治州,马尔康县', 3, 'maerkang', '0837', '624000', 'M', '102.20625', '31.90584'),
+(2531, 2521, '壤塘', '壤塘县', '中国,四川省,阿坝藏族羌族自治州,壤塘县', 3, 'rangtang', '0837', '624300', 'R', '100.9783', '32.26578'),
+(2532, 2521, '阿坝', '阿坝县', '中国,四川省,阿坝藏族羌族自治州,阿坝县', 3, 'aba', '0837', '624600', 'A', '101.70632', '32.90301'),
+(2533, 2521, '若尔盖', '若尔盖县', '中国,四川省,阿坝藏族羌族自治州,若尔盖县', 3, 'ruoergai', '0837', '624500', 'R', '102.9598', '33.57432'),
+(2534, 2521, '红原', '红原县', '中国,四川省,阿坝藏族羌族自治州,红原县', 3, 'hongyuan', '0837', '624400', 'H', '102.54525', '32.78989'),
+(2535, 2367, '甘孜', '甘孜藏族自治州', '中国,四川省,甘孜藏族自治州', 2, 'garze', '0836', '626000', 'G', '101.963815', '30.050663'),
+(2536, 2535, '康定', '康定县', '中国,四川省,甘孜藏族自治州,康定县', 3, 'kangding', '0836', '626000', 'K', '101.96487', '30.05532'),
+(2537, 2535, '泸定', '泸定县', '中国,四川省,甘孜藏族自治州,泸定县', 3, 'luding', '0836', '626100', NULL, '102.23507', '29.91475'),
+(2538, 2535, '丹巴', '丹巴县', '中国,四川省,甘孜藏族自治州,丹巴县', 3, 'danba', '0836', '626300', 'D', '101.88424', '30.87656'),
+(2539, 2535, '九龙', '九龙县', '中国,四川省,甘孜藏族自治州,九龙县', 3, 'jiulong', '0836', '626200', 'J', '101.50848', '29.00091'),
+(2540, 2535, '雅江', '雅江县', '中国,四川省,甘孜藏族自治州,雅江县', 3, 'yajiang', '0836', '627450', 'Y', '101.01492', '30.03281'),
+(2541, 2535, '道孚', '道孚县', '中国,四川省,甘孜藏族自治州,道孚县', 3, 'daofu', '0836', '626400', 'D', '101.12554', '30.98046'),
+(2542, 2535, '炉霍', '炉霍县', '中国,四川省,甘孜藏族自治州,炉霍县', 3, 'luhuo', '0836', '626500', 'L', '100.67681', '31.3917'),
+(2543, 2535, '甘孜', '甘孜县', '中国,四川省,甘孜藏族自治州,甘孜县', 3, 'ganzi', '0836', '626700', 'G', '99.99307', '31.62672'),
+(2544, 2535, '新龙', '新龙县', '中国,四川省,甘孜藏族自治州,新龙县', 3, 'xinlong', '0836', '626800', 'X', '100.3125', '30.94067'),
+(2545, 2535, '德格', '德格县', '中国,四川省,甘孜藏族自治州,德格县', 3, 'dege', '0836', '627250', 'D', '98.58078', '31.80615'),
+(2546, 2535, '白玉', '白玉县', '中国,四川省,甘孜藏族自治州,白玉县', 3, 'baiyu', '0836', '627150', 'B', '98.82568', '31.20902'),
+(2547, 2535, '石渠', '石渠县', '中国,四川省,甘孜藏族自治州,石渠县', 3, 'shiqu', '0836', '627350', 'S', '98.10156', '32.97884'),
+(2548, 2535, '色达', '色达县', '中国,四川省,甘孜藏族自治州,色达县', 3, 'seda', '0836', '626600', 'S', '100.33224', '32.26839'),
+(2549, 2535, '理塘', '理塘县', '中国,四川省,甘孜藏族自治州,理塘县', 3, 'litang', '0836', '627550', 'L', '100.27005', '29.99674'),
+(2550, 2535, '巴塘', '巴塘县', '中国,四川省,甘孜藏族自治州,巴塘县', 3, 'batang', '0836', '627650', 'B', '99.10409', '30.00423'),
+(2551, 2535, '乡城', '乡城县', '中国,四川省,甘孜藏族自治州,乡城县', 3, 'xiangcheng', '0836', '627850', 'X', '99.79943', '28.93554'),
+(2552, 2535, '稻城', '稻城县', '中国,四川省,甘孜藏族自治州,稻城县', 3, 'daocheng', '0836', '627750', 'D', '100.29809', '29.0379'),
+(2553, 2535, '得荣', '得荣县', '中国,四川省,甘孜藏族自治州,得荣县', 3, 'derong', '0836', '627950', 'D', '99.28628', '28.71297'),
+(2554, 2367, '凉山', '凉山彝族自治州', '中国,四川省,凉山彝族自治州', 2, 'liangshan', '0834', '615000', 'L', '102.258746', '27.886762'),
+(2555, 2554, '西昌', '西昌市', '中国,四川省,凉山彝族自治州,西昌市', 3, 'xichang', '0835', '615000', 'X', '102.26413', '27.89524'),
+(2556, 2554, '木里', '木里藏族自治县', '中国,四川省,凉山彝族自治州,木里藏族自治县', 3, 'muli', '0851', '615800', 'M', '101.2796', '27.92875'),
+(2557, 2554, '盐源', '盐源县', '中国,四川省,凉山彝族自治州,盐源县', 3, 'yanyuan', '0836', '615700', 'Y', '101.5097', '27.42177'),
+(2558, 2554, '德昌', '德昌县', '中国,四川省,凉山彝族自治州,德昌县', 3, 'dechang', '0837', '615500', 'D', '102.18017', '27.40482'),
+(2559, 2554, '会理', '会理县', '中国,四川省,凉山彝族自治州,会理县', 3, 'huili', '0838', '615100', 'H', '102.24539', '26.65627'),
+(2560, 2554, '会东', '会东县', '中国,四川省,凉山彝族自治州,会东县', 3, 'huidong', '0839', '615200', 'H', '102.57815', '26.63429'),
+(2561, 2554, '宁南', '宁南县', '中国,四川省,凉山彝族自治州,宁南县', 3, 'ningnan', '0840', '615400', 'N', '102.76116', '27.06567'),
+(2562, 2554, '普格', '普格县', '中国,四川省,凉山彝族自治州,普格县', 3, 'puge', '0841', '615300', 'P', '102.54055', '27.37485'),
+(2563, 2554, '布拖', '布拖县', '中国,四川省,凉山彝族自治州,布拖县', 3, 'butuo', '0842', '616350', 'B', '102.81234', '27.7079'),
+(2564, 2554, '金阳', '金阳县', '中国,四川省,凉山彝族自治州,金阳县', 3, 'jinyang', '0843', '616250', 'J', '103.24774', '27.69698'),
+(2565, 2554, '昭觉', '昭觉县', '中国,四川省,凉山彝族自治州,昭觉县', 3, 'zhaojue', '0844', '616150', 'Z', '102.84661', '28.01155'),
+(2566, 2554, '喜德', '喜德县', '中国,四川省,凉山彝族自治州,喜德县', 3, 'xide', '0845', '616750', 'X', '102.41336', '28.30739'),
+(2567, 2554, '冕宁', '冕宁县', '中国,四川省,凉山彝族自治州,冕宁县', 3, 'mianning', '0846', '615600', 'M', '102.17108', '28.55161'),
+(2568, 2554, '越西', '越西县', '中国,四川省,凉山彝族自治州,越西县', 3, 'yuexi', '0847', '616650', 'Y', '102.5079', '28.64133'),
+(2569, 2554, '甘洛', '甘洛县', '中国,四川省,凉山彝族自治州,甘洛县', 3, 'ganluo', '0848', '616850', 'G', '102.77154', '28.96624'),
+(2570, 2554, '美姑', '美姑县', '中国,四川省,凉山彝族自治州,美姑县', 3, 'meigu', '0849', '616450', 'M', '103.13116', '28.32596'),
+(2571, 2554, '雷波', '雷波县', '中国,四川省,凉山彝族自治州,雷波县', 3, 'leibo', '0850', '616550', 'L', '103.57287', '28.26407'),
+(2572, 0, '贵州', '贵州省', '中国,贵州省', 1, 'guizhou', '', '', 'G', '106.713478', '26.578343'),
+(2573, 2572, '贵阳', '贵阳市', '中国,贵州省,贵阳市', 2, 'guiyang', '0851', '550001', 'G', '106.713478', '26.578343'),
+(2574, 2573, '南明', '南明区', '中国,贵州省,贵阳市,南明区', 3, 'nanming', '0851', '550001', 'N', '106.7145', '26.56819'),
+(2575, 2573, '云岩', '云岩区', '中国,贵州省,贵阳市,云岩区', 3, 'yunyan', '0851', '550001', 'Y', '106.72485', '26.60484'),
+(2576, 2573, '花溪', '花溪区', '中国,贵州省,贵阳市,花溪区', 3, 'huaxi', '0851', '550025', 'H', '106.67688', '26.43343'),
+(2577, 2573, '乌当', '乌当区', '中国,贵州省,贵阳市,乌当区', 3, 'wudang', '0851', '550018', 'W', '106.7521', '26.6302'),
+(2578, 2573, '白云', '白云区', '中国,贵州省,贵阳市,白云区', 3, 'baiyun', '0851', '550014', 'B', '106.63088', '26.68284'),
+(2579, 2573, '观山湖', '观山湖区', '中国,贵州省,贵阳市,观山湖区', 3, 'guanshanhu', '0851', '550009', 'G', '106.625442', '26.618209'),
+(2580, 2573, '开阳', '开阳县', '中国,贵州省,贵阳市,开阳县', 3, 'kaiyang', '0851', '550300', 'K', '106.9692', '27.05533'),
+(2581, 2573, '息烽', '息烽县', '中国,贵州省,贵阳市,息烽县', 3, 'xifeng', '0851', '551100', 'X', '106.738', '27.09346'),
+(2582, 2573, '修文', '修文县', '中国,贵州省,贵阳市,修文县', 3, 'xiuwen', '0851', '550200', 'X', '106.59487', '26.83783'),
+(2583, 2573, '清镇', '清镇市', '中国,贵州省,贵阳市,清镇市', 3, 'qingzhen', '0851', '551400', 'Q', '106.46862', '26.55261'),
+(2584, 2572, '六盘水', '六盘水市', '中国,贵州省,六盘水市', 2, 'liupanshui', '0858', '553400', 'L', '104.846743', '26.584643'),
+(2585, 2584, '钟山', '钟山区', '中国,贵州省,六盘水市,钟山区', 3, 'zhongshan', '0858', '553000', 'Z', '104.87848', '26.57699'),
+(2586, 2584, '六枝', '六枝特区', '中国,贵州省,六盘水市,六枝特区', 3, 'liuzhi', '0858', '553400', 'L', '105.48062', '26.20117'),
+(2587, 2584, '水城', '水城县', '中国,贵州省,六盘水市,水城县', 3, 'shuicheng', '0858', '553000', 'S', '104.95764', '26.54785'),
+(2588, 2584, '盘县', '盘县', '中国,贵州省,六盘水市,盘县', 3, 'panxian', '0858', '561601', 'P', '104.47061', '25.7136'),
+(2589, 2572, '遵义', '遵义市', '中国,贵州省,遵义市', 2, 'zunyi', '0852', '563000', 'Z', '106.937265', '27.706626'),
+(2590, 2589, '红花岗', '红花岗区', '中国,贵州省,遵义市,红花岗区', 3, 'honghuagang', '0852', '563000', 'H', '106.89404', '27.64471'),
+(2591, 2589, '汇川', '汇川区', '中国,贵州省,遵义市,汇川区', 3, 'huichuan', '0852', '563000', 'H', '106.9393', '27.70625'),
+(2592, 2589, '遵义', '遵义县', '中国,贵州省,遵义市,遵义县', 3, 'zunyi', '0852', '563100', 'Z', '106.83331', '27.53772'),
+(2593, 2589, '桐梓', '桐梓县', '中国,贵州省,遵义市,桐梓县', 3, 'tongzi', '0852', '563200', 'T', '106.82568', '28.13806'),
+(2594, 2589, '绥阳', '绥阳县', '中国,贵州省,遵义市,绥阳县', 3, 'suiyang', '0852', '563300', 'S', '107.19064', '27.94702'),
+(2595, 2589, '正安', '正安县', '中国,贵州省,遵义市,正安县', 3, 'zheng''an', '0852', '563400', 'Z', '107.44357', '28.5512'),
+(2596, 2589, '道真', '道真仡佬族苗族自治县', '中国,贵州省,遵义市,道真仡佬族苗族自治县', 3, 'daozhen', '0852', '563500', 'D', '107.61152', '28.864'),
+(2597, 2589, '务川', '务川仡佬族苗族自治县', '中国,贵州省,遵义市,务川仡佬族苗族自治县', 3, 'wuchuan', '0852', '564300', 'W', '107.88935', '28.52227'),
+(2598, 2589, '凤冈', '凤冈县', '中国,贵州省,遵义市,凤冈县', 3, 'fenggang', '0852', '564200', 'F', '107.71682', '27.95461'),
+(2599, 2589, '湄潭', '湄潭县', '中国,贵州省,遵义市,湄潭县', 3, 'meitan', '0852', '564100', NULL, '107.48779', '27.76676'),
+(2600, 2589, '余庆', '余庆县', '中国,贵州省,遵义市,余庆县', 3, 'yuqing', '0852', '564400', 'Y', '107.88821', '27.22532'),
+(2601, 2589, '习水', '习水县', '中国,贵州省,遵义市,习水县', 3, 'xishui', '0852', '564600', 'X', '106.21267', '28.31976'),
+(2602, 2589, '赤水', '赤水市', '中国,贵州省,遵义市,赤水市', 3, 'chishui', '0852', '564700', 'C', '105.69845', '28.58921'),
+(2603, 2589, '仁怀', '仁怀市', '中国,贵州省,遵义市,仁怀市', 3, 'renhuai', '0852', '564500', 'R', '106.40152', '27.79231'),
+(2604, 2572, '安顺', '安顺市', '中国,贵州省,安顺市', 2, 'anshun', '0853', '561000', 'A', '105.932188', '26.245544'),
+(2605, 2604, '西秀', '西秀区', '中国,贵州省,安顺市,西秀区', 3, 'xixiu', '0853', '561000', 'X', '105.96585', '26.24491'),
+(2606, 2604, '平坝', '平坝区', '中国,贵州省,安顺市,平坝区', 3, 'pingba', '0853', '561100', 'P', '106.25683', '26.40543'),
+(2607, 2604, '普定', '普定县', '中国,贵州省,安顺市,普定县', 3, 'puding', '0853', '562100', 'P', '105.74285', '26.30141'),
+(2608, 2604, '镇宁', '镇宁布依族苗族自治县', '中国,贵州省,安顺市,镇宁布依族苗族自治县', 3, 'zhenning', '0853', '561200', 'Z', '105.76513', '26.05533'),
+(2609, 2604, '关岭', '关岭布依族苗族自治县', '中国,贵州省,安顺市,关岭布依族苗族自治县', 3, 'guanling', '0853', '561300', 'G', '105.61883', '25.94248'),
+(2610, 2604, '紫云', '紫云苗族布依族自治县', '中国,贵州省,安顺市,紫云苗族布依族自治县', 3, 'ziyun', '0853', '550800', 'Z', '106.08364', '25.75258'),
+(2611, 2572, '毕节', '毕节市', '中国,贵州省,毕节市', 2, 'bijie', '0857', '551700', 'B', '105.28501', '27.301693'),
+(2612, 2611, '七星关', '七星关区', '中国,贵州省,毕节市,七星关区', 3, 'qixingguan', '0857', '551700', 'Q', '104.9497', '27.153556'),
+(2613, 2611, '大方', '大方县', '中国,贵州省,毕节市,大方县', 3, 'dafang', '0857', '551600', 'D', '105.609254', '27.143521'),
+(2614, 2611, '黔西', '黔西县', '中国,贵州省,毕节市,黔西县', 3, 'qianxi', '0857', '551500', 'Q', '106.038299', '27.024923'),
+(2615, 2611, '金沙', '金沙县', '中国,贵州省,毕节市,金沙县', 3, 'jinsha', '0857', '551800', 'J', '106.222103', '27.459693'),
+(2616, 2611, '织金', '织金县', '中国,贵州省,毕节市,织金县', 3, 'zhijin', '0857', '552100', 'Z', '105.768997', '26.668497'),
+(2617, 2611, '纳雍', '纳雍县', '中国,贵州省,毕节市,纳雍县', 3, 'nayong', '0857', '553300', 'N', '105.375322', '26.769875'),
+(2618, 2611, '威宁', '威宁彝族回族苗族自治县', '中国,贵州省,毕节市,威宁彝族回族苗族自治县', 3, 'weining', '0857', '553100', 'W', '104.286523', '26.859099'),
+(2619, 2611, '赫章', '赫章县', '中国,贵州省,毕节市,赫章县', 3, 'hezhang', '0857', '553200', 'H', '104.726438', '27.119243'),
+(2620, 2572, '铜仁', '铜仁市', '中国,贵州省,铜仁市', 2, 'tongren', '0856', '554300', 'T', '109.191555', '27.718346'),
+(2621, 2620, '碧江', '碧江区', '中国,贵州省,铜仁市,碧江区', 3, 'bijiang', '0856', '554300', 'B', '109.191555', '27.718346'),
+(2622, 2620, '万山', '万山区', '中国,贵州省,铜仁市,万山区', 3, 'wanshan', '0856', '554200', 'W', '109.21199', '27.51903'),
+(2623, 2620, '江口', '江口县', '中国,贵州省,铜仁市,江口县', 3, 'jiangkou', '0856', '554400', 'J', '108.848427', '27.691904'),
+(2624, 2620, '玉屏', '玉屏侗族自治县', '中国,贵州省,铜仁市,玉屏侗族自治县', 3, 'yuping', '0856', '554004', 'Y', '108.917882', '27.238024'),
+(2625, 2620, '石阡', '石阡县', '中国,贵州省,铜仁市,石阡县', 3, 'shiqian', '0856', '555100', 'S', '108.229854', '27.519386'),
+(2626, 2620, '思南', '思南县', '中国,贵州省,铜仁市,思南县', 3, 'sinan', '0856', '565100', 'S', '108.255827', '27.941331'),
+(2627, 2620, '印江', '印江土家族苗族自治县', '中国,贵州省,铜仁市,印江土家族苗族自治县', 3, 'yinjiang', '0856', '555200', 'Y', '108.405517', '27.997976'),
+(2628, 2620, '德江', '德江县', '中国,贵州省,铜仁市,德江县', 3, 'dejiang', '0856', '565200', 'D', '108.117317', '28.26094'),
+(2629, 2620, '沿河', '沿河土家族自治县', '中国,贵州省,铜仁市,沿河土家族自治县', 3, 'yuanhe', '0856', '565300', 'Y', '108.495746', '28.560487'),
+(2630, 2620, '松桃', '松桃苗族自治县', '中国,贵州省,铜仁市,松桃苗族自治县', 3, 'songtao', '0856', '554100', 'S', '109.202627', '28.165419'),
+(2631, 2572, '黔西南', '黔西南布依族苗族自治州', '中国,贵州省,黔西南布依族苗族自治州', 2, 'qianxinan', '0859', '562400', 'Q', '104.897971', '25.08812'),
+(2632, 2631, '兴义', '兴义市 ', '中国,贵州省,黔西南布依族苗族自治州,兴义市 ', 3, 'xingyi', '0859', '562400', 'X', '104.89548', '25.09205'),
+(2633, 2631, '兴仁', '兴仁县', '中国,贵州省,黔西南布依族苗族自治州,兴仁县', 3, 'xingren', '0859', '562300', 'X', '105.18652', '25.43282'),
+(2634, 2631, '普安', '普安县', '中国,贵州省,黔西南布依族苗族自治州,普安县', 3, 'pu''an', '0859', '561500', 'P', '104.95529', '25.78603'),
+(2635, 2631, '晴隆', '晴隆县', '中国,贵州省,黔西南布依族苗族自治州,晴隆县', 3, 'qinglong', '0859', '561400', 'Q', '105.2192', '25.83522'),
+(2636, 2631, '贞丰', '贞丰县', '中国,贵州省,黔西南布依族苗族自治州,贞丰县', 3, 'zhenfeng', '0859', '562200', 'Z', '105.65454', '25.38464'),
+(2637, 2631, '望谟', '望谟县', '中国,贵州省,黔西南布依族苗族自治州,望谟县', 3, 'wangmo', '0859', '552300', 'W', '106.09957', '25.17822'),
+(2638, 2631, '册亨', '册亨县', '中国,贵州省,黔西南布依族苗族自治州,册亨县', 3, 'ceheng', '0859', '552200', 'C', '105.8124', '24.98376'),
+(2639, 2631, '安龙', '安龙县', '中国,贵州省,黔西南布依族苗族自治州,安龙县', 3, 'anlong', '0859', '552400', 'A', '105.44268', '25.09818'),
+(2640, 2572, '黔东南', '黔东南苗族侗族自治州', '中国,贵州省,黔东南苗族侗族自治州', 2, 'qiandongnan', '0855', '556000', 'Q', '107.977488', '26.583352'),
+(2641, 2640, '凯里', '凯里市', '中国,贵州省,黔东南苗族侗族自治州,凯里市', 3, 'kaili', '0855', '556000', 'K', '107.98132', '26.56689'),
+(2642, 2640, '黄平', '黄平县', '中国,贵州省,黔东南苗族侗族自治州,黄平县', 3, 'huangping', '0855', '556100', 'H', '107.90179', '26.89573'),
+(2643, 2640, '施秉', '施秉县', '中国,贵州省,黔东南苗族侗族自治州,施秉县', 3, 'shibing', '0855', '556200', 'S', '108.12597', '27.03495'),
+(2644, 2640, '三穗', '三穗县', '中国,贵州省,黔东南苗族侗族自治州,三穗县', 3, 'sansui', '0855', '556500', 'S', '108.67132', '26.94765'),
+(2645, 2640, '镇远', '镇远县', '中国,贵州省,黔东南苗族侗族自治州,镇远县', 3, 'zhenyuan', '0855', '557700', 'Z', '108.42721', '27.04933'),
+(2646, 2640, '岑巩', '岑巩县', '中国,贵州省,黔东南苗族侗族自治州,岑巩县', 3, 'cengong', '0855', '557800', NULL, '108.81884', '27.17539'),
+(2647, 2640, '天柱', '天柱县', '中国,贵州省,黔东南苗族侗族自治州,天柱县', 3, 'tianzhu', '0855', '556600', 'T', '109.20718', '26.90781'),
+(2648, 2640, '锦屏', '锦屏县', '中国,贵州省,黔东南苗族侗族自治州,锦屏县', 3, 'jinping', '0855', '556700', 'J', '109.19982', '26.67635'),
+(2649, 2640, '剑河', '剑河县', '中国,贵州省,黔东南苗族侗族自治州,剑河县', 3, 'jianhe', '0855', '556400', 'J', '108.5913', '26.6525'),
+(2650, 2640, '台江', '台江县', '中国,贵州省,黔东南苗族侗族自治州,台江县', 3, 'taijiang', '0855', '556300', 'T', '108.31814', '26.66916'),
+(2651, 2640, '黎平', '黎平县', '中国,贵州省,黔东南苗族侗族自治州,黎平县', 3, 'liping', '0855', '557300', 'L', '109.13607', '26.23114'),
+(2652, 2640, '榕江', '榕江县', '中国,贵州省,黔东南苗族侗族自治州,榕江县', 3, 'rongjiang', '0855', '557200', NULL, '108.52072', '25.92421'),
+(2653, 2640, '从江', '从江县', '中国,贵州省,黔东南苗族侗族自治州,从江县', 3, 'congjiang', '0855', '557400', 'C', '108.90527', '25.75415'),
+(2654, 2640, '雷山', '雷山县', '中国,贵州省,黔东南苗族侗族自治州,雷山县', 3, 'leishan', '0855', '557100', 'L', '108.07745', '26.38385'),
+(2655, 2640, '麻江', '麻江县', '中国,贵州省,黔东南苗族侗族自治州,麻江县', 3, 'majiang', '0855', '557600', 'M', '107.59155', '26.49235'),
+(2656, 2640, '丹寨', '丹寨县', '中国,贵州省,黔东南苗族侗族自治州,丹寨县', 3, 'danzhai', '0855', '557500', 'D', '107.79718', '26.19816'),
+(2657, 2572, '黔南', '黔南布依族苗族自治州', '中国,贵州省,黔南布依族苗族自治州', 2, 'qiannan', '0854', '558000', 'Q', '107.517156', '26.258219'),
+(2658, 2657, '都匀', '都匀市', '中国,贵州省,黔南布依族苗族自治州,都匀市', 3, 'duyun', '0854', '558000', 'D', '107.51872', '26.2594'),
+(2659, 2657, '福泉', '福泉市', '中国,贵州省,黔南布依族苗族自治州,福泉市', 3, 'fuquan', '0854', '550500', 'F', '107.51715', '26.67989'),
+(2660, 2657, '荔波', '荔波县', '中国,贵州省,黔南布依族苗族自治州,荔波县', 3, 'libo', '0854', '558400', 'L', '107.88592', '25.4139'),
+(2661, 2657, '贵定', '贵定县', '中国,贵州省,黔南布依族苗族自治州,贵定县', 3, 'guiding', '0854', '551300', 'G', '107.23654', '26.57812'),
+(2662, 2657, '瓮安', '瓮安县', '中国,贵州省,黔南布依族苗族自治州,瓮安县', 3, 'weng''an', '0854', '550400', 'W', '107.4757', '27.06813'),
+(2663, 2657, '独山', '独山县', '中国,贵州省,黔南布依族苗族自治州,独山县', 3, 'dushan', '0854', '558200', 'D', '107.54101', '25.8245'),
+(2664, 2657, '平塘', '平塘县', '中国,贵州省,黔南布依族苗族自治州,平塘县', 3, 'pingtang', '0854', '558300', 'P', '107.32428', '25.83294'),
+(2665, 2657, '罗甸', '罗甸县', '中国,贵州省,黔南布依族苗族自治州,罗甸县', 3, 'luodian', '0854', '550100', 'L', '106.75186', '25.42586'),
+(2666, 2657, '长顺', '长顺县', '中国,贵州省,黔南布依族苗族自治州,长顺县', 3, 'changshun', '0854', '550700', 'C', '106.45217', '26.02299'),
+(2667, 2657, '龙里', '龙里县', '中国,贵州省,黔南布依族苗族自治州,龙里县', 3, 'longli', '0854', '551200', 'L', '106.97662', '26.45076'),
+(2668, 2657, '惠水', '惠水县', '中国,贵州省,黔南布依族苗族自治州,惠水县', 3, 'huishui', '0854', '550600', 'H', '106.65911', '26.13389'),
+(2669, 2657, '三都', '三都水族自治县', '中国,贵州省,黔南布依族苗族自治州,三都水族自治县', 3, 'sandu', '0854', '558100', 'S', '107.87464', '25.98562'),
+(2670, 0, '云南', '云南省', '中国,云南省', 1, 'yunnan', '', '', 'Y', '102.712251', '25.040609'),
+(2671, 2670, '昆明', '昆明市', '中国,云南省,昆明市', 2, 'kunming', '0871', '650500', 'K', '102.712251', '25.040609'),
+(2672, 2671, '五华', '五华区', '中国,云南省,昆明市,五华区', 3, 'wuhua', '0871', '650021', 'W', '102.70786', '25.03521'),
+(2673, 2671, '盘龙', '盘龙区', '中国,云南省,昆明市,盘龙区', 3, 'panlong', '0871', '650051', 'P', '102.71994', '25.04053'),
+(2674, 2671, '官渡', '官渡区', '中国,云南省,昆明市,官渡区', 3, 'guandu', '0871', '650200', 'G', '102.74362', '25.01497'),
+(2675, 2671, '西山', '西山区', '中国,云南省,昆明市,西山区', 3, 'xishan', '0871', '650118', 'X', '102.66464', '25.03796'),
+(2676, 2671, '东川', '东川区', '中国,云南省,昆明市,东川区', 3, 'dongchuan', '0871', '654100', 'D', '103.18832', '26.083'),
+(2677, 2671, '呈贡', '呈贡区', '中国,云南省,昆明市,呈贡区', 3, 'chenggong', '0871', '650500', 'C', '102.801382', '24.889275'),
+(2678, 2671, '晋宁', '晋宁县', '中国,云南省,昆明市,晋宁县', 3, 'jinning', '0871', '650600', 'J', '102.59393', '24.6665'),
+(2679, 2671, '富民', '富民县', '中国,云南省,昆明市,富民县', 3, 'fumin', '0871', '650400', 'F', '102.4985', '25.22119'),
+(2680, 2671, '宜良', '宜良县', '中国,云南省,昆明市,宜良县', 3, 'yiliang', '0871', '652100', 'Y', '103.14117', '24.91705'),
+(2681, 2671, '石林', '石林彝族自治县', '中国,云南省,昆明市,石林彝族自治县', 3, 'shilin', '0871', '652200', 'S', '103.27148', '24.75897'),
+(2682, 2671, '嵩明', '嵩明县', '中国,云南省,昆明市,嵩明县', 3, 'songming', '0871', '651700', NULL, '103.03729', '25.33986'),
+(2683, 2671, '禄劝', '禄劝彝族苗族自治县', '中国,云南省,昆明市,禄劝彝族苗族自治县', 3, 'luquan', '0871', '651500', 'L', '102.4671', '25.55387'),
+(2684, 2671, '寻甸', '寻甸回族彝族自治县 ', '中国,云南省,昆明市,寻甸回族彝族自治县 ', 3, 'xundian', '0871', '655200', 'X', '103.2557', '25.55961'),
+(2685, 2671, '安宁', '安宁市', '中国,云南省,昆明市,安宁市', 3, 'anning', '0871', '650300', 'A', '102.46972', '24.91652'),
+(2686, 2670, '曲靖', '曲靖市', '中国,云南省,曲靖市', 2, 'qujing', '0874', '655000', 'Q', '103.797851', '25.501557'),
+(2687, 2686, '麒麟', '麒麟区', '中国,云南省,曲靖市,麒麟区', 3, 'qilin', '0874', '655000', NULL, '103.80504', '25.49515'),
+(2688, 2686, '马龙', '马龙县', '中国,云南省,曲靖市,马龙县', 3, 'malong', '0874', '655100', 'M', '103.57873', '25.42521'),
+(2689, 2686, '陆良', '陆良县', '中国,云南省,曲靖市,陆良县', 3, 'luliang', '0874', '655600', 'L', '103.6665', '25.02335'),
+(2690, 2686, '师宗', '师宗县', '中国,云南省,曲靖市,师宗县', 3, 'shizong', '0874', '655700', 'S', '103.99084', '24.82822'),
+(2691, 2686, '罗平', '罗平县', '中国,云南省,曲靖市,罗平县', 3, 'luoping', '0874', '655800', 'L', '104.30859', '24.88444'),
+(2692, 2686, '富源', '富源县', '中国,云南省,曲靖市,富源县', 3, 'fuyuan', '0874', '655500', 'F', '104.25387', '25.66587'),
+(2693, 2686, '会泽', '会泽县', '中国,云南省,曲靖市,会泽县', 3, 'huize', '0874', '654200', 'H', '103.30017', '26.41076'),
+(2694, 2686, '沾益', '沾益县', '中国,云南省,曲靖市,沾益县', 3, 'zhanyi', '0874', '655331', 'Z', '103.82135', '25.60715'),
+(2695, 2686, '宣威', '宣威市', '中国,云南省,曲靖市,宣威市', 3, 'xuanwei', '0874', '655400', 'X', '104.10409', '26.2173'),
+(2696, 2670, '玉溪', '玉溪市', '中国,云南省,玉溪市', 2, 'yuxi', '0877', '653100', 'Y', '102.543907', '24.350461'),
+(2697, 2696, '红塔', '红塔区', '中国,云南省,玉溪市,红塔区', 3, 'hongta', '0877', '653100', 'H', '102.5449', '24.35411'),
+(2698, 2696, '江川', '江川县', '中国,云南省,玉溪市,江川县', 3, 'jiangchuan', '0877', '652600', 'J', '102.75412', '24.28863'),
+(2699, 2696, '澄江', '澄江县', '中国,云南省,玉溪市,澄江县', 3, 'chengjiang', '0877', '652500', 'C', '102.90817', '24.67376'),
+(2700, 2696, '通海', '通海县', '中国,云南省,玉溪市,通海县', 3, 'tonghai', '0877', '652700', 'T', '102.76641', '24.11362'),
+(2701, 2696, '华宁', '华宁县', '中国,云南省,玉溪市,华宁县', 3, 'huaning', '0877', '652800', 'H', '102.92831', '24.1926'),
+(2702, 2696, '易门', '易门县', '中国,云南省,玉溪市,易门县', 3, 'yimen', '0877', '651100', 'Y', '102.16354', '24.67122'),
+(2703, 2696, '峨山', '峨山彝族自治县', '中国,云南省,玉溪市,峨山彝族自治县', 3, 'eshan', '0877', '653200', 'E', '102.40576', '24.16904'),
+(2704, 2696, '新平', '新平彝族傣族自治县', '中国,云南省,玉溪市,新平彝族傣族自治县', 3, 'xinping', '0877', '653400', 'X', '101.98895', '24.06886'),
+(2705, 2696, '元江', '元江哈尼族彝族傣族自治县', '中国,云南省,玉溪市,元江哈尼族彝族傣族自治县', 3, 'yuanjiang', '0877', '653300', 'Y', '101.99812', '23.59655'),
+(2706, 2670, '保山', '保山市', '中国,云南省,保山市', 2, 'baoshan', '0875', '678000', 'B', '99.167133', '25.111802'),
+(2707, 2706, '隆阳', '隆阳区', '中国,云南省,保山市,隆阳区', 3, 'longyang', '0875', '678000', 'L', '99.16334', '25.11163'),
+(2708, 2706, '施甸', '施甸县', '中国,云南省,保山市,施甸县', 3, 'shidian', '0875', '678200', 'S', '99.18768', '24.72418'),
+(2709, 2706, '腾冲', '腾冲县', '中国,云南省,保山市,腾冲县', 3, 'tengchong', '0875', '679100', 'T', '98.49414', '25.02539'),
+(2710, 2706, '龙陵', '龙陵县', '中国,云南省,保山市,龙陵县', 3, 'longling', '0875', '678300', 'L', '98.69024', '24.58746'),
+(2711, 2706, '昌宁', '昌宁县', '中国,云南省,保山市,昌宁县', 3, 'changning', '0875', '678100', 'C', '99.6036', '24.82763'),
+(2712, 2670, '昭通', '昭通市', '中国,云南省,昭通市', 2, 'zhaotong', '0870', '657000', 'Z', '103.717216', '27.336999'),
+(2713, 2712, '昭阳', '昭阳区', '中国,云南省,昭通市,昭阳区', 3, 'zhaoyang', '0870', '657000', 'Z', '103.70654', '27.31998'),
+(2714, 2712, '鲁甸', '鲁甸县', '中国,云南省,昭通市,鲁甸县', 3, 'ludian', '0870', '657100', 'L', '103.54721', '27.19238'),
+(2715, 2712, '巧家', '巧家县', '中国,云南省,昭通市,巧家县', 3, 'qiaojia', '0870', '654600', 'Q', '102.92416', '26.91237'),
+(2716, 2712, '盐津', '盐津县', '中国,云南省,昭通市,盐津县', 3, 'yanjin', '0870', '657500', 'Y', '104.23461', '28.10856'),
+(2717, 2712, '大关', '大关县', '中国,云南省,昭通市,大关县', 3, 'daguan', '0870', '657400', 'D', '103.89254', '27.7488'),
+(2718, 2712, '永善', '永善县', '中国,云南省,昭通市,永善县', 3, 'yongshan', '0870', '657300', 'Y', '103.63504', '28.2279'),
+(2719, 2712, '绥江', '绥江县', '中国,云南省,昭通市,绥江县', 3, 'suijiang', '0870', '657700', 'S', '103.94937', '28.59661'),
+(2720, 2712, '镇雄', '镇雄县', '中国,云南省,昭通市,镇雄县', 3, 'zhenxiong', '0870', '657200', 'Z', '104.87258', '27.43981'),
+(2721, 2712, '彝良', '彝良县', '中国,云南省,昭通市,彝良县', 3, 'yiliang', '0870', '657600', 'Y', '104.04983', '27.62809'),
+(2722, 2712, '威信', '威信县', '中国,云南省,昭通市,威信县', 3, 'weixin', '0870', '657900', 'W', '105.04754', '27.84065'),
+(2723, 2712, '水富', '水富县', '中国,云南省,昭通市,水富县', 3, 'shuifu', '0870', '657800', 'S', '104.4158', '28.62986'),
+(2724, 2670, '丽江', '丽江市', '中国,云南省,丽江市', 2, 'lijiang', '0888', '674100', 'L', '100.233026', '26.872108'),
+(2725, 2724, '古城', '古城区', '中国,云南省,丽江市,古城区', 3, 'gucheng', '0888', '674100', 'G', '100.2257', '26.87697'),
+(2726, 2724, '玉龙', '玉龙纳西族自治县', '中国,云南省,丽江市,玉龙纳西族自治县', 3, 'yulong', '0888', '674100', 'Y', '100.2369', '26.82149'),
+(2727, 2724, '永胜', '永胜县', '中国,云南省,丽江市,永胜县', 3, 'yongsheng', '0888', '674200', 'Y', '100.74667', '26.68591'),
+(2728, 2724, '华坪', '华坪县', '中国,云南省,丽江市,华坪县', 3, 'huaping', '0888', '674800', 'H', '101.26562', '26.62967'),
+(2729, 2724, '宁蒗', '宁蒗彝族自治县', '中国,云南省,丽江市,宁蒗彝族自治县', 3, 'ninglang', '0888', '674300', 'N', '100.8507', '27.28179'),
+(2730, 2670, '普洱', '普洱市', '中国,云南省,普洱市', 2, 'pu''er', '0879', '665000', 'P', '100.972344', '22.777321'),
+(2731, 2730, '思茅', '思茅区', '中国,云南省,普洱市,思茅区', 3, 'simao', '0879', '665000', 'S', '100.97716', '22.78691'),
+(2732, 2730, '宁洱', '宁洱哈尼族彝族自治县', '中国,云南省,普洱市,宁洱哈尼族彝族自治县', 3, 'ninger', '0879', '665100', 'N', '101.04653', '23.06341'),
+(2733, 2730, '墨江', '墨江哈尼族自治县', '中国,云南省,普洱市,墨江哈尼族自治县', 3, 'mojiang', '0879', '654800', 'M', '101.69171', '23.43214'),
+(2734, 2730, '景东', '景东彝族自治县', '中国,云南省,普洱市,景东彝族自治县', 3, 'jingdong', '0879', '676200', 'J', '100.83599', '24.44791'),
+(2735, 2730, '景谷', '景谷傣族彝族自治县', '中国,云南省,普洱市,景谷傣族彝族自治县', 3, 'jinggu', '0879', '666400', 'J', '100.70251', '23.49705'),
+(2736, 2730, '镇沅', '镇沅彝族哈尼族拉祜族自治县', '中国,云南省,普洱市,镇沅彝族哈尼族拉祜族自治县', 3, 'zhenyuan', '0879', '666500', 'Z', '101.10675', '24.00557'),
+(2737, 2730, '江城', '江城哈尼族彝族自治县', '中国,云南省,普洱市,江城哈尼族彝族自治县', 3, 'jiangcheng', '0879', '665900', 'J', '101.85788', '22.58424'),
+(2738, 2730, '孟连', '孟连傣族拉祜族佤族自治县', '中国,云南省,普洱市,孟连傣族拉祜族佤族自治县', 3, 'menglian', '0879', '665800', 'M', '99.58424', '22.32922'),
+(2739, 2730, '澜沧', '澜沧拉祜族自治县', '中国,云南省,普洱市,澜沧拉祜族自治县', 3, 'lancang', '0879', '665600', 'L', '99.93591', '22.55474'),
+(2740, 2730, '西盟', '西盟佤族自治县', '中国,云南省,普洱市,西盟佤族自治县', 3, 'ximeng', '0879', '665700', 'X', '99.59869', '22.64774'),
+(2741, 2670, '临沧', '临沧市', '中国,云南省,临沧市', 2, 'lincang', '0883', '677000', 'L', '100.08697', '23.886567'),
+(2742, 2741, '临翔', '临翔区', '中国,云南省,临沧市,临翔区', 3, 'linxiang', '0883', '677000', 'L', '100.08242', '23.89497'),
+(2743, 2741, '凤庆', '凤庆县', '中国,云南省,临沧市,凤庆县', 3, 'fengqing', '0883', '675900', 'F', '99.92837', '24.58034'),
+(2744, 2741, '云县', '云县', '中国,云南省,临沧市,云县', 3, 'yunxian', '0883', '675800', 'Y', '100.12808', '24.44675'),
+(2745, 2741, '永德', '永德县', '中国,云南省,临沧市,永德县', 3, 'yongde', '0883', '677600', 'Y', '99.25326', '24.0276'),
+(2746, 2741, '镇康', '镇康县', '中国,云南省,临沧市,镇康县', 3, 'zhenkang', '0883', '677704', 'Z', '98.8255', '23.76241'),
+(2747, 2741, '双江', '双江拉祜族佤族布朗族傣族自治县', '中国,云南省,临沧市,双江拉祜族佤族布朗族傣族自治县', 3, 'shuangjiang', '0883', '677300', 'S', '99.82769', '23.47349'),
+(2748, 2741, '耿马', '耿马傣族佤族自治县', '中国,云南省,临沧市,耿马傣族佤族自治县', 3, 'gengma', '0883', '677500', 'G', '99.39785', '23.53776'),
+(2749, 2741, '沧源', '沧源佤族自治县', '中国,云南省,临沧市,沧源佤族自治县', 3, 'cangyuan', '0883', '677400', 'C', '99.24545', '23.14821'),
+(2750, 2670, '楚雄', '楚雄彝族自治州', '中国,云南省,楚雄彝族自治州', 2, 'chuxiong', '0878', '675000', 'C', '101.546046', '25.041988'),
+(2751, 2750, '楚雄', '楚雄市', '中国,云南省,楚雄彝族自治州,楚雄市', 3, 'chuxiong', '0878', '675000', 'C', '101.54615', '25.0329'),
+(2752, 2750, '双柏', '双柏县', '中国,云南省,楚雄彝族自治州,双柏县', 3, 'shuangbai', '0878', '675100', 'S', '101.64205', '24.68882'),
+(2753, 2750, '牟定', '牟定县', '中国,云南省,楚雄彝族自治州,牟定县', 3, 'mouding', '0878', '675500', 'M', '101.54', '25.31551'),
+(2754, 2750, '南华', '南华县', '中国,云南省,楚雄彝族自治州,南华县', 3, 'nanhua', '0878', '675200', 'N', '101.27313', '25.19293'),
+(2755, 2750, '姚安', '姚安县', '中国,云南省,楚雄彝族自治州,姚安县', 3, 'yao''an', '0878', '675300', 'Y', '101.24279', '25.50467'),
+(2756, 2750, '大姚', '大姚县', '中国,云南省,楚雄彝族自治州,大姚县', 3, 'dayao', '0878', '675400', 'D', '101.32397', '25.72218'),
+(2757, 2750, '永仁', '永仁县', '中国,云南省,楚雄彝族自治州,永仁县', 3, 'yongren', '0878', '651400', 'Y', '101.6716', '26.05794'),
+(2758, 2750, '元谋', '元谋县', '中国,云南省,楚雄彝族自治州,元谋县', 3, 'yuanmou', '0878', '651300', 'Y', '101.87728', '25.70438'),
+(2759, 2750, '武定', '武定县', '中国,云南省,楚雄彝族自治州,武定县', 3, 'wuding', '0878', '651600', 'W', '102.4038', '25.5295'),
+(2760, 2750, '禄丰', '禄丰县', '中国,云南省,楚雄彝族自治州,禄丰县', 3, 'lufeng', '0878', '651200', 'L', '102.07797', '25.14815'),
+(2761, 2670, '红河', '红河哈尼族彝族自治州', '中国,云南省,红河哈尼族彝族自治州', 2, 'honghe', '0873', '661400', 'H', '103.384182', '23.366775'),
+(2762, 2761, '个旧', '个旧市', '中国,云南省,红河哈尼族彝族自治州,个旧市', 3, 'gejiu', '0873', '661000', 'G', '103.15966', '23.35894'),
+(2763, 2761, '开远', '开远市', '中国,云南省,红河哈尼族彝族自治州,开远市', 3, 'kaiyuan', '0873', '661600', 'K', '103.26986', '23.71012'),
+(2764, 2761, '蒙自', '蒙自市', '中国,云南省,红河哈尼族彝族自治州,蒙自市', 3, 'mengzi', '0873', '661101', 'M', '103.385005', '23.366843'),
+(2765, 2761, '弥勒', '弥勒市', '中国,云南省,红河哈尼族彝族自治州,弥勒市', 3, 'mile', '0873', '652300', 'M', '103.436988', '24.40837'),
+(2766, 2761, '屏边', '屏边苗族自治县', '中国,云南省,红河哈尼族彝族自治州,屏边苗族自治县', 3, 'pingbian', '0873', '661200', 'P', '103.68554', '22.98425'),
+(2767, 2761, '建水', '建水县', '中国,云南省,红河哈尼族彝族自治州,建水县', 3, 'jianshui', '0873', '654300', 'J', '102.82656', '23.63472'),
+(2768, 2761, '石屏', '石屏县', '中国,云南省,红河哈尼族彝族自治州,石屏县', 3, 'shiping', '0873', '662200', 'S', '102.49408', '23.71441'),
+(2769, 2761, '泸西', '泸西县', '中国,云南省,红河哈尼族彝族自治州,泸西县', 3, 'luxi', '0873', '652400', NULL, '103.76373', '24.52854'),
+(2770, 2761, '元阳', '元阳县', '中国,云南省,红河哈尼族彝族自治州,元阳县', 3, 'yuanyang', '0873', '662400', 'Y', '102.83261', '23.22281'),
+(2771, 2761, '红河县', '红河县', '中国,云南省,红河哈尼族彝族自治州,红河县', 3, 'honghexian', '0873', '654400', 'H', '102.42059', '23.36767'),
+(2772, 2761, '金平', '金平苗族瑶族傣族自治县', '中国,云南省,红河哈尼族彝族自治州,金平苗族瑶族傣族自治县', 3, 'jinping', '0873', '661500', 'J', '103.22651', '22.77959'),
+(2773, 2761, '绿春', '绿春县', '中国,云南省,红河哈尼族彝族自治州,绿春县', 3, 'lvchun', '0873', '662500', 'L', '102.39672', '22.99371'),
+(2774, 2761, '河口', '河口瑶族自治县', '中国,云南省,红河哈尼族彝族自治州,河口瑶族自治县', 3, 'hekou', '0873', '661300', 'H', '103.93936', '22.52929'),
+(2775, 2670, '文山', '文山壮族苗族自治州', '中国,云南省,文山壮族苗族自治州', 2, 'wenshan', '0876', '663000', 'W', '104.24401', '23.36951'),
+(2776, 2775, '文山', '文山市', '中国,云南省,文山壮族苗族自治州,文山市', 3, 'wenshan', '0876', '663000', 'W', '104.244277', '23.369216'),
+(2777, 2775, '砚山', '砚山县', '中国,云南省,文山壮族苗族自治州,砚山县', 3, 'yanshan', '0876', '663100', 'Y', '104.33306', '23.60723'),
+(2778, 2775, '西畴', '西畴县', '中国,云南省,文山壮族苗族自治州,西畴县', 3, 'xichou', '0876', '663500', 'X', '104.67419', '23.43941'),
+(2779, 2775, '麻栗坡', '麻栗坡县', '中国,云南省,文山壮族苗族自治州,麻栗坡县', 3, 'malipo', '0876', '663600', 'M', '104.70132', '23.12028'),
+(2780, 2775, '马关', '马关县', '中国,云南省,文山壮族苗族自治州,马关县', 3, 'maguan', '0876', '663700', 'M', '104.39514', '23.01293'),
+(2781, 2775, '丘北', '丘北县', '中国,云南省,文山壮族苗族自治州,丘北县', 3, 'qiubei', '0876', '663200', 'Q', '104.19256', '24.03957'),
+(2782, 2775, '广南', '广南县', '中国,云南省,文山壮族苗族自治州,广南县', 3, 'guangnan', '0876', '663300', 'G', '105.05511', '24.0464'),
+(2783, 2775, '富宁', '富宁县', '中国,云南省,文山壮族苗族自治州,富宁县', 3, 'funing', '0876', '663400', 'F', '105.63085', '23.62536'),
+(2784, 2670, '西双版纳', '西双版纳傣族自治州', '中国,云南省,西双版纳傣族自治州', 2, 'xishuangbanna', '0691', '666100', 'X', '100.797941', '22.001724'),
+(2785, 2784, '景洪', '景洪市', '中国,云南省,西双版纳傣族自治州,景洪市', 3, 'jinghong', '0691', '666100', 'J', '100.79977', '22.01071'),
+(2786, 2784, '勐海', '勐海县', '中国,云南省,西双版纳傣族自治州,勐海县', 3, 'menghai', '0691', '666200', NULL, '100.44931', '21.96175'),
+(2787, 2784, '勐腊', '勐腊县', '中国,云南省,西双版纳傣族自治州,勐腊县', 3, 'mengla', '0691', '666300', NULL, '101.56488', '21.48162'),
+(2788, 2670, '大理', '大理白族自治州', '中国,云南省,大理白族自治州', 2, 'dali', '0872', '671000', 'D', '100.240037', '25.592765'),
+(2789, 2788, '大理', '大理市', '中国,云南省,大理白族自治州,大理市', 3, 'dali', '0872', '671000', 'D', '100.22998', '25.59157'),
+(2790, 2788, '漾濞', '漾濞彝族自治县', '中国,云南省,大理白族自治州,漾濞彝族自治县', 3, 'yangbi', '0872', '672500', 'Y', '99.95474', '25.6652'),
+(2791, 2788, '祥云', '祥云县', '中国,云南省,大理白族自治州,祥云县', 3, 'xiangyun', '0872', '672100', 'X', '100.55761', '25.47342'),
+(2792, 2788, '宾川', '宾川县', '中国,云南省,大理白族自治州,宾川县', 3, 'binchuan', '0872', '671600', 'B', '100.57666', '25.83144'),
+(2793, 2788, '弥渡', '弥渡县', '中国,云南省,大理白族自治州,弥渡县', 3, 'midu', '0872', '675600', 'M', '100.49075', '25.34179'),
+(2794, 2788, '南涧', '南涧彝族自治县', '中国,云南省,大理白族自治州,南涧彝族自治县', 3, 'nanjian', '0872', '675700', 'N', '100.50964', '25.04349'),
+(2795, 2788, '巍山', '巍山彝族回族自治县', '中国,云南省,大理白族自治州,巍山彝族回族自治县', 3, 'weishan', '0872', '672400', 'W', '100.30612', '25.23197'),
+(2796, 2788, '永平', '永平县', '中国,云南省,大理白族自治州,永平县', 3, 'yongping', '0872', '672600', 'Y', '99.54095', '25.46451'),
+(2797, 2788, '云龙', '云龙县', '中国,云南省,大理白族自治州,云龙县', 3, 'yunlong', '0872', '672700', 'Y', '99.37255', '25.88505'),
+(2798, 2788, '洱源', '洱源县', '中国,云南省,大理白族自治州,洱源县', 3, 'eryuan', '0872', '671200', 'E', '99.94903', '26.10829'),
+(2799, 2788, '剑川', '剑川县', '中国,云南省,大理白族自治州,剑川县', 3, 'jianchuan', '0872', '671300', 'J', '99.90545', '26.53688'),
+(2800, 2788, '鹤庆', '鹤庆县', '中国,云南省,大理白族自治州,鹤庆县', 3, 'heqing', '0872', '671500', 'H', '100.17697', '26.55798'),
+(2801, 2670, '德宏', '德宏傣族景颇族自治州', '中国,云南省,德宏傣族景颇族自治州', 2, 'dehong', '0692', '678400', 'D', '98.578363', '24.436694'),
+(2802, 2801, '瑞丽', '瑞丽市', '中国,云南省,德宏傣族景颇族自治州,瑞丽市', 3, 'ruili', '0692', '678600', 'R', '97.85183', '24.01277'),
+(2803, 2801, '芒市', '芒市', '中国,云南省,德宏傣族景颇族自治州,芒市', 3, 'mangshi', '0692', '678400', 'M', '98.588641', '24.433735'),
+(2804, 2801, '梁河', '梁河县', '中国,云南省,德宏傣族景颇族自治州,梁河县', 3, 'lianghe', '0692', '679200', 'L', '98.29705', '24.80658'),
+(2805, 2801, '盈江', '盈江县', '中国,云南省,德宏傣族景颇族自治州,盈江县', 3, 'yingjiang', '0692', '679300', 'Y', '97.93179', '24.70579'),
+(2806, 2801, '陇川', '陇川县', '中国,云南省,德宏傣族景颇族自治州,陇川县', 3, 'longchuan', '0692', '678700', 'L', '97.79199', '24.18302'),
+(2807, 2670, '怒江', '怒江傈僳族自治州', '中国,云南省,怒江傈僳族自治州', 2, 'nujiang', '0886', '673100', 'N', '98.854304', '25.850949'),
+(2808, 2807, '泸水', '泸水县', '中国,云南省,怒江傈僳族自治州,泸水县', 3, 'lushui', '0886', '673100', NULL, '98.85534', '25.83772'),
+(2809, 2807, '福贡', '福贡县', '中国,云南省,怒江傈僳族自治州,福贡县', 3, 'fugong', '0886', '673400', 'F', '98.86969', '26.90366'),
+(2810, 2807, '贡山', '贡山独龙族怒族自治县', '中国,云南省,怒江傈僳族自治州,贡山独龙族怒族自治县', 3, 'gongshan', '0886', '673500', 'G', '98.66583', '27.74088'),
+(2811, 2807, '兰坪', '兰坪白族普米族自治县', '中国,云南省,怒江傈僳族自治州,兰坪白族普米族自治县', 3, 'lanping', '0886', '671400', 'L', '99.41891', '26.45251'),
+(2812, 2670, '迪庆', '迪庆藏族自治州', '中国,云南省,迪庆藏族自治州', 2, 'deqen', '0887', '674400', 'D', '99.706463', '27.826853'),
+(2813, 2812, '香格里拉', '香格里拉市', '中国,云南省,迪庆藏族自治州,香格里拉市', 3, 'xianggelila', '0887', '674400', 'X', '99.70601', '27.82308'),
+(2814, 2812, '德钦', '德钦县', '中国,云南省,迪庆藏族自治州,德钦县', 3, 'deqin', '0887', '674500', 'D', '98.91082', '28.4863'),
+(2815, 2812, '维西', '维西傈僳族自治县', '中国,云南省,迪庆藏族自治州,维西傈僳族自治县', 3, 'weixi', '0887', '674600', 'W', '99.28402', '27.1793'),
+(2816, 0, '西藏', '西藏自治区', '中国,西藏自治区', 1, 'tibet', '', '', 'X', '91.132212', '29.660361'),
+(2817, 2816, '拉萨', '拉萨市', '中国,西藏自治区,拉萨市', 2, 'lhasa', '0891', '850000', 'L', '91.132212', '29.660361'),
+(2818, 2817, '城关', '城关区', '中国,西藏自治区,拉萨市,城关区', 3, 'chengguan', '0891', '850000', 'C', '91.13859', '29.65312'),
+(2819, 2817, '林周', '林周县', '中国,西藏自治区,拉萨市,林周县', 3, 'linzhou', '0891', '851600', 'L', '91.2586', '29.89445'),
+(2820, 2817, '当雄', '当雄县', '中国,西藏自治区,拉萨市,当雄县', 3, 'dangxiong', '0891', '851500', 'D', '91.10076', '30.48309'),
+(2821, 2817, '尼木', '尼木县', '中国,西藏自治区,拉萨市,尼木县', 3, 'nimu', '0891', '851300', 'N', '90.16378', '29.43353'),
+(2822, 2817, '曲水', '曲水县', '中国,西藏自治区,拉萨市,曲水县', 3, 'qushui', '0891', '850600', 'Q', '90.73187', '29.35636'),
+(2823, 2817, '堆龙德庆', '堆龙德庆县', '中国,西藏自治区,拉萨市,堆龙德庆县', 3, 'duilongdeqing', '0891', '851400', 'D', '91.00033', '29.65002'),
+(2824, 2817, '达孜', '达孜县', '中国,西藏自治区,拉萨市,达孜县', 3, 'dazi', '0891', '850100', 'D', '91.35757', '29.6722'),
+(2825, 2817, '墨竹工卡', '墨竹工卡县', '中国,西藏自治区,拉萨市,墨竹工卡县', 3, 'mozhugongka', '0891', '850200', 'M', '91.72814', '29.83614'),
+(2826, 2816, '日喀则', '日喀则市', '中国,西藏自治区,日喀则市', 2, 'rikaze', '0892', '857000', 'R', '88.884874', '29.263792'),
+(2827, 2826, '桑珠孜', '桑珠孜区', '中国,西藏自治区,日喀则市,桑珠孜区', 3, 'sangzhuzi', '0892', '857000', 'S', '88.880367', '29.269565'),
+(2828, 2826, '南木林', '南木林县', '中国,西藏自治区,日喀则市,南木林县', 3, 'nanmulin', '0892', '857100', 'N', '89.09686', '29.68206'),
+(2829, 2826, '江孜', '江孜县', '中国,西藏自治区,日喀则市,江孜县', 3, 'jiangzi', '0892', '857400', 'J', '89.60263', '28.91744'),
+(2830, 2826, '定日', '定日县', '中国,西藏自治区,日喀则市,定日县', 3, 'dingri', '0892', '858200', 'D', '87.12176', '28.66129'),
+(2831, 2826, '萨迦', '萨迦县', '中国,西藏自治区,日喀则市,萨迦县', 3, 'sajia', '0892', '857800', 'S', '88.02191', '28.90299'),
+(2832, 2826, '拉孜', '拉孜县', '中国,西藏自治区,日喀则市,拉孜县', 3, 'lazi', '0892', '858100', 'L', '87.63412', '29.085'),
+(2833, 2826, '昂仁', '昂仁县', '中国,西藏自治区,日喀则市,昂仁县', 3, 'angren', '0892', '858500', 'A', '87.23858', '29.29496'),
+(2834, 2826, '谢通门', '谢通门县', '中国,西藏自治区,日喀则市,谢通门县', 3, 'xietongmen', '0892', '858900', 'X', '88.26242', '29.43337'),
+(2835, 2826, '白朗', '白朗县', '中国,西藏自治区,日喀则市,白朗县', 3, 'bailang', '0892', '857300', 'B', '89.26205', '29.10553'),
+(2836, 2826, '仁布', '仁布县', '中国,西藏自治区,日喀则市,仁布县', 3, 'renbu', '0892', '857200', 'R', '89.84228', '29.2301'),
+(2837, 2826, '康马', '康马县', '中国,西藏自治区,日喀则市,康马县', 3, 'kangma', '0892', '857500', 'K', '89.68527', '28.5567'),
+(2838, 2826, '定结', '定结县', '中国,西藏自治区,日喀则市,定结县', 3, 'dingjie', '0892', '857900', 'D', '87.77255', '28.36403');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(2839, 2826, '仲巴', '仲巴县', '中国,西藏自治区,日喀则市,仲巴县', 3, 'zhongba', '0892', '858800', 'Z', '84.02951', '29.76595'),
+(2840, 2826, '亚东', '亚东县', '中国,西藏自治区,日喀则市,亚东县', 3, 'yadong', '0892', '857600', 'Y', '88.90802', '27.4839'),
+(2841, 2826, '吉隆', '吉隆县', '中国,西藏自治区,日喀则市,吉隆县', 3, 'jilong', '0892', '858700', 'J', '85.29846', '28.85382'),
+(2842, 2826, '聂拉木', '聂拉木县', '中国,西藏自治区,日喀则市,聂拉木县', 3, 'nielamu', '0892', '858300', 'N', '85.97998', '28.15645'),
+(2843, 2826, '萨嘎', '萨嘎县', '中国,西藏自治区,日喀则市,萨嘎县', 3, 'saga', '0892', '857800', 'S', '85.23413', '29.32936'),
+(2844, 2826, '岗巴', '岗巴县', '中国,西藏自治区,日喀则市,岗巴县', 3, 'gangba', '0892', '857700', 'G', '88.52069', '28.27504'),
+(2845, 2816, '昌都', '昌都市', '中国,西藏自治区,昌都市', 2, 'qamdo', '0895', '854000', 'C', '97.178452', '31.136875'),
+(2846, 2845, '昌都', '卡若区', '中国,西藏自治区,昌都市,卡若区', 3, 'karuo', '0895', '854000', 'K', '97.18043', '31.1385'),
+(2847, 2845, '江达', '江达县', '中国,西藏自治区,昌都市,江达县', 3, 'jiangda', '0895', '854100', 'J', '98.21865', '31.50343'),
+(2848, 2845, '贡觉', '贡觉县', '中国,西藏自治区,昌都市,贡觉县', 3, 'gongjue', '0895', '854200', 'G', '98.27163', '30.85941'),
+(2849, 2845, '类乌齐', '类乌齐县', '中国,西藏自治区,昌都市,类乌齐县', 3, 'leiwuqi', '0895', '855600', 'L', '96.60015', '31.21207'),
+(2850, 2845, '丁青', '丁青县', '中国,西藏自治区,昌都市,丁青县', 3, 'dingqing', '0895', '855700', 'D', '95.59362', '31.41621'),
+(2851, 2845, '察雅', '察雅县', '中国,西藏自治区,昌都市,察雅县', 3, 'chaya', '0895', '854300', 'C', '97.56521', '30.65336'),
+(2852, 2845, '八宿', '八宿县', '中国,西藏自治区,昌都市,八宿县', 3, 'basu', '0895', '854600', 'B', '96.9176', '30.05346'),
+(2853, 2845, '左贡', '左贡县', '中国,西藏自治区,昌都市,左贡县', 3, 'zuogong', '0895', '854400', 'Z', '97.84429', '29.67108'),
+(2854, 2845, '芒康', '芒康县', '中国,西藏自治区,昌都市,芒康县', 3, 'mangkang', '0895', '854500', 'M', '98.59378', '29.67946'),
+(2855, 2845, '洛隆', '洛隆县', '中国,西藏自治区,昌都市,洛隆县', 3, 'luolong', '0895', '855400', 'L', '95.82644', '30.74049'),
+(2856, 2845, '边坝', '边坝县', '中国,西藏自治区,昌都市,边坝县', 3, 'bianba', '0895', '855500', 'B', '94.70687', '30.93434'),
+(2857, 2816, '山南', '山南地区', '中国,西藏自治区,山南地区', 2, 'shannan', '0893', '856000', 'S', '91.766529', '29.236023'),
+(2858, 2857, '乃东', '乃东县', '中国,西藏自治区,山南地区,乃东县', 3, 'naidong', '0893', '856100', 'N', '91.76153', '29.2249'),
+(2859, 2857, '扎囊', '扎囊县', '中国,西藏自治区,山南地区,扎囊县', 3, 'zhanang', '0893', '850800', 'Z', '91.33288', '29.2399'),
+(2860, 2857, '贡嘎', '贡嘎县', '中国,西藏自治区,山南地区,贡嘎县', 3, 'gongga', '0893', '850700', 'G', '90.98867', '29.29408'),
+(2861, 2857, '桑日', '桑日县', '中国,西藏自治区,山南地区,桑日县', 3, 'sangri', '0893', '856200', 'S', '92.02005', '29.26643'),
+(2862, 2857, '琼结', '琼结县', '中国,西藏自治区,山南地区,琼结县', 3, 'qiongjie', '0893', '856800', 'Q', '91.68093', '29.02632'),
+(2863, 2857, '曲松', '曲松县', '中国,西藏自治区,山南地区,曲松县', 3, 'qusong', '0893', '856300', 'Q', '92.20263', '29.06412'),
+(2864, 2857, '措美', '措美县', '中国,西藏自治区,山南地区,措美县', 3, 'cuomei', '0893', '856900', 'C', '91.43237', '28.43794'),
+(2865, 2857, '洛扎', '洛扎县', '中国,西藏自治区,山南地区,洛扎县', 3, 'luozha', '0893', '856600', 'L', '90.86035', '28.3872'),
+(2866, 2857, '加查', '加查县', '中国,西藏自治区,山南地区,加查县', 3, 'jiacha', '0893', '856400', 'J', '92.57702', '29.13973'),
+(2867, 2857, '隆子', '隆子县', '中国,西藏自治区,山南地区,隆子县', 3, 'longzi', '0893', '856600', 'L', '92.46148', '28.40797'),
+(2868, 2857, '错那', '错那县', '中国,西藏自治区,山南地区,错那县', 3, 'cuona', '0893', '856700', 'C', '91.95752', '27.99224'),
+(2869, 2857, '浪卡子', '浪卡子县', '中国,西藏自治区,山南地区,浪卡子县', 3, 'langkazi', '0893', '851100', 'L', '90.40002', '28.96948'),
+(2870, 2816, '那曲', '那曲地区', '中国,西藏自治区,那曲地区', 2, 'nagqu', '0896', '852000', 'N', '92.060214', '31.476004'),
+(2871, 2870, '那曲', '那曲县', '中国,西藏自治区,那曲地区,那曲县', 3, 'naqu', '0896', '852000', 'N', '92.0535', '31.46964'),
+(2872, 2870, '嘉黎', '嘉黎县', '中国,西藏自治区,那曲地区,嘉黎县', 3, 'jiali', '0896', '852400', 'J', '93.24987', '30.64233'),
+(2873, 2870, '比如', '比如县', '中国,西藏自治区,那曲地区,比如县', 3, 'biru', '0896', '852300', 'B', '93.68685', '31.4779'),
+(2874, 2870, '聂荣', '聂荣县', '中国,西藏自治区,那曲地区,聂荣县', 3, 'nierong', '0896', '853500', 'N', '92.29574', '32.11193'),
+(2875, 2870, '安多', '安多县', '中国,西藏自治区,那曲地区,安多县', 3, 'anduo', '0896', '853400', 'A', '91.6795', '32.26125'),
+(2876, 2870, '申扎', '申扎县', '中国,西藏自治区,那曲地区,申扎县', 3, 'shenzha', '0896', '853100', 'S', '88.70776', '30.92995'),
+(2877, 2870, '索县', '索县', '中国,西藏自治区,那曲地区,索县', 3, 'suoxian', '0896', '852200', 'S', '93.78295', '31.88427'),
+(2878, 2870, '班戈', '班戈县', '中国,西藏自治区,那曲地区,班戈县', 3, 'bange', '0896', '852500', 'B', '90.01907', '31.36149'),
+(2879, 2870, '巴青', '巴青县', '中国,西藏自治区,那曲地区,巴青县', 3, 'baqing', '0896', '852100', 'B', '94.05316', '31.91833'),
+(2880, 2870, '尼玛', '尼玛县', '中国,西藏自治区,那曲地区,尼玛县', 3, 'nima', '0896', '852600', 'N', '87.25256', '31.79654'),
+(2881, 2870, '双湖', '双湖县', '中国,西藏自治区,那曲地区,双湖县', 3, 'shuanghu', '0896', '852600', 'S', '88.837776', '33.189032'),
+(2882, 2816, '阿里', '阿里地区', '中国,西藏自治区,阿里地区', 2, 'ngari', '0897', '859000', 'A', '80.105498', '32.503187'),
+(2883, 2882, '普兰', '普兰县', '中国,西藏自治区,阿里地区,普兰县', 3, 'pulan', '0897', '859500', 'P', '81.177', '30.30002'),
+(2884, 2882, '札达', '札达县', '中国,西藏自治区,阿里地区,札达县', 3, 'zhada', '0897', '859600', 'Z', '79.80255', '31.48345'),
+(2885, 2882, '噶尔', '噶尔县', '中国,西藏自治区,阿里地区,噶尔县', 3, 'gaer', '0897', '859400', 'G', '80.09579', '32.50024'),
+(2886, 2882, '日土', '日土县', '中国,西藏自治区,阿里地区,日土县', 3, 'ritu', '0897', '859700', 'R', '79.7131', '33.38741'),
+(2887, 2882, '革吉', '革吉县', '中国,西藏自治区,阿里地区,革吉县', 3, 'geji', '0897', '859100', 'G', '81.151', '32.3964'),
+(2888, 2882, '改则', '改则县', '中国,西藏自治区,阿里地区,改则县', 3, 'gaize', '0897', '859200', 'G', '84.06295', '32.30446'),
+(2889, 2882, '措勤', '措勤县', '中国,西藏自治区,阿里地区,措勤县', 3, 'cuoqin', '0897', '859300', 'C', '85.16616', '31.02095'),
+(2890, 2816, '林芝', '林芝地区', '中国,西藏自治区,林芝地区', 2, 'nyingchi', '0894', '850400', 'L', '94.362348', '29.654693'),
+(2891, 2890, '林芝', '林芝县', '中国,西藏自治区,林芝地区,林芝县', 3, 'linzhi', '0894', '850400', 'L', '94.48391', '29.57562'),
+(2892, 2890, '工布江达', '工布江达县', '中国,西藏自治区,林芝地区,工布江达县', 3, 'gongbujiangda', '0894', '850300', 'G', '93.2452', '29.88576'),
+(2893, 2890, '米林', '米林县', '中国,西藏自治区,林芝地区,米林县', 3, 'milin', '0894', '850500', 'M', '94.21316', '29.21535'),
+(2894, 2890, '墨脱', '墨脱县', '中国,西藏自治区,林芝地区,墨脱县', 3, 'motuo', '0894', '855300', 'M', '95.3316', '29.32698'),
+(2895, 2890, '波密', '波密县', '中国,西藏自治区,林芝地区,波密县', 3, 'bomi', '0894', '855200', 'B', '95.77096', '29.85907'),
+(2896, 2890, '察隅', '察隅县', '中国,西藏自治区,林芝地区,察隅县', 3, 'chayu', '0894', '855100', 'C', '97.46679', '28.6618'),
+(2897, 2890, '朗县', '朗县', '中国,西藏自治区,林芝地区,朗县', 3, 'langxian', '0894', '856500', 'L', '93.0754', '29.04549'),
+(2898, 0, '陕西', '陕西省', '中国,陕西省', 1, 'shaanxi', '', '', 'S', '108.948024', '34.263161'),
+(2899, 2898, '西安', '西安市', '中国,陕西省,西安市', 2, 'xi''an', '029', '710003', 'X', '108.948024', '34.263161'),
+(2900, 2899, '新城', '新城区', '中国,陕西省,西安市,新城区', 3, 'xincheng', '029', '710004', 'X', '108.9608', '34.26641'),
+(2901, 2899, '碑林', '碑林区', '中国,陕西省,西安市,碑林区', 3, 'beilin', '029', '710001', 'B', '108.93426', '34.2304'),
+(2902, 2899, '莲湖', '莲湖区', '中国,陕西省,西安市,莲湖区', 3, 'lianhu', '029', '710003', 'L', '108.9401', '34.26709'),
+(2903, 2899, '灞桥', '灞桥区', '中国,陕西省,西安市,灞桥区', 3, 'baqiao', '029', '710038', NULL, '109.06451', '34.27264'),
+(2904, 2899, '未央', '未央区', '中国,陕西省,西安市,未央区', 3, 'weiyang', '029', '710014', 'W', '108.94683', '34.29296'),
+(2905, 2899, '雁塔', '雁塔区', '中国,陕西省,西安市,雁塔区', 3, 'yanta', '029', '710061', 'Y', '108.94866', '34.22245'),
+(2906, 2899, '阎良', '阎良区', '中国,陕西省,西安市,阎良区', 3, 'yanliang', '029', '710087', 'Y', '109.22616', '34.66221'),
+(2907, 2899, '临潼', '临潼区', '中国,陕西省,西安市,临潼区', 3, 'lintong', '029', '710600', 'L', '109.21417', '34.36665'),
+(2908, 2899, '长安', '长安区', '中国,陕西省,西安市,长安区', 3, 'chang''an', '029', '710100', 'C', '108.94586', '34.15559'),
+(2909, 2899, '蓝田', '蓝田县', '中国,陕西省,西安市,蓝田县', 3, 'lantian', '029', '710500', 'L', '109.32339', '34.15128'),
+(2910, 2899, '周至', '周至县', '中国,陕西省,西安市,周至县', 3, 'zhouzhi', '029', '710400', 'Z', '108.22207', '34.16337'),
+(2911, 2899, '户县', '户县', '中国,陕西省,西安市,户县', 3, 'huxian', '029', '710300', 'H', '108.60513', '34.10856'),
+(2912, 2899, '高陵', '高陵区', '中国,陕西省,西安市,高陵区', 3, 'gaoling', '029', '710200', 'G', '109.08816', '34.53483'),
+(2913, 2898, '铜川', '铜川市', '中国,陕西省,铜川市', 2, 'tongchuan', '0919', '727100', 'T', '108.963122', '34.90892'),
+(2914, 2913, '王益', '王益区', '中国,陕西省,铜川市,王益区', 3, 'wangyi', '0919', '727000', 'W', '109.07564', '35.06896'),
+(2915, 2913, '印台', '印台区', '中国,陕西省,铜川市,印台区', 3, 'yintai', '0919', '727007', 'Y', '109.10208', '35.1169'),
+(2916, 2913, '耀州', '耀州区', '中国,陕西省,铜川市,耀州区', 3, 'yaozhou', '0919', '727100', 'Y', '108.98556', '34.91308'),
+(2917, 2913, '宜君', '宜君县', '中国,陕西省,铜川市,宜君县', 3, 'yijun', '0919', '727200', 'Y', '109.11813', '35.40108'),
+(2918, 2898, '宝鸡', '宝鸡市', '中国,陕西省,宝鸡市', 2, 'baoji', '0917', '721000', 'B', '107.14487', '34.369315'),
+(2919, 2918, '渭滨', '渭滨区', '中国,陕西省,宝鸡市,渭滨区', 3, 'weibin', '0917', '721000', 'W', '107.14991', '34.37116'),
+(2920, 2918, '金台', '金台区', '中国,陕西省,宝鸡市,金台区', 3, 'jintai', '0917', '721000', 'J', '107.14691', '34.37612'),
+(2921, 2918, '陈仓', '陈仓区', '中国,陕西省,宝鸡市,陈仓区', 3, 'chencang', '0917', '721300', 'C', '107.38742', '34.35451'),
+(2922, 2918, '凤翔', '凤翔县', '中国,陕西省,宝鸡市,凤翔县', 3, 'fengxiang', '0917', '721400', 'F', '107.39645', '34.52321'),
+(2923, 2918, '岐山', '岐山县', '中国,陕西省,宝鸡市,岐山县', 3, 'qishan', '0917', '722400', NULL, '107.62173', '34.44378'),
+(2924, 2918, '扶风', '扶风县', '中国,陕西省,宝鸡市,扶风县', 3, 'fufeng', '0917', '722200', 'F', '107.90017', '34.37524'),
+(2925, 2918, '眉县', '眉县', '中国,陕西省,宝鸡市,眉县', 3, 'meixian', '0917', '722300', 'M', '107.75079', '34.27569'),
+(2926, 2918, '陇县', '陇县', '中国,陕西省,宝鸡市,陇县', 3, 'longxian', '0917', '721200', 'L', '106.85946', '34.89404'),
+(2927, 2918, '千阳', '千阳县', '中国,陕西省,宝鸡市,千阳县', 3, 'qianyang', '0917', '721100', 'Q', '107.13043', '34.64219'),
+(2928, 2918, '麟游', '麟游县', '中国,陕西省,宝鸡市,麟游县', 3, 'linyou', '0917', '721500', NULL, '107.79623', '34.67844'),
+(2929, 2918, '凤县', '凤县', '中国,陕西省,宝鸡市,凤县', 3, 'fengxian', '0917', '721700', 'F', '106.52356', '33.91172'),
+(2930, 2918, '太白', '太白县', '中国,陕西省,宝鸡市,太白县', 3, 'taibai', '0917', '721600', 'T', '107.31646', '34.06207'),
+(2931, 2898, '咸阳', '咸阳市', '中国,陕西省,咸阳市', 2, 'xianyang', '029', '712000', 'X', '108.705117', '34.333439'),
+(2932, 2931, '秦都', '秦都区', '中国,陕西省,咸阳市,秦都区', 3, 'qindu', '029', '712000', 'Q', '108.71493', '34.33804'),
+(2933, 2931, '杨陵', '杨陵区', '中国,陕西省,咸阳市,杨陵区', 3, 'yangling', '029', '712100', 'Y', '108.083481', '34.270434'),
+(2934, 2931, '渭城', '渭城区', '中国,陕西省,咸阳市,渭城区', 3, 'weicheng', '029', '712000', 'W', '108.72227', '34.33198'),
+(2935, 2931, '三原', '三原县', '中国,陕西省,咸阳市,三原县', 3, 'sanyuan', '029', '713800', 'S', '108.93194', '34.61556'),
+(2936, 2931, '泾阳', '泾阳县', '中国,陕西省,咸阳市,泾阳县', 3, 'jingyang', '029', '713700', NULL, '108.84259', '34.52705'),
+(2937, 2931, '乾县', '乾县', '中国,陕西省,咸阳市,乾县', 3, 'qianxian', '029', '713300', 'Q', '108.24231', '34.52946'),
+(2938, 2931, '礼泉', '礼泉县', '中国,陕西省,咸阳市,礼泉县', 3, 'liquan', '029', '713200', 'L', '108.4263', '34.48455'),
+(2939, 2931, '永寿', '永寿县', '中国,陕西省,咸阳市,永寿县', 3, 'yongshou', '029', '713400', 'Y', '108.14474', '34.69081'),
+(2940, 2931, '彬县', '彬县', '中国,陕西省,咸阳市,彬县', 3, 'binxian', '029', '713500', 'B', '108.08468', '35.0342'),
+(2941, 2931, '长武', '长武县', '中国,陕西省,咸阳市,长武县', 3, 'changwu', '029', '713600', 'C', '107.7951', '35.2067'),
+(2942, 2931, '旬邑', '旬邑县', '中国,陕西省,咸阳市,旬邑县', 3, 'xunyi', '029', '711300', 'X', '108.3341', '35.11338'),
+(2943, 2931, '淳化', '淳化县', '中国,陕西省,咸阳市,淳化县', 3, 'chunhua', '029', '711200', 'C', '108.58026', '34.79886'),
+(2944, 2931, '武功', '武功县', '中国,陕西省,咸阳市,武功县', 3, 'wugong', '029', '712200', 'W', '108.20434', '34.26003'),
+(2945, 2931, '兴平', '兴平市', '中国,陕西省,咸阳市,兴平市', 3, 'xingping', '029', '713100', 'X', '108.49057', '34.29785'),
+(2946, 2898, '渭南', '渭南市', '中国,陕西省,渭南市', 2, 'weinan', '0913', '714000', 'W', '109.502882', '34.499381'),
+(2947, 2946, '临渭', '临渭区', '中国,陕西省,渭南市,临渭区', 3, 'linwei', '0913', '714000', 'L', '109.49296', '34.49822'),
+(2948, 2946, '华县', '华县', '中国,陕西省,渭南市,华县', 3, 'huaxian', '0913', '714100', 'H', '109.77185', '34.51255'),
+(2949, 2946, '潼关', '潼关县', '中国,陕西省,渭南市,潼关县', 3, 'tongguan', '0913', '714300', NULL, '110.24362', '34.54284'),
+(2950, 2946, '大荔', '大荔县', '中国,陕西省,渭南市,大荔县', 3, 'dali', '0913', '715100', 'D', '109.94216', '34.79565'),
+(2951, 2946, '合阳', '合阳县', '中国,陕西省,渭南市,合阳县', 3, 'heyang', '0913', '715300', 'H', '110.14862', '35.23805'),
+(2952, 2946, '澄城', '澄城县', '中国,陕西省,渭南市,澄城县', 3, 'chengcheng', '0913', '715200', 'C', '109.93444', '35.18396'),
+(2953, 2946, '蒲城', '蒲城县', '中国,陕西省,渭南市,蒲城县', 3, 'pucheng', '0913', '715500', 'P', '109.5903', '34.9568'),
+(2954, 2946, '白水', '白水县', '中国,陕西省,渭南市,白水县', 3, 'baishui', '0913', '715600', 'B', '109.59286', '35.17863'),
+(2955, 2946, '富平', '富平县', '中国,陕西省,渭南市,富平县', 3, 'fuping', '0913', '711700', 'F', '109.1802', '34.75109'),
+(2956, 2946, '韩城', '韩城市', '中国,陕西省,渭南市,韩城市', 3, 'hancheng', '0913', '715400', 'H', '110.44238', '35.47926'),
+(2957, 2946, '华阴', '华阴市', '中国,陕西省,渭南市,华阴市', 3, 'huayin', '0913', '714200', 'H', '110.08752', '34.56608'),
+(2958, 2898, '延安', '延安市', '中国,陕西省,延安市', 2, 'yan''an', '0911', '716000', 'Y', '109.49081', '36.596537'),
+(2959, 2958, '宝塔', '宝塔区', '中国,陕西省,延安市,宝塔区', 3, 'baota', '0911', '716000', 'B', '109.49336', '36.59154'),
+(2960, 2958, '延长', '延长县', '中国,陕西省,延安市,延长县', 3, 'yanchang', '0911', '717100', 'Y', '110.01083', '36.57904'),
+(2961, 2958, '延川', '延川县', '中国,陕西省,延安市,延川县', 3, 'yanchuan', '0911', '717200', 'Y', '110.19415', '36.87817'),
+(2962, 2958, '子长', '子长县', '中国,陕西省,延安市,子长县', 3, 'zichang', '0911', '717300', 'Z', '109.67532', '37.14253'),
+(2963, 2958, '安塞', '安塞县', '中国,陕西省,延安市,安塞县', 3, 'ansai', '0911', '717400', 'A', '109.32708', '36.86507'),
+(2964, 2958, '志丹', '志丹县', '中国,陕西省,延安市,志丹县', 3, 'zhidan', '0911', '717500', 'Z', '108.76815', '36.82177'),
+(2965, 2958, '吴起', '吴起县', '中国,陕西省,延安市,吴起县', 3, 'wuqi', '0911', '717600', 'W', '108.17611', '36.92785'),
+(2966, 2958, '甘泉', '甘泉县', '中国,陕西省,延安市,甘泉县', 3, 'ganquan', '0911', '716100', 'G', '109.35012', '36.27754'),
+(2967, 2958, '富县', '富县', '中国,陕西省,延安市,富县', 3, 'fuxian', '0911', '727500', 'F', '109.37927', '35.98803'),
+(2968, 2958, '洛川', '洛川县', '中国,陕西省,延安市,洛川县', 3, 'luochuan', '0911', '727400', 'L', '109.43286', '35.76076'),
+(2969, 2958, '宜川', '宜川县', '中国,陕西省,延安市,宜川县', 3, 'yichuan', '0911', '716200', 'Y', '110.17196', '36.04732'),
+(2970, 2958, '黄龙', '黄龙县', '中国,陕西省,延安市,黄龙县', 3, 'huanglong', '0911', '715700', 'H', '109.84259', '35.58349'),
+(2971, 2958, '黄陵', '黄陵县', '中国,陕西省,延安市,黄陵县', 3, 'huangling', '0911', '727300', 'H', '109.26333', '35.58357'),
+(2972, 2898, '汉中', '汉中市', '中国,陕西省,汉中市', 2, 'hanzhong', '0916', '723000', 'H', '107.028621', '33.077668'),
+(2973, 2972, '汉台', '汉台区', '中国,陕西省,汉中市,汉台区', 3, 'hantai', '0916', '723000', 'H', '107.03187', '33.06774'),
+(2974, 2972, '南郑', '南郑县', '中国,陕西省,汉中市,南郑县', 3, 'nanzheng', '0916', '723100', 'N', '106.94024', '33.00299'),
+(2975, 2972, '城固', '城固县', '中国,陕西省,汉中市,城固县', 3, 'chenggu', '0916', '723200', 'C', '107.33367', '33.15661'),
+(2976, 2972, '洋县', '洋县', '中国,陕西省,汉中市,洋县', 3, 'yangxian', '0916', '723300', 'Y', '107.54672', '33.22102'),
+(2977, 2972, '西乡', '西乡县', '中国,陕西省,汉中市,西乡县', 3, 'xixiang', '0916', '723500', 'X', '107.76867', '32.98411'),
+(2978, 2972, '勉县', '勉县', '中国,陕西省,汉中市,勉县', 3, 'mianxian', '0916', '724200', 'M', '106.67584', '33.15273'),
+(2979, 2972, '宁强', '宁强县', '中国,陕西省,汉中市,宁强县', 3, 'ningqiang', '0916', '724400', 'N', '106.25958', '32.82881'),
+(2980, 2972, '略阳', '略阳县', '中国,陕西省,汉中市,略阳县', 3, 'lueyang', '0916', '724300', 'L', '106.15399', '33.33009'),
+(2981, 2972, '镇巴', '镇巴县', '中国,陕西省,汉中市,镇巴县', 3, 'zhenba', '0916', '723600', 'Z', '107.89648', '32.53487'),
+(2982, 2972, '留坝', '留坝县', '中国,陕西省,汉中市,留坝县', 3, 'liuba', '0916', '724100', 'L', '106.92233', '33.61606'),
+(2983, 2972, '佛坪', '佛坪县', '中国,陕西省,汉中市,佛坪县', 3, 'foping', '0916', '723400', 'F', '107.98974', '33.52496'),
+(2984, 2898, '榆林', '榆林市', '中国,陕西省,榆林市', 2, 'yulin', '0912', '719000', 'Y', '109.741193', '38.290162'),
+(2985, 2984, '榆阳', '榆阳区', '中国,陕西省,榆林市,榆阳区', 3, 'yuyang', '0912', '719000', 'Y', '109.73473', '38.27843'),
+(2986, 2984, '神木', '神木县', '中国,陕西省,榆林市,神木县', 3, 'shenmu', '0912', '719300', 'S', '110.4989', '38.84234'),
+(2987, 2984, '府谷', '府谷县', '中国,陕西省,榆林市,府谷县', 3, 'fugu', '0912', '719400', 'F', '111.06723', '39.02805'),
+(2988, 2984, '横山', '横山县', '中国,陕西省,榆林市,横山县', 3, 'hengshan', '0912', '719100', 'H', '109.29568', '37.958'),
+(2989, 2984, '靖边', '靖边县', '中国,陕西省,榆林市,靖边县', 3, 'jingbian', '0912', '718500', 'J', '108.79412', '37.59938'),
+(2990, 2984, '定边', '定边县', '中国,陕西省,榆林市,定边县', 3, 'dingbian', '0912', '718600', 'D', '107.59793', '37.59037'),
+(2991, 2984, '绥德', '绥德县', '中国,陕西省,榆林市,绥德县', 3, 'suide', '0912', '718000', 'S', '110.26126', '37.49778'),
+(2992, 2984, '米脂', '米脂县', '中国,陕西省,榆林市,米脂县', 3, 'mizhi', '0912', '718100', 'M', '110.18417', '37.75529'),
+(2993, 2984, '佳县', '佳县', '中国,陕西省,榆林市,佳县', 3, 'jiaxian', '0912', '719200', 'J', '110.49362', '38.02248'),
+(2994, 2984, '吴堡', '吴堡县', '中国,陕西省,榆林市,吴堡县', 3, 'wubu', '0912', '718200', 'W', '110.74533', '37.45709'),
+(2995, 2984, '清涧', '清涧县', '中国,陕西省,榆林市,清涧县', 3, 'qingjian', '0912', '718300', 'Q', '110.12173', '37.08854'),
+(2996, 2984, '子洲', '子洲县', '中国,陕西省,榆林市,子洲县', 3, 'zizhou', '0912', '718400', 'Z', '110.03488', '37.61238'),
+(2997, 2898, '安康', '安康市', '中国,陕西省,安康市', 2, 'ankang', '0915', '725000', 'A', '109.029273', '32.6903'),
+(2998, 2997, '汉滨', '汉滨区', '中国,陕西省,安康市,汉滨区', 3, 'hanbin', '0915', '725000', 'H', '109.02683', '32.69517'),
+(2999, 2997, '汉阴', '汉阴县', '中国,陕西省,安康市,汉阴县', 3, 'hanyin', '0915', '725100', 'H', '108.51098', '32.89129'),
+(3000, 2997, '石泉', '石泉县', '中国,陕西省,安康市,石泉县', 3, 'shiquan', '0915', '725200', 'S', '108.24755', '33.03971'),
+(3001, 2997, '宁陕', '宁陕县', '中国,陕西省,安康市,宁陕县', 3, 'ningshan', '0915', '711600', 'N', '108.31515', '33.31726'),
+(3002, 2997, '紫阳', '紫阳县', '中国,陕西省,安康市,紫阳县', 3, 'ziyang', '0915', '725300', 'Z', '108.5368', '32.52115'),
+(3003, 2997, '岚皋', '岚皋县', '中国,陕西省,安康市,岚皋县', 3, 'langao', '0915', '725400', NULL, '108.90289', '32.30794'),
+(3004, 2997, '平利', '平利县', '中国,陕西省,安康市,平利县', 3, 'pingli', '0915', '725500', 'P', '109.35775', '32.39111'),
+(3005, 2997, '镇坪', '镇坪县', '中国,陕西省,安康市,镇坪县', 3, 'zhenping', '0915', '725600', 'Z', '109.52456', '31.8833'),
+(3006, 2997, '旬阳', '旬阳县', '中国,陕西省,安康市,旬阳县', 3, 'xunyang', '0915', '725700', 'X', '109.3619', '32.83207'),
+(3007, 2997, '白河', '白河县', '中国,陕西省,安康市,白河县', 3, 'baihe', '0915', '725800', 'B', '110.11315', '32.80955'),
+(3008, 2898, '商洛', '商洛市', '中国,陕西省,商洛市', 2, 'shangluo', '0914', '726000', 'S', '109.939776', '33.868319'),
+(3009, 3008, '商州', '商州区', '中国,陕西省,商洛市,商州区', 3, 'shangzhou', '0914', '726000', 'S', '109.94126', '33.8627'),
+(3010, 3008, '洛南', '洛南县', '中国,陕西省,商洛市,洛南县', 3, 'luonan', '0914', '726100', 'L', '110.14645', '34.08994'),
+(3011, 3008, '丹凤', '丹凤县', '中国,陕西省,商洛市,丹凤县', 3, 'danfeng', '0914', '726200', 'D', '110.33486', '33.69468'),
+(3012, 3008, '商南', '商南县', '中国,陕西省,商洛市,商南县', 3, 'shangnan', '0914', '726300', 'S', '110.88375', '33.52581'),
+(3013, 3008, '山阳', '山阳县', '中国,陕西省,商洛市,山阳县', 3, 'shanyang', '0914', '726400', 'S', '109.88784', '33.52931'),
+(3014, 3008, '镇安', '镇安县', '中国,陕西省,商洛市,镇安县', 3, 'zhen''an', '0914', '711500', 'Z', '109.15374', '33.42366'),
+(3015, 3008, '柞水', '柞水县', '中国,陕西省,商洛市,柞水县', 3, 'zhashui', '0914', '711400', 'Z', '109.11105', '33.6831'),
+(3016, 2898, '西咸', '西咸新区', '中国,陕西省,西咸新区', 2, 'xixian', '029', '712000', 'X', '108.810654', '34.307144'),
+(3017, 3016, '空港', '空港新城', '中国,陕西省,西咸新区,空港新城', 3, 'konggang', '0374', '461000', 'K', '108.760529', '34.440894'),
+(3018, 3016, '沣东', '沣东新城', '中国,陕西省,西咸新区,沣东新城', 3, 'fengdong', '029', '710000', NULL, '108.82988', '34.267431'),
+(3019, 3016, '秦汉', '秦汉新城', '中国,陕西省,西咸新区,秦汉新城', 3, 'qinhan', '029', '712000', 'Q', '108.83812', '34.386513'),
+(3020, 3016, '沣西', '沣西新城', '中国,陕西省,西咸新区,沣西新城', 3, 'fengxi', '029', '710000', NULL, '108.71215', '34.190453'),
+(3021, 3016, '泾河', '泾河新城', '中国,陕西省,西咸新区,泾河新城', 3, 'jinghe', '029', '713700', NULL, '109.049603', '34.460587'),
+(3022, 0, '甘肃', '甘肃省', '中国,甘肃省', 1, 'gansu', '', '', 'G', '103.823557', '36.058039'),
+(3023, 3022, '兰州', '兰州市', '中国,甘肃省,兰州市', 2, 'lanzhou', '0931', '730030', 'L', '103.823557', '36.058039'),
+(3024, 3023, '城关', '城关区', '中国,甘肃省,兰州市,城关区', 3, 'chengguan', '0931', '730030', 'C', '103.8252', '36.05725'),
+(3025, 3023, '七里河', '七里河区', '中国,甘肃省,兰州市,七里河区', 3, 'qilihe', '0931', '730050', 'Q', '103.78564', '36.06585'),
+(3026, 3023, '西固', '西固区', '中国,甘肃省,兰州市,西固区', 3, 'xigu', '0931', '730060', 'X', '103.62811', '36.08858'),
+(3027, 3023, '安宁', '安宁区', '中国,甘肃省,兰州市,安宁区', 3, 'anning', '0931', '730070', 'A', '103.7189', '36.10384'),
+(3028, 3023, '红古', '红古区', '中国,甘肃省,兰州市,红古区', 3, 'honggu', '0931', '730084', 'H', '102.85955', '36.34537'),
+(3029, 3023, '永登', '永登县', '中国,甘肃省,兰州市,永登县', 3, 'yongdeng', '0931', '730300', 'Y', '103.26055', '36.73522'),
+(3030, 3023, '皋兰', '皋兰县', '中国,甘肃省,兰州市,皋兰县', 3, 'gaolan', '0931', '730200', 'G', '103.94506', '36.33215'),
+(3031, 3023, '榆中', '榆中县', '中国,甘肃省,兰州市,榆中县', 3, 'yuzhong', '0931', '730100', 'Y', '104.1145', '35.84415'),
+(3032, 3022, '嘉峪关', '嘉峪关市', '中国,甘肃省,嘉峪关市', 2, 'jiayuguan', '0937', '735100', 'J', '98.277304', '39.786529'),
+(3033, 3032, '雄关', '雄关区', '中国,甘肃省,嘉峪关市,雄关区', 3, 'xiongguan', '0937', '735100', 'X', '98.277398', '39.77925'),
+(3034, 3032, '长城', '长城区', '中国,甘肃省,嘉峪关市,长城区', 3, 'changcheng', '0937', '735106', 'C', '98.273523', '39.787431'),
+(3035, 3032, '镜铁', '镜铁区', '中国,甘肃省,嘉峪关市,镜铁区', 3, 'jingtie', '0937', '735100', 'J', '98.277304', '39.786529'),
+(3036, 3022, '金昌', '金昌市', '中国,甘肃省,金昌市', 2, 'jinchang', '0935', '737100', 'J', '102.187888', '38.514238'),
+(3037, 3036, '金川', '金川区', '中国,甘肃省,金昌市,金川区', 3, 'jinchuan', '0935', '737100', 'J', '102.19376', '38.52101'),
+(3038, 3036, '永昌', '永昌县', '中国,甘肃省,金昌市,永昌县', 3, 'yongchang', '0935', '737200', 'Y', '101.97222', '38.24711'),
+(3039, 3022, '白银', '白银市', '中国,甘肃省,白银市', 2, 'baiyin', '0943', '730900', 'B', '104.173606', '36.54568'),
+(3040, 3039, '白银', '白银区', '中国,甘肃省,白银市,白银区', 3, 'baiyin', '0943', '730900', 'B', '104.17355', '36.54411'),
+(3041, 3039, '平川', '平川区', '中国,甘肃省,白银市,平川区', 3, 'pingchuan', '0943', '730913', 'P', '104.82498', '36.7277'),
+(3042, 3039, '靖远', '靖远县', '中国,甘肃省,白银市,靖远县', 3, 'jingyuan', '0943', '730600', 'J', '104.68325', '36.56602'),
+(3043, 3039, '会宁', '会宁县', '中国,甘肃省,白银市,会宁县', 3, 'huining', '0943', '730700', 'H', '105.05297', '35.69626'),
+(3044, 3039, '景泰', '景泰县', '中国,甘肃省,白银市,景泰县', 3, 'jingtai', '0943', '730400', 'J', '104.06295', '37.18359'),
+(3045, 3022, '天水', '天水市', '中国,甘肃省,天水市', 2, 'tianshui', '0938', '741000', 'T', '105.724998', '34.578529'),
+(3046, 3045, '秦州', '秦州区', '中国,甘肃省,天水市,秦州区', 3, 'qinzhou', '0938', '741000', 'Q', '105.72421', '34.58089'),
+(3047, 3045, '麦积', '麦积区', '中国,甘肃省,天水市,麦积区', 3, 'maiji', '0938', '741020', 'M', '105.89013', '34.57069'),
+(3048, 3045, '清水', '清水县', '中国,甘肃省,天水市,清水县', 3, 'qingshui', '0938', '741400', 'Q', '106.13671', '34.75032'),
+(3049, 3045, '秦安', '秦安县', '中国,甘肃省,天水市,秦安县', 3, 'qin''an', '0938', '741600', 'Q', '105.66955', '34.85894'),
+(3050, 3045, '甘谷', '甘谷县', '中国,甘肃省,天水市,甘谷县', 3, 'gangu', '0938', '741200', 'G', '105.33291', '34.73665'),
+(3051, 3045, '武山', '武山县', '中国,甘肃省,天水市,武山县', 3, 'wushan', '0938', '741300', 'W', '104.88382', '34.72123'),
+(3052, 3045, '张家川', '张家川回族自治县', '中国,甘肃省,天水市,张家川回族自治县', 3, 'zhangjiachuan', '0938', '741500', 'Z', '106.21582', '34.99582'),
+(3053, 3022, '武威', '武威市', '中国,甘肃省,武威市', 2, 'wuwei', '0935', '733000', 'W', '102.634697', '37.929996'),
+(3054, 3053, '凉州', '凉州区', '中国,甘肃省,武威市,凉州区', 3, 'liangzhou', '0935', '733000', 'L', '102.64203', '37.92832'),
+(3055, 3053, '民勤', '民勤县', '中国,甘肃省,武威市,民勤县', 3, 'minqin', '0935', '733300', 'M', '103.09011', '38.62487'),
+(3056, 3053, '古浪', '古浪县', '中国,甘肃省,武威市,古浪县', 3, 'gulang', '0935', '733100', 'G', '102.89154', '37.46508'),
+(3057, 3053, '天祝', '天祝藏族自治县', '中国,甘肃省,武威市,天祝藏族自治县', 3, 'tianzhu', '0935', '733200', 'T', '103.1361', '36.97715'),
+(3058, 3022, '张掖', '张掖市', '中国,甘肃省,张掖市', 2, 'zhangye', '0936', '734000', 'Z', '100.455472', '38.932897'),
+(3059, 3058, '甘州', '甘州区', '中国,甘肃省,张掖市,甘州区', 3, 'ganzhou', '0936', '734000', 'G', '100.4527', '38.92947'),
+(3060, 3058, '肃南', '肃南裕固族自治县', '中国,甘肃省,张掖市,肃南裕固族自治县', 3, 'sunan', '0936', '734400', 'S', '99.61407', '38.83776'),
+(3061, 3058, '民乐', '民乐县', '中国,甘肃省,张掖市,民乐县', 3, 'minle', '0936', '734500', 'M', '100.81091', '38.43479'),
+(3062, 3058, '临泽', '临泽县', '中国,甘肃省,张掖市,临泽县', 3, 'linze', '0936', '734200', 'L', '100.16445', '39.15252'),
+(3063, 3058, '高台', '高台县', '中国,甘肃省,张掖市,高台县', 3, 'gaotai', '0936', '734300', 'G', '99.81918', '39.37829'),
+(3064, 3058, '山丹', '山丹县', '中国,甘肃省,张掖市,山丹县', 3, 'shandan', '0936', '734100', 'S', '101.09359', '38.78468'),
+(3065, 3022, '平凉', '平凉市', '中国,甘肃省,平凉市', 2, 'pingliang', '0933', '744000', 'P', '106.684691', '35.54279'),
+(3066, 3065, '崆峒', '崆峒区', '中国,甘肃省,平凉市,崆峒区', 3, 'kongtong', '0933', '744000', NULL, '106.67483', '35.54262'),
+(3067, 3065, '泾川', '泾川县', '中国,甘肃省,平凉市,泾川县', 3, 'jingchuan', '0933', '744300', NULL, '107.36581', '35.33223'),
+(3068, 3065, '灵台', '灵台县', '中国,甘肃省,平凉市,灵台县', 3, 'lingtai', '0933', '744400', 'L', '107.6174', '35.06768'),
+(3069, 3065, '崇信', '崇信县', '中国,甘肃省,平凉市,崇信县', 3, 'chongxin', '0933', '744200', 'C', '107.03738', '35.30344'),
+(3070, 3065, '华亭', '华亭县', '中国,甘肃省,平凉市,华亭县', 3, 'huating', '0933', '744100', 'H', '106.65463', '35.2183'),
+(3071, 3065, '庄浪', '庄浪县', '中国,甘肃省,平凉市,庄浪县', 3, 'zhuanglang', '0933', '744600', 'Z', '106.03662', '35.20235'),
+(3072, 3065, '静宁', '静宁县', '中国,甘肃省,平凉市,静宁县', 3, 'jingning', '0933', '743400', 'J', '105.72723', '35.51991'),
+(3073, 3022, '酒泉', '酒泉市', '中国,甘肃省,酒泉市', 2, 'jiuquan', '0937', '735000', 'J', '98.510795', '39.744023'),
+(3074, 3073, '肃州', '肃州区', '中国,甘肃省,酒泉市,肃州区', 3, 'suzhou', '0937', '735000', 'S', '98.50775', '39.74506'),
+(3075, 3073, '金塔', '金塔县', '中国,甘肃省,酒泉市,金塔县', 3, 'jinta', '0937', '735300', 'J', '98.90002', '39.97733'),
+(3076, 3073, '瓜州', '瓜州县', '中国,甘肃省,酒泉市,瓜州县', 3, 'guazhou', '0937', '736100', 'G', '95.78271', '40.51548'),
+(3077, 3073, '肃北', '肃北蒙古族自治县', '中国,甘肃省,酒泉市,肃北蒙古族自治县', 3, 'subei', '0937', '736300', 'S', '94.87649', '39.51214'),
+(3078, 3073, '阿克塞', '阿克塞哈萨克族自治县', '中国,甘肃省,酒泉市,阿克塞哈萨克族自治县', 3, 'akesai', '0937', '736400', 'A', '94.34097', '39.63435'),
+(3079, 3073, '玉门', '玉门市', '中国,甘肃省,酒泉市,玉门市', 3, 'yumen', '0937', '735200', 'Y', '97.04538', '40.29172'),
+(3080, 3073, '敦煌', '敦煌市', '中国,甘肃省,酒泉市,敦煌市', 3, 'dunhuang', '0937', '736200', 'D', '94.66159', '40.14211'),
+(3081, 3022, '庆阳', '庆阳市', '中国,甘肃省,庆阳市', 2, 'qingyang', '0934', '745000', 'Q', '107.638372', '35.734218'),
+(3082, 3081, '西峰', '西峰区', '中国,甘肃省,庆阳市,西峰区', 3, 'xifeng', '0934', '745000', 'X', '107.65107', '35.73065'),
+(3083, 3081, '庆城', '庆城县', '中国,甘肃省,庆阳市,庆城县', 3, 'qingcheng', '0934', '745100', 'Q', '107.88272', '36.01507'),
+(3084, 3081, '环县', '环县', '中国,甘肃省,庆阳市,环县', 3, 'huanxian', '0934', '745700', 'H', '107.30835', '36.56846'),
+(3085, 3081, '华池', '华池县', '中国,甘肃省,庆阳市,华池县', 3, 'huachi', '0934', '745600', 'H', '107.9891', '36.46108'),
+(3086, 3081, '合水', '合水县', '中国,甘肃省,庆阳市,合水县', 3, 'heshui', '0934', '745400', 'H', '108.02032', '35.81911'),
+(3087, 3081, '正宁', '正宁县', '中国,甘肃省,庆阳市,正宁县', 3, 'zhengning', '0934', '745300', 'Z', '108.36007', '35.49174'),
+(3088, 3081, '宁县', '宁县', '中国,甘肃省,庆阳市,宁县', 3, 'ningxian', '0934', '745200', 'N', '107.92517', '35.50164'),
+(3089, 3081, '镇原', '镇原县', '中国,甘肃省,庆阳市,镇原县', 3, 'zhenyuan', '0934', '744500', 'Z', '107.199', '35.67712'),
+(3090, 3022, '定西', '定西市', '中国,甘肃省,定西市', 2, 'dingxi', '0932', '743000', 'D', '104.626294', '35.579578'),
+(3091, 3090, '安定', '安定区', '中国,甘肃省,定西市,安定区', 3, 'anding', '0932', '743000', 'A', '104.6106', '35.58066'),
+(3092, 3090, '通渭', '通渭县', '中国,甘肃省,定西市,通渭县', 3, 'tongwei', '0932', '743300', 'T', '105.24224', '35.21101'),
+(3093, 3090, '陇西', '陇西县', '中国,甘肃省,定西市,陇西县', 3, 'longxi', '0932', '748100', 'L', '104.63446', '35.00238'),
+(3094, 3090, '渭源', '渭源县', '中国,甘肃省,定西市,渭源县', 3, 'weiyuan', '0932', '748200', 'W', '104.21435', '35.13649'),
+(3095, 3090, '临洮', '临洮县', '中国,甘肃省,定西市,临洮县', 3, 'lintao', '0932', '730500', 'L', '103.86196', '35.3751'),
+(3096, 3090, '漳县', '漳县', '中国,甘肃省,定西市,漳县', 3, 'zhangxian', '0932', '748300', 'Z', '104.46704', '34.84977'),
+(3097, 3090, '岷县', '岷县', '中国,甘肃省,定西市,岷县', 3, 'minxian', '0932', '748400', NULL, '104.03772', '34.43444'),
+(3098, 3022, '陇南', '陇南市', '中国,甘肃省,陇南市', 2, 'longnan', '0939', '746000', 'L', '104.929379', '33.388598'),
+(3099, 3098, '武都', '武都区', '中国,甘肃省,陇南市,武都区', 3, 'wudu', '0939', '746000', 'W', '104.92652', '33.39239'),
+(3100, 3098, '成县', '成县', '中国,甘肃省,陇南市,成县', 3, 'chengxian', '0939', '742500', 'C', '105.72586', '33.73925'),
+(3101, 3098, '文县', '文县', '中国,甘肃省,陇南市,文县', 3, 'wenxian', '0939', '746400', 'W', '104.68362', '32.94337'),
+(3102, 3098, '宕昌', '宕昌县', '中国,甘肃省,陇南市,宕昌县', 3, 'dangchang', '0939', '748500', NULL, '104.39349', '34.04732'),
+(3103, 3098, '康县', '康县', '中国,甘肃省,陇南市,康县', 3, 'kangxian', '0939', '746500', 'K', '105.60711', '33.32912'),
+(3104, 3098, '西和', '西和县', '中国,甘肃省,陇南市,西和县', 3, 'xihe', '0939', '742100', 'X', '105.30099', '34.01432'),
+(3105, 3098, '礼县', '礼县', '中国,甘肃省,陇南市,礼县', 3, 'lixian', '0939', '742200', 'L', '105.17785', '34.18935'),
+(3106, 3098, '徽县', '徽县', '中国,甘肃省,陇南市,徽县', 3, 'huixian', '0939', '742300', 'H', '106.08529', '33.76898'),
+(3107, 3098, '两当', '两当县', '中国,甘肃省,陇南市,两当县', 3, 'liangdang', '0939', '742400', 'L', '106.30484', '33.9096'),
+(3108, 3022, '临夏', '临夏回族自治州', '中国,甘肃省,临夏回族自治州', 2, 'linxia', '0930', '731100', 'L', '103.212006', '35.599446'),
+(3109, 3108, '临夏', '临夏市', '中国,甘肃省,临夏回族自治州,临夏市', 3, 'linxia', '0930', '731100', 'L', '103.21', '35.59916'),
+(3110, 3108, '临夏', '临夏县', '中国,甘肃省,临夏回族自治州,临夏县', 3, 'linxia', '0930', '731800', 'L', '102.9938', '35.49519'),
+(3111, 3108, '康乐', '康乐县', '中国,甘肃省,临夏回族自治州,康乐县', 3, 'kangle', '0930', '731500', 'K', '103.71093', '35.37219'),
+(3112, 3108, '永靖', '永靖县', '中国,甘肃省,临夏回族自治州,永靖县', 3, 'yongjing', '0930', '731600', 'Y', '103.32043', '35.93835'),
+(3113, 3108, '广河', '广河县', '中国,甘肃省,临夏回族自治州,广河县', 3, 'guanghe', '0930', '731300', 'G', '103.56933', '35.48097'),
+(3114, 3108, '和政', '和政县', '中国,甘肃省,临夏回族自治州,和政县', 3, 'hezheng', '0930', '731200', 'H', '103.34936', '35.42592'),
+(3115, 3108, '东乡族', '东乡族自治县', '中国,甘肃省,临夏回族自治州,东乡族自治县', 3, 'dongxiangzu', '0930', '731400', 'D', '103.39477', '35.66471'),
+(3116, 3108, '积石山', '积石山保安族东乡族撒拉族自治县', '中国,甘肃省,临夏回族自治州,积石山保安族东乡族撒拉族自治县', 3, 'jishishan', '0930', '731700', 'J', '102.87374', '35.7182'),
+(3117, 3022, '甘南', '甘南藏族自治州', '中国,甘肃省,甘南藏族自治州', 2, 'gannan', '0941', '747000', 'G', '102.911008', '34.986354'),
+(3118, 3117, '合作', '合作市', '中国,甘肃省,甘南藏族自治州,合作市', 3, 'hezuo', '0941', '747000', 'H', '102.91082', '35.00016'),
+(3119, 3117, '临潭', '临潭县', '中国,甘肃省,甘南藏族自治州,临潭县', 3, 'lintan', '0941', '747500', 'L', '103.35287', '34.69515'),
+(3120, 3117, '卓尼', '卓尼县', '中国,甘肃省,甘南藏族自治州,卓尼县', 3, 'zhuoni', '0941', '747600', 'Z', '103.50811', '34.58919'),
+(3121, 3117, '舟曲', '舟曲县', '中国,甘肃省,甘南藏族自治州,舟曲县', 3, 'zhouqu', '0941', '746300', 'Z', '104.37155', '33.78468'),
+(3122, 3117, '迭部', '迭部县', '中国,甘肃省,甘南藏族自治州,迭部县', 3, 'diebu', '0941', '747400', 'D', '103.22274', '34.05623'),
+(3123, 3117, '玛曲', '玛曲县', '中国,甘肃省,甘南藏族自治州,玛曲县', 3, 'maqu', '0941', '747300', 'M', '102.0754', '33.997'),
+(3124, 3117, '碌曲', '碌曲县', '中国,甘肃省,甘南藏族自治州,碌曲县', 3, 'luqu', '0941', '747200', 'L', '102.49176', '34.58872'),
+(3125, 3117, '夏河', '夏河县', '中国,甘肃省,甘南藏族自治州,夏河县', 3, 'xiahe', '0941', '747100', 'X', '102.52215', '35.20487'),
+(3126, 0, '青海', '青海省', '中国,青海省', 1, 'qinghai', '', '', 'Q', '101.778916', '36.623178'),
+(3127, 3126, '西宁', '西宁市', '中国,青海省,西宁市', 2, 'xining', '0971', '810000', 'X', '101.778916', '36.623178'),
+(3128, 3127, '城东', '城东区', '中国,青海省,西宁市,城东区', 3, 'chengdong', '0971', '810007', 'C', '101.80373', '36.59969'),
+(3129, 3127, '城中', '城中区', '中国,青海省,西宁市,城中区', 3, 'chengzhong', '0971', '810000', 'C', '101.78394', '36.62279'),
+(3130, 3127, '城西', '城西区', '中国,青海省,西宁市,城西区', 3, 'chengxi', '0971', '810001', 'C', '101.76588', '36.62828'),
+(3131, 3127, '城北', '城北区', '中国,青海省,西宁市,城北区', 3, 'chengbei', '0971', '810003', 'C', '101.7662', '36.65014'),
+(3132, 3127, '大通', '大通回族土族自治县', '中国,青海省,西宁市,大通回族土族自治县', 3, 'datong', '0971', '810100', 'D', '101.70236', '36.93489'),
+(3133, 3127, '湟中', '湟中县', '中国,青海省,西宁市,湟中县', 3, 'huangzhong', '0971', '811600', NULL, '101.57159', '36.50083'),
+(3134, 3127, '湟源', '湟源县', '中国,青海省,西宁市,湟源县', 3, 'huangyuan', '0971', '812100', NULL, '101.25643', '36.68243'),
+(3135, 3126, '海东', '海东市', '中国,青海省,海东市', 2, 'haidong', '0972', '810700', 'H', '102.10327', '36.502916'),
+(3136, 3135, '乐都', '乐都区', '中国,青海省,海东市,乐都区', 3, 'ledu', '0972', '810700', 'L', '102.402431', '36.480291'),
+(3137, 3135, '平安', '平安县', '中国,青海省,海东市,平安县', 3, 'ping''an', '0972', '810600', 'P', '102.104295', '36.502714'),
+(3138, 3135, '民和', '民和回族土族自治县', '中国,青海省,海东市,民和回族土族自治县', 3, 'minhe', '0972', '810800', 'M', '102.804209', '36.329451'),
+(3139, 3135, '互助', '互助土族自治县', '中国,青海省,海东市,互助土族自治县', 3, 'huzhu', '0972', '810500', 'H', '101.956734', '36.83994'),
+(3140, 3135, '化隆', '化隆回族自治县', '中国,青海省,海东市,化隆回族自治县', 3, 'hualong', '0972', '810900', 'H', '102.262329', '36.098322'),
+(3141, 3135, '循化', '循化撒拉族自治县', '中国,青海省,海东市,循化撒拉族自治县', 3, 'xunhua', '0972', '811100', 'X', '102.486534', '35.847247'),
+(3142, 3126, '海北', '海北藏族自治州', '中国,青海省,海北藏族自治州', 2, 'haibei', '0970', '812200', 'H', '100.901059', '36.959435'),
+(3143, 3142, '门源', '门源回族自治县', '中国,青海省,海北藏族自治州,门源回族自治县', 3, 'menyuan', '0970', '810300', 'M', '101.62228', '37.37611'),
+(3144, 3142, '祁连', '祁连县', '中国,青海省,海北藏族自治州,祁连县', 3, 'qilian', '0970', '810400', 'Q', '100.24618', '38.17901'),
+(3145, 3142, '海晏', '海晏县', '中国,青海省,海北藏族自治州,海晏县', 3, 'haiyan', '0970', '812200', 'H', '100.9927', '36.89902'),
+(3146, 3142, '刚察', '刚察县', '中国,青海省,海北藏族自治州,刚察县', 3, 'gangcha', '0970', '812300', 'G', '100.14675', '37.32161'),
+(3147, 3126, '黄南', '黄南藏族自治州', '中国,青海省,黄南藏族自治州', 2, 'huangnan', '0973', '811300', 'H', '102.019988', '35.517744'),
+(3148, 3147, '同仁', '同仁县', '中国,青海省,黄南藏族自治州,同仁县', 3, 'tongren', '0973', '811300', 'T', '102.0184', '35.51603'),
+(3149, 3147, '尖扎', '尖扎县', '中国,青海省,黄南藏族自治州,尖扎县', 3, 'jianzha', '0973', '811200', 'J', '102.03411', '35.93947'),
+(3150, 3147, '泽库', '泽库县', '中国,青海省,黄南藏族自治州,泽库县', 3, 'zeku', '0973', '811400', 'Z', '101.46444', '35.03519'),
+(3151, 3147, '河南', '河南蒙古族自治县', '中国,青海省,黄南藏族自治州,河南蒙古族自治县', 3, 'henan', '0973', '811500', 'H', '101.60864', '34.73476'),
+(3152, 3126, '海南', '海南藏族自治州', '中国,青海省,海南藏族自治州', 2, 'hainan', '0974', '813000', 'H', '100.619542', '36.280353'),
+(3153, 3152, '共和', '共和县', '中国,青海省,海南藏族自治州,共和县', 3, 'gonghe', '0974', '813000', 'G', '100.62003', '36.2841'),
+(3154, 3152, '同德', '同德县', '中国,青海省,海南藏族自治州,同德县', 3, 'tongde', '0974', '813200', 'T', '100.57159', '35.25488'),
+(3155, 3152, '贵德', '贵德县', '中国,青海省,海南藏族自治州,贵德县', 3, 'guide', '0974', '811700', 'G', '101.432', '36.044'),
+(3156, 3152, '兴海', '兴海县', '中国,青海省,海南藏族自治州,兴海县', 3, 'xinghai', '0974', '813300', 'X', '99.98846', '35.59031'),
+(3157, 3152, '贵南', '贵南县', '中国,青海省,海南藏族自治州,贵南县', 3, 'guinan', '0974', '813100', 'G', '100.74716', '35.58667'),
+(3158, 3126, '果洛', '果洛藏族自治州', '中国,青海省,果洛藏族自治州', 2, 'golog', '0975', '814000', 'G', '100.242143', '34.4736'),
+(3159, 3158, '玛沁', '玛沁县', '中国,青海省,果洛藏族自治州,玛沁县', 3, 'maqin', '0975', '814000', 'M', '100.23901', '34.47746'),
+(3160, 3158, '班玛', '班玛县', '中国,青海省,果洛藏族自治州,班玛县', 3, 'banma', '0975', '814300', 'B', '100.73745', '32.93253'),
+(3161, 3158, '甘德', '甘德县', '中国,青海省,果洛藏族自治州,甘德县', 3, 'gande', '0975', '814100', 'G', '99.90246', '33.96838'),
+(3162, 3158, '达日', '达日县', '中国,青海省,果洛藏族自治州,达日县', 3, 'dari', '0975', '814200', 'D', '99.65179', '33.75193'),
+(3163, 3158, '久治', '久治县', '中国,青海省,果洛藏族自治州,久治县', 3, 'jiuzhi', '0975', '624700', 'J', '101.48342', '33.42989'),
+(3164, 3158, '玛多', '玛多县', '中国,青海省,果洛藏族自治州,玛多县', 3, 'maduo', '0975', '813500', 'M', '98.20996', '34.91567'),
+(3165, 3126, '玉树', '玉树藏族自治州', '中国,青海省,玉树藏族自治州', 2, 'yushu', '0976', '815000', 'Y', '97.008522', '33.004049'),
+(3166, 3165, '玉树', '玉树市', '中国,青海省,玉树藏族自治州,玉树市', 3, 'yushu', '0976', '815000', 'Y', '97.008762', '33.00393'),
+(3167, 3165, '杂多', '杂多县', '中国,青海省,玉树藏族自治州,杂多县', 3, 'zaduo', '0976', '815300', 'Z', '95.29864', '32.89318'),
+(3168, 3165, '称多', '称多县', '中国,青海省,玉树藏族自治州,称多县', 3, 'chenduo', '0976', '815100', 'C', '97.10788', '33.36899'),
+(3169, 3165, '治多', '治多县', '中国,青海省,玉树藏族自治州,治多县', 3, 'zhiduo', '0976', '815400', 'Z', '95.61572', '33.8528'),
+(3170, 3165, '囊谦', '囊谦县', '中国,青海省,玉树藏族自治州,囊谦县', 3, 'nangqian', '0976', '815200', 'N', '96.47753', '32.20359'),
+(3171, 3165, '曲麻莱', '曲麻莱县', '中国,青海省,玉树藏族自治州,曲麻莱县', 3, 'qumalai', '0976', '815500', 'Q', '95.79757', '34.12609'),
+(3172, 3126, '海西', '海西蒙古族藏族自治州', '中国,青海省,海西蒙古族藏族自治州', 2, 'haixi', '0977', '817000', 'H', '97.370785', '37.374663'),
+(3173, 3172, '格尔木', '格尔木市', '中国,青海省,海西蒙古族藏族自治州,格尔木市', 3, 'geermu', '0977', '816000', 'G', '94.90329', '36.40236'),
+(3174, 3172, '德令哈', '德令哈市', '中国,青海省,海西蒙古族藏族自治州,德令哈市', 3, 'delingha', '0977', '817000', 'D', '97.36084', '37.36946'),
+(3175, 3172, '乌兰', '乌兰县', '中国,青海省,海西蒙古族藏族自治州,乌兰县', 3, 'wulan', '0977', '817100', 'W', '98.48196', '36.93471'),
+(3176, 3172, '都兰', '都兰县', '中国,青海省,海西蒙古族藏族自治州,都兰县', 3, 'dulan', '0977', '816100', 'D', '98.09228', '36.30135'),
+(3177, 3172, '天峻', '天峻县', '中国,青海省,海西蒙古族藏族自治州,天峻县', 3, 'tianjun', '0977', '817200', 'T', '99.02453', '37.30326'),
+(3178, 0, '宁夏', '宁夏回族自治区', '中国,宁夏回族自治区', 1, 'ningxia', '', '', 'N', '106.278179', '38.46637'),
+(3179, 3178, '银川', '银川市', '中国,宁夏回族自治区,银川市', 2, 'yinchuan', '0951', '750004', 'Y', '106.278179', '38.46637'),
+(3180, 3179, '兴庆', '兴庆区', '中国,宁夏回族自治区,银川市,兴庆区', 3, 'xingqing', '0951', '750001', 'X', '106.28872', '38.47392'),
+(3181, 3179, '西夏', '西夏区', '中国,宁夏回族自治区,银川市,西夏区', 3, 'xixia', '0951', '750021', 'X', '106.15023', '38.49137'),
+(3182, 3179, '金凤', '金凤区', '中国,宁夏回族自治区,银川市,金凤区', 3, 'jinfeng', '0951', '750011', 'J', '106.24261', '38.47294'),
+(3183, 3179, '永宁', '永宁县', '中国,宁夏回族自治区,银川市,永宁县', 3, 'yongning', '0951', '750100', 'Y', '106.2517', '38.27559'),
+(3184, 3179, '贺兰', '贺兰县', '中国,宁夏回族自治区,银川市,贺兰县', 3, 'helan', '0951', '750200', 'H', '106.34982', '38.5544'),
+(3185, 3179, '灵武', '灵武市', '中国,宁夏回族自治区,银川市,灵武市', 3, 'lingwu', '0951', '750004', 'L', '106.33999', '38.10266'),
+(3186, 3178, '石嘴山', '石嘴山市', '中国,宁夏回族自治区,石嘴山市', 2, 'shizuishan', '0952', '753000', 'S', '106.376173', '39.01333'),
+(3187, 3186, '大武口', '大武口区', '中国,宁夏回族自治区,石嘴山市,大武口区', 3, 'dawukou', '0952', '753000', 'D', '106.37717', '39.01226'),
+(3188, 3186, '惠农', '惠农区', '中国,宁夏回族自治区,石嘴山市,惠农区', 3, 'huinong', '0952', '753600', 'H', '106.71145', '39.13193'),
+(3189, 3186, '平罗', '平罗县', '中国,宁夏回族自治区,石嘴山市,平罗县', 3, 'pingluo', '0952', '753400', 'P', '106.54538', '38.90429'),
+(3190, 3178, '吴忠', '吴忠市', '中国,宁夏回族自治区,吴忠市', 2, 'wuzhong', '0953', '751100', 'W', '106.199409', '37.986165'),
+(3191, 3190, '利通', '利通区', '中国,宁夏回族自治区,吴忠市,利通区', 3, 'litong', '0953', '751100', 'L', '106.20311', '37.98512'),
+(3192, 3190, '红寺堡', '红寺堡区', '中国,宁夏回族自治区,吴忠市,红寺堡区', 3, 'hongsibao', '0953', '751900', 'H', '106.19822', '37.99747'),
+(3193, 3190, '盐池', '盐池县', '中国,宁夏回族自治区,吴忠市,盐池县', 3, 'yanchi', '0953', '751500', 'Y', '107.40707', '37.7833'),
+(3194, 3190, '同心', '同心县', '中国,宁夏回族自治区,吴忠市,同心县', 3, 'tongxin', '0953', '751300', 'T', '105.91418', '36.98116'),
+(3195, 3190, '青铜峡', '青铜峡市', '中国,宁夏回族自治区,吴忠市,青铜峡市', 3, 'qingtongxia', '0953', '751600', 'Q', '106.07489', '38.02004'),
+(3196, 3178, '固原', '固原市', '中国,宁夏回族自治区,固原市', 2, 'guyuan', '0954', '756000', 'G', '106.285241', '36.004561'),
+(3197, 3196, '原州', '原州区', '中国,宁夏回族自治区,固原市,原州区', 3, 'yuanzhou', '0954', '756000', 'Y', '106.28778', '36.00374'),
+(3198, 3196, '西吉', '西吉县', '中国,宁夏回族自治区,固原市,西吉县', 3, 'xiji', '0954', '756200', 'X', '105.73107', '35.96616'),
+(3199, 3196, '隆德', '隆德县', '中国,宁夏回族自治区,固原市,隆德县', 3, 'longde', '0954', '756300', 'L', '106.12426', '35.61718'),
+(3200, 3196, '泾源', '泾源县', '中国,宁夏回族自治区,固原市,泾源县', 3, 'jingyuan', '0954', '756400', NULL, '106.33902', '35.49072'),
+(3201, 3196, '彭阳', '彭阳县', '中国,宁夏回族自治区,固原市,彭阳县', 3, 'pengyang', '0954', '756500', 'P', '106.64462', '35.85076'),
+(3202, 3178, '中卫', '中卫市', '中国,宁夏回族自治区,中卫市', 2, 'zhongwei', '0955', '751700', 'Z', '105.189568', '37.514951'),
+(3203, 3202, '沙坡头', '沙坡头区', '中国,宁夏回族自治区,中卫市,沙坡头区', 3, 'shapotou', '0955', '755000', 'S', '105.18962', '37.51044'),
+(3204, 3202, '中宁', '中宁县', '中国,宁夏回族自治区,中卫市,中宁县', 3, 'zhongning', '0955', '751200', 'Z', '105.68515', '37.49149'),
+(3205, 3202, '海原', '海原县', '中国,宁夏回族自治区,中卫市,海原县', 3, 'haiyuan', '0955', '751800', 'H', '105.64712', '36.56498'),
+(3206, 0, '新疆', '新疆维吾尔自治区', '中国,新疆维吾尔自治区', 1, 'xinjiang', '', '', 'X', '87.617733', '43.792818'),
+(3207, 3206, '乌鲁木齐', '乌鲁木齐市', '中国,新疆维吾尔自治区,乌鲁木齐市', 2, 'urumqi', '0991', '830002', 'W', '87.617733', '43.792818'),
+(3208, 3207, '天山', '天山区', '中国,新疆维吾尔自治区,乌鲁木齐市,天山区', 3, 'tianshan', '0991', '830002', 'T', '87.63167', '43.79439'),
+(3209, 3207, '沙依巴克', '沙依巴克区', '中国,新疆维吾尔自治区,乌鲁木齐市,沙依巴克区', 3, 'shayibake', '0991', '830000', 'S', '87.59788', '43.80118'),
+(3210, 3207, '新市', '新市区', '中国,新疆维吾尔自治区,乌鲁木齐市,新市区', 3, 'xinshi', '0991', '830011', 'X', '87.57406', '43.84348'),
+(3211, 3207, '水磨沟', '水磨沟区', '中国,新疆维吾尔自治区,乌鲁木齐市,水磨沟区', 3, 'shuimogou', '0991', '830017', 'S', '87.64249', '43.83247'),
+(3212, 3207, '头屯河', '头屯河区', '中国,新疆维吾尔自治区,乌鲁木齐市,头屯河区', 3, 'toutunhe', '0991', '830022', 'T', '87.29138', '43.85487'),
+(3213, 3207, '达坂城', '达坂城区', '中国,新疆维吾尔自治区,乌鲁木齐市,达坂城区', 3, 'dabancheng', '0991', '830039', 'D', '88.30697', '43.35797'),
+(3214, 3207, '米东', '米东区', '中国,新疆维吾尔自治区,乌鲁木齐市,米东区', 3, 'midong', '0991', '830019', 'M', '87.68583', '43.94739'),
+(3215, 3207, '乌鲁木齐', '乌鲁木齐县', '中国,新疆维吾尔自治区,乌鲁木齐市,乌鲁木齐县', 3, 'wulumuqi', '0991', '830063', 'W', '87.40939', '43.47125'),
+(3216, 3206, '克拉玛依', '克拉玛依市', '中国,新疆维吾尔自治区,克拉玛依市', 2, 'karamay', '0990', '834000', 'K', '84.873946', '45.595886'),
+(3217, 3216, '独山子', '独山子区', '中国,新疆维吾尔自治区,克拉玛依市,独山子区', 3, 'dushanzi', '0992', '834021', 'D', '84.88671', '44.32867'),
+(3218, 3216, '克拉玛依', '克拉玛依区', '中国,新疆维吾尔自治区,克拉玛依市,克拉玛依区', 3, 'kelamayi', '0990', '834000', 'K', '84.86225', '45.59089'),
+(3219, 3216, '白碱滩', '白碱滩区', '中国,新疆维吾尔自治区,克拉玛依市,白碱滩区', 3, 'baijiantan', '0990', '834008', 'B', '85.13244', '45.68768'),
+(3220, 3216, '乌尔禾', '乌尔禾区', '中国,新疆维吾尔自治区,克拉玛依市,乌尔禾区', 3, 'wuerhe', '0990', '834012', 'W', '85.69143', '46.09006'),
+(3221, 3206, '吐鲁番', '吐鲁番地区', '中国,新疆维吾尔自治区,吐鲁番地区', 2, 'turpan', '0995', '838000', 'T', '89.184078', '42.947613'),
+(3222, 3221, '吐鲁番', '吐鲁番市', '中国,新疆维吾尔自治区,吐鲁番地区,吐鲁番市', 3, 'tulufan', '0995', '838000', 'T', '89.18579', '42.93505'),
+(3223, 3221, '鄯善', '鄯善县', '中国,新疆维吾尔自治区,吐鲁番地区,鄯善县', 3, 'shanshan', '0995', '838200', NULL, '90.21402', '42.8635'),
+(3224, 3221, '托克逊', '托克逊县', '中国,新疆维吾尔自治区,吐鲁番地区,托克逊县', 3, 'tuokexun', '0995', '838100', 'T', '88.65823', '42.79231'),
+(3225, 3206, '哈密', '哈密地区', '中国,新疆维吾尔自治区,哈密地区', 2, 'hami', '0902', '839000', 'H', '93.51316', '42.833248'),
+(3226, 3225, '哈密', '哈密市', '中国,新疆维吾尔自治区,哈密地区,哈密市', 3, 'hami', '0902', '839000', 'H', '93.51452', '42.82699'),
+(3227, 3225, '巴里坤', '巴里坤哈萨克自治县', '中国,新疆维吾尔自治区,哈密地区,巴里坤哈萨克自治县', 3, 'balikun', '0902', '839200', 'B', '93.01236', '43.59993'),
+(3228, 3225, '伊吾', '伊吾县', '中国,新疆维吾尔自治区,哈密地区,伊吾县', 3, 'yiwu', '0902', '839300', 'Y', '94.69403', '43.2537'),
+(3229, 3206, '昌吉', '昌吉回族自治州', '中国,新疆维吾尔自治区,昌吉回族自治州', 2, 'changji', '0994', '831100', 'C', '87.304012', '44.014577'),
+(3230, 3229, '昌吉', '昌吉市', '中国,新疆维吾尔自治区,昌吉回族自治州,昌吉市', 3, 'changji', '0994', '831100', 'C', '87.30249', '44.01267'),
+(3231, 3229, '阜康', '阜康市', '中国,新疆维吾尔自治区,昌吉回族自治州,阜康市', 3, 'fukang', '0994', '831500', 'F', '87.98529', '44.1584'),
+(3232, 3229, '呼图壁', '呼图壁县', '中国,新疆维吾尔自治区,昌吉回族自治州,呼图壁县', 3, 'hutubi', '0994', '831200', 'H', '86.89892', '44.18977'),
+(3233, 3229, '玛纳斯', '玛纳斯县', '中国,新疆维吾尔自治区,昌吉回族自治州,玛纳斯县', 3, 'manasi', '0994', '832200', 'M', '86.2145', '44.30438'),
+(3234, 3229, '奇台', '奇台县', '中国,新疆维吾尔自治区,昌吉回族自治州,奇台县', 3, 'qitai', '0994', '831800', 'Q', '89.5932', '44.02221'),
+(3235, 3229, '吉木萨尔', '吉木萨尔县', '中国,新疆维吾尔自治区,昌吉回族自治州,吉木萨尔县', 3, 'jimusaer', '0994', '831700', 'J', '89.18078', '44.00048'),
+(3236, 3229, '木垒', '木垒哈萨克自治县', '中国,新疆维吾尔自治区,昌吉回族自治州,木垒哈萨克自治县', 3, 'mulei', '0994', '831900', 'M', '90.28897', '43.83508'),
+(3237, 3206, '博尔塔拉', '博尔塔拉蒙古自治州', '中国,新疆维吾尔自治区,博尔塔拉蒙古自治州', 2, 'bortala', '0909', '833400', 'B', '82.074778', '44.903258'),
+(3238, 3237, '博乐', '博乐市', '中国,新疆维吾尔自治区,博尔塔拉蒙古自治州,博乐市', 3, 'bole', '0909', '833400', 'B', '82.0713', '44.90052'),
+(3239, 3237, '阿拉山口', '阿拉山口市', '中国,新疆维吾尔自治区,博尔塔拉蒙古自治州,阿拉山口市', 3, 'alashankou', '0909', '833400', 'A', '82.567721', '45.170616'),
+(3240, 3237, '精河', '精河县', '中国,新疆维吾尔自治区,博尔塔拉蒙古自治州,精河县', 3, 'jinghe', '0909', '833300', 'J', '82.89419', '44.60774'),
+(3241, 3237, '温泉', '温泉县', '中国,新疆维吾尔自治区,博尔塔拉蒙古自治州,温泉县', 3, 'wenquan', '0909', '833500', 'W', '81.03134', '44.97373'),
+(3242, 3206, '巴音郭楞', '巴音郭楞蒙古自治州', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州', 2, 'bayingol', '0996', '841000', 'B', '86.150969', '41.768552'),
+(3243, 3242, '库尔勒', '库尔勒市', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,库尔勒市', 3, 'kuerle', '0996', '841000', 'K', '86.15528', '41.76602'),
+(3244, 3242, '轮台', '轮台县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,轮台县', 3, 'luntai', '0996', '841600', 'L', '84.26101', '41.77642'),
+(3245, 3242, '尉犁', '尉犁县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,尉犁县', 3, 'yuli', '0996', '841500', 'W', '86.25903', '41.33632'),
+(3246, 3242, '若羌', '若羌县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,若羌县', 3, 'ruoqiang', '0996', '841800', 'R', '88.16812', '39.0179'),
+(3247, 3242, '且末', '且末县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,且末县', 3, 'qiemo', '0996', '841900', 'Q', '85.52975', '38.14534'),
+(3248, 3242, '焉耆', '焉耆回族自治县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,焉耆回族自治县', 3, 'yanqi', '0996', '841100', 'Y', '86.5744', '42.059'),
+(3249, 3242, '和静', '和静县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,和静县', 3, 'hejing', '0996', '841300', 'H', '86.39611', '42.31838'),
+(3250, 3242, '和硕', '和硕县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,和硕县', 3, 'heshuo', '0996', '841200', 'H', '86.86392', '42.26814'),
+(3251, 3242, '博湖', '博湖县', '中国,新疆维吾尔自治区,巴音郭楞蒙古自治州,博湖县', 3, 'bohu', '0996', '841400', 'B', '86.63333', '41.98014'),
+(3252, 3206, '阿克苏', '阿克苏地区', '中国,新疆维吾尔自治区,阿克苏地区', 2, 'aksu', '0997', '843000', 'A', '80.265068', '41.170712'),
+(3253, 3252, '阿克苏', '阿克苏市', '中国,新疆维吾尔自治区,阿克苏地区,阿克苏市', 3, 'akesu', '0997', '843000', 'A', '80.26338', '41.16754'),
+(3254, 3252, '温宿', '温宿县', '中国,新疆维吾尔自治区,阿克苏地区,温宿县', 3, 'wensu', '0997', '843100', 'W', '80.24173', '41.27679'),
+(3255, 3252, '库车', '库车县', '中国,新疆维吾尔自治区,阿克苏地区,库车县', 3, 'kuche', '0997', '842000', 'K', '82.96209', '41.71793'),
+(3256, 3252, '沙雅', '沙雅县', '中国,新疆维吾尔自治区,阿克苏地区,沙雅县', 3, 'shaya', '0997', '842200', 'S', '82.78131', '41.22497'),
+(3257, 3252, '新和', '新和县', '中国,新疆维吾尔自治区,阿克苏地区,新和县', 3, 'xinhe', '0997', '842100', 'X', '82.61053', '41.54964'),
+(3258, 3252, '拜城', '拜城县', '中国,新疆维吾尔自治区,阿克苏地区,拜城县', 3, 'baicheng', '0997', '842300', 'B', '81.87564', '41.79801'),
+(3259, 3252, '乌什', '乌什县', '中国,新疆维吾尔自治区,阿克苏地区,乌什县', 3, 'wushi', '0997', '843400', 'W', '79.22937', '41.21569'),
+(3260, 3252, '阿瓦提', '阿瓦提县', '中国,新疆维吾尔自治区,阿克苏地区,阿瓦提县', 3, 'awati', '0997', '843200', 'A', '80.38336', '40.63926'),
+(3261, 3252, '柯坪', '柯坪县', '中国,新疆维吾尔自治区,阿克苏地区,柯坪县', 3, 'keping', '0997', '843600', 'K', '79.04751', '40.50585'),
+(3262, 3206, '克孜勒苏', '克孜勒苏柯尔克孜自治州', '中国,新疆维吾尔自治区,克孜勒苏柯尔克孜自治州', 2, 'kizilsu', '0908', '845350', 'K', '76.172825', '39.713431'),
+(3263, 3262, '阿图什', '阿图什市', '中国,新疆维吾尔自治区,克孜勒苏柯尔克孜自治州,阿图什市', 3, 'atushi', '0908', '845350', 'A', '76.16827', '39.71615'),
+(3264, 3262, '阿克陶', '阿克陶县', '中国,新疆维吾尔自治区,克孜勒苏柯尔克孜自治州,阿克陶县', 3, 'aketao', '0908', '845550', 'A', '75.94692', '39.14892'),
+(3265, 3262, '阿合奇', '阿合奇县', '中国,新疆维吾尔自治区,克孜勒苏柯尔克孜自治州,阿合奇县', 3, 'aheqi', '0997', '843500', 'A', '78.44848', '40.93947'),
+(3266, 3262, '乌恰', '乌恰县', '中国,新疆维吾尔自治区,克孜勒苏柯尔克孜自治州,乌恰县', 3, 'wuqia', '0908', '845450', 'W', '75.25839', '39.71984'),
+(3267, 3206, '喀什', '喀什地区', '中国,新疆维吾尔自治区,喀什地区', 2, 'kashgar', '0998', '844000', 'K', '75.989138', '39.467664'),
+(3268, 3267, '喀什', '喀什市', '中国,新疆维吾尔自治区,喀什地区,喀什市', 3, 'kashi', '0998', '844000', 'K', '75.99379', '39.46768'),
+(3269, 3267, '疏附', '疏附县', '中国,新疆维吾尔自治区,喀什地区,疏附县', 3, 'shufu', '0998', '844100', 'S', '75.86029', '39.37534'),
+(3270, 3267, '疏勒', '疏勒县', '中国,新疆维吾尔自治区,喀什地区,疏勒县', 3, 'shule', '0998', '844200', 'S', '76.05398', '39.40625'),
+(3271, 3267, '英吉沙', '英吉沙县', '中国,新疆维吾尔自治区,喀什地区,英吉沙县', 3, 'yingjisha', '0998', '844500', 'Y', '76.17565', '38.92968'),
+(3272, 3267, '泽普', '泽普县', '中国,新疆维吾尔自治区,喀什地区,泽普县', 3, 'zepu', '0998', '844800', 'Z', '77.27145', '38.18935'),
+(3273, 3267, '莎车', '莎车县', '中国,新疆维吾尔自治区,喀什地区,莎车县', 3, 'shache', '0998', '844700', 'S', '77.24316', '38.41601'),
+(3274, 3267, '叶城', '叶城县', '中国,新疆维吾尔自治区,喀什地区,叶城县', 3, 'yecheng', '0998', '844900', 'Y', '77.41659', '37.88324'),
+(3275, 3267, '麦盖提', '麦盖提县', '中国,新疆维吾尔自治区,喀什地区,麦盖提县', 3, 'maigaiti', '0998', '844600', 'M', '77.64224', '38.89662'),
+(3276, 3267, '岳普湖', '岳普湖县', '中国,新疆维吾尔自治区,喀什地区,岳普湖县', 3, 'yuepuhu', '0998', '844400', 'Y', '76.77233', '39.23561'),
+(3277, 3267, '伽师', '伽师县', '中国,新疆维吾尔自治区,喀什地区,伽师县', 3, 'jiashi', '0998', '844300', NULL, '76.72372', '39.48801'),
+(3278, 3267, '巴楚', '巴楚县', '中国,新疆维吾尔自治区,喀什地区,巴楚县', 3, 'bachu', '0998', '843800', 'B', '78.54888', '39.7855'),
+(3279, 3267, '塔什库尔干塔吉克', '塔什库尔干塔吉克自治县', '中国,新疆维吾尔自治区,喀什地区,塔什库尔干塔吉克自治县', 3, 'tashikuergantajike', '0998', '845250', 'T', '75.23196', '37.77893'),
+(3280, 3206, '和田', '和田地区', '中国,新疆维吾尔自治区,和田地区', 2, 'hotan', '0903', '848000', 'H', '79.92533', '37.110687'),
+(3281, 3280, '和田市', '和田市', '中国,新疆维吾尔自治区,和田地区,和田市', 3, 'hetianshi', '0903', '848000', 'H', '79.91353', '37.11214'),
+(3282, 3280, '和田县', '和田县', '中国,新疆维吾尔自治区,和田地区,和田县', 3, 'hetianxian', '0903', '848000', 'H', '79.82874', '37.08922'),
+(3283, 3280, '墨玉', '墨玉县', '中国,新疆维吾尔自治区,和田地区,墨玉县', 3, 'moyu', '0903', '848100', 'M', '79.74035', '37.27248'),
+(3284, 3280, '皮山', '皮山县', '中国,新疆维吾尔自治区,和田地区,皮山县', 3, 'pishan', '0903', '845150', 'P', '78.28125', '37.62007'),
+(3285, 3280, '洛浦', '洛浦县', '中国,新疆维吾尔自治区,和田地区,洛浦县', 3, 'luopu', '0903', '848200', 'L', '80.18536', '37.07364'),
+(3286, 3280, '策勒', '策勒县', '中国,新疆维吾尔自治区,和田地区,策勒县', 3, 'cele', '0903', '848300', 'C', '80.80999', '36.99843'),
+(3287, 3280, '于田', '于田县', '中国,新疆维吾尔自治区,和田地区,于田县', 3, 'yutian', '0903', '848400', 'Y', '81.66717', '36.854'),
+(3288, 3280, '民丰', '民丰县', '中国,新疆维吾尔自治区,和田地区,民丰县', 3, 'minfeng', '0903', '848500', 'M', '82.68444', '37.06577'),
+(3289, 3206, '伊犁', '伊犁哈萨克自治州', '中国,新疆维吾尔自治区,伊犁哈萨克自治州', 2, 'ili', '0999', '835100', 'Y', '81.317946', '43.92186'),
+(3290, 3289, '伊宁', '伊宁市', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,伊宁市', 3, 'yining', '0999', '835000', 'Y', '81.32932', '43.91294'),
+(3291, 3289, '奎屯', '奎屯市', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,奎屯市', 3, 'kuitun', '0992', '833200', 'K', '84.90228', '44.425'),
+(3292, 3289, '霍尔果斯', '霍尔果斯市', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,霍尔果斯市', 3, 'huoerguosi', '0999', '835221', 'H', '80.418189', '44.205778'),
+(3293, 3289, '伊宁', '伊宁县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,伊宁县', 3, 'yining', '0999', '835100', 'Y', '81.52764', '43.97863'),
+(3294, 3289, '察布查尔锡伯', '察布查尔锡伯自治县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,察布查尔锡伯自治县', 3, 'chabuchaerxibo', '0999', '835300', 'C', '81.14956', '43.84023'),
+(3295, 3289, '霍城', '霍城县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,霍城县', 3, 'huocheng', '0999', '835200', 'H', '80.87826', '44.0533'),
+(3296, 3289, '巩留', '巩留县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,巩留县', 3, 'gongliu', '0999', '835400', 'G', '82.22851', '43.48429'),
+(3297, 3289, '新源', '新源县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,新源县', 3, 'xinyuan', '0999', '835800', 'X', '83.26095', '43.4284'),
+(3298, 3289, '昭苏', '昭苏县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,昭苏县', 3, 'zhaosu', '0999', '835600', 'Z', '81.1307', '43.15828'),
+(3299, 3289, '特克斯', '特克斯县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,特克斯县', 3, 'tekesi', '0999', '835500', 'T', '81.84005', '43.21938'),
+(3300, 3289, '尼勒克', '尼勒克县', '中国,新疆维吾尔自治区,伊犁哈萨克自治州,尼勒克县', 3, 'nileke', '0999', '835700', 'N', '82.51184', '43.79901'),
+(3301, 3206, '塔城', '塔城地区', '中国,新疆维吾尔自治区,塔城地区', 2, 'qoqek', '0901', '834700', 'T', '82.985732', '46.746301'),
+(3302, 3301, '塔城', '塔城市', '中国,新疆维吾尔自治区,塔城地区,塔城市', 3, 'tacheng', '0901', '834700', 'T', '82.97892', '46.74852');
+INSERT INTO `__PREFIX__area` (`id`, `pid`, `shortname`, `name`, `mergename`, `level`, `pinyin`, `code`, `zip`, `first`, `lng`, `lat`) VALUES
+(3303, 3301, '乌苏', '乌苏市', '中国,新疆维吾尔自治区,塔城地区,乌苏市', 3, 'wusu', '0992', '833000', 'W', '84.68258', '44.43729'),
+(3304, 3301, '额敏', '额敏县', '中国,新疆维吾尔自治区,塔城地区,额敏县', 3, 'emin', '0901', '834600', 'E', '83.62872', '46.5284'),
+(3305, 3301, '沙湾', '沙湾县', '中国,新疆维吾尔自治区,塔城地区,沙湾县', 3, 'shawan', '0993', '832100', 'S', '85.61932', '44.33144'),
+(3306, 3301, '托里', '托里县', '中国,新疆维吾尔自治区,塔城地区,托里县', 3, 'tuoli', '0901', '834500', 'T', '83.60592', '45.93623'),
+(3307, 3301, '裕民', '裕民县', '中国,新疆维吾尔自治区,塔城地区,裕民县', 3, 'yumin', '0901', '834800', 'Y', '82.99002', '46.20377'),
+(3308, 3301, '和布克赛尔', '和布克赛尔蒙古自治县', '中国,新疆维吾尔自治区,塔城地区,和布克赛尔蒙古自治县', 3, 'hebukesaier', '0990', '834400', 'H', '85.72662', '46.79362'),
+(3309, 3206, '阿勒泰', '阿勒泰地区', '中国,新疆维吾尔自治区,阿勒泰地区', 2, 'altay', '0906', '836500', 'A', '88.13963', '47.848393'),
+(3310, 3309, '阿勒泰', '阿勒泰市', '中国,新疆维吾尔自治区,阿勒泰地区,阿勒泰市', 3, 'aletai', '0906', '836500', 'A', '88.13913', '47.8317'),
+(3311, 3309, '布尔津', '布尔津县', '中国,新疆维吾尔自治区,阿勒泰地区,布尔津县', 3, 'buerjin', '0906', '836600', 'B', '86.85751', '47.70062'),
+(3312, 3309, '富蕴', '富蕴县', '中国,新疆维吾尔自治区,阿勒泰地区,富蕴县', 3, 'fuyun', '0906', '836100', 'F', '89.52679', '46.99444'),
+(3313, 3309, '福海', '福海县', '中国,新疆维吾尔自治区,阿勒泰地区,福海县', 3, 'fuhai', '0906', '836400', 'F', '87.49508', '47.11065'),
+(3314, 3309, '哈巴河', '哈巴河县', '中国,新疆维吾尔自治区,阿勒泰地区,哈巴河县', 3, 'habahe', '0906', '836700', 'H', '86.42092', '48.06046'),
+(3315, 3309, '青河', '青河县', '中国,新疆维吾尔自治区,阿勒泰地区,青河县', 3, 'qinghe', '0906', '836200', 'Q', '90.38305', '46.67382'),
+(3316, 3309, '吉木乃', '吉木乃县', '中国,新疆维吾尔自治区,阿勒泰地区,吉木乃县', 3, 'jimunai', '0906', '836800', 'J', '85.87814', '47.43359'),
+(3317, 3206, ' ', '直辖县级', '中国,新疆维吾尔自治区,直辖县级', 2, '', '', '', 'Z', '91.132212', '29.660361'),
+(3318, 3317, '石河子', '石河子市', '中国,新疆维吾尔自治区,直辖县级,石河子市', 3, 'shihezi', '0993', '832000', 'S', '86.041075', '44.305886'),
+(3319, 3317, '阿拉尔', '阿拉尔市', '中国,新疆维吾尔自治区,直辖县级,阿拉尔市', 3, 'aral', '0997', '843300', 'A', '81.285884', '40.541914'),
+(3320, 3317, '图木舒克', '图木舒克市', '中国,新疆维吾尔自治区,直辖县级,图木舒克市', 3, 'tumxuk', '0998', '843806', 'T', '79.077978', '39.867316'),
+(3321, 3317, '五家渠', '五家渠市', '中国,新疆维吾尔自治区,直辖县级,五家渠市', 3, 'wujiaqu', '0994', '831300', 'W', '87.526884', '44.167401'),
+(3322, 3317, '北屯', '北屯市', '中国,新疆维吾尔自治区,直辖县级,北屯市', 3, 'beitun', '0906', '836000', 'B', '87.808456', '47.362308'),
+(3323, 3317, '铁门关', '铁门关市', '中国,新疆维吾尔自治区,直辖县级,铁门关市', 3, 'tiemenguan', '0906', '836000', 'T', '86.194687', '41.811007'),
+(3324, 3317, '双河', '双河市', '中国,新疆维吾尔自治区,直辖县级,双河市', 3, 'shuanghe', '0909', '833408', 'S', '91.132212', '29.660361'),
+(3325, 0, '台湾', '台湾', '中国,台湾', 1, 'taiwan', '', '', 'T', '121.509062', '25.044332'),
+(3326, 3325, '台北', '台北市', '中国,台湾,台北市', 2, 'taipei', '02', '1', 'T', '121.565170', '25.037798'),
+(3327, 3326, '松山', '松山区', '中国,台湾,台北市,松山区', 3, 'songshan', '02', '105', 'S', '121.577206', '25.049698'),
+(3328, 3326, '信义', '信义区', '中国,台湾,台北市,信义区', 3, 'xinyi', '02', '110', 'X', '121.751381', '25.129407'),
+(3329, 3326, '大安', '大安区', '中国,台湾,台北市,大安区', 3, 'da''an', '02', '106', 'D', '121.534648', '25.026406'),
+(3330, 3326, '中山', '中山区', '中国,台湾,台北市,中山区', 3, 'zhongshan', '02', '104', 'Z', '121.533468', '25.064361'),
+(3331, 3326, '中正', '中正区', '中国,台湾,台北市,中正区', 3, 'zhongzheng', '02', '100', 'Z', '121.518267', '25.032361'),
+(3332, 3326, '大同', '大同区', '中国,台湾,台北市,大同区', 3, 'datong', '02', '103', 'D', '121.515514', '25.065986'),
+(3333, 3326, '万华', '万华区', '中国,台湾,台北市,万华区', 3, 'wanhua', '02', '108', 'W', '121.499332', '25.031933'),
+(3334, 3326, '文山', '文山区', '中国,台湾,台北市,文山区', 3, 'wenshan', '02', '116', 'W', '121.570458', '24.989786'),
+(3335, 3326, '南港', '南港区', '中国,台湾,台北市,南港区', 3, 'nangang', '02', '115', 'N', '121.606858', '25.054656'),
+(3336, 3326, '内湖', '内湖区', '中国,台湾,台北市,内湖区', 3, 'nahu', '02', '114', 'N', '121.588998', '25.069664'),
+(3337, 3326, '士林', '士林区', '中国,台湾,台北市,士林区', 3, 'shilin', '02', '111', 'S', '121.519874', '25.092822'),
+(3338, 3326, '北投', '北投区', '中国,台湾,台北市,北投区', 3, 'beitou', '02', '112', 'B', '121.501379', '25.132419'),
+(3339, 3325, '高雄', '高雄市', '中国,台湾,高雄市', 2, 'kaohsiung', '07', '8', 'G', '120.311922', '22.620856'),
+(3340, 3339, '盐埕', '盐埕区', '中国,台湾,高雄市,盐埕区', 3, 'yancheng', '07', '803', 'Y', '120.286795', '22.624666'),
+(3341, 3339, '鼓山', '鼓山区', '中国,台湾,高雄市,鼓山区', 3, 'gushan', '07', '804', 'G', '120.281154', '22.636797'),
+(3342, 3339, '左营', '左营区', '中国,台湾,高雄市,左营区', 3, 'zuoying', '07', '813', 'Z', '120.294958', '22.690124'),
+(3343, 3339, '楠梓', '楠梓区', '中国,台湾,高雄市,楠梓区', 3, 'nanzi', '07', '811', NULL, '120.326314', '22.728401'),
+(3344, 3339, '三民', '三民区', '中国,台湾,高雄市,三民区', 3, 'sanmin', '07', '807', 'S', '120.299622', '22.647695'),
+(3345, 3339, '新兴', '新兴区', '中国,台湾,高雄市,新兴区', 3, 'xinxing', '07', '800', 'X', '120.309535', '22.631147'),
+(3346, 3339, '前金', '前金区', '中国,台湾,高雄市,前金区', 3, 'qianjin', '07', '801', 'Q', '120.294159', '22.627421'),
+(3347, 3339, '苓雅', '苓雅区', '中国,台湾,高雄市,苓雅区', 3, 'lingya', '07', '802', NULL, '120.312347', '22.621770'),
+(3348, 3339, '前镇', '前镇区', '中国,台湾,高雄市,前镇区', 3, 'qianzhen', '07', '806', 'Q', '120.318583', '22.586425'),
+(3349, 3339, '旗津', '旗津区', '中国,台湾,高雄市,旗津区', 3, 'qijin', '07', '805', 'Q', '120.284429', '22.590565'),
+(3350, 3339, '小港', '小港区', '中国,台湾,高雄市,小港区', 3, 'xiaogang', '07', '812', 'X', '120.337970', '22.565354'),
+(3351, 3339, '凤山', '凤山区', '中国,台湾,高雄市,凤山区', 3, 'fengshan', '07', '830', 'F', '120.356892', '22.626945'),
+(3352, 3339, '林园', '林园区', '中国,台湾,高雄市,林园区', 3, 'linyuan', '07', '832', 'L', '120.395977', '22.501490'),
+(3353, 3339, '大寮', '大寮区', '中国,台湾,高雄市,大寮区', 3, 'daliao', '07', '831', 'D', '120.395422', '22.605386'),
+(3354, 3339, '大树', '大树区', '中国,台湾,高雄市,大树区', 3, 'dashu', '07', '840', 'D', '120.433095', '22.693394'),
+(3355, 3339, '大社', '大社区', '中国,台湾,高雄市,大社区', 3, 'dashe', '07', '815', 'D', '120.346635', '22.729966'),
+(3356, 3339, '仁武', '仁武区', '中国,台湾,高雄市,仁武区', 3, 'renwu', '07', '814', 'R', '120.347779', '22.701901'),
+(3357, 3339, '鸟松', '鸟松区', '中国,台湾,高雄市,鸟松区', 3, 'niaosong', '07', '833', 'N', '120.364402', '22.659340'),
+(3358, 3339, '冈山', '冈山区', '中国,台湾,高雄市,冈山区', 3, 'gangshan', '07', '820', 'G', '120.295820', '22.796762'),
+(3359, 3339, '桥头', '桥头区', '中国,台湾,高雄市,桥头区', 3, 'qiaotou', '07', '825', 'Q', '120.305741', '22.757501'),
+(3360, 3339, '燕巢', '燕巢区', '中国,台湾,高雄市,燕巢区', 3, 'yanchao', '07', '824', 'Y', '120.361956', '22.793370'),
+(3361, 3339, '田寮', '田寮区', '中国,台湾,高雄市,田寮区', 3, 'tianliao', '07', '823', 'T', '120.359636', '22.869307'),
+(3362, 3339, '阿莲', '阿莲区', '中国,台湾,高雄市,阿莲区', 3, 'alian', '07', '822', 'A', '120.327036', '22.883703'),
+(3363, 3339, '路竹', '路竹区', '中国,台湾,高雄市,路竹区', 3, 'luzhu', '07', '821', 'L', '120.261828', '22.856851'),
+(3364, 3339, '湖内', '湖内区', '中国,台湾,高雄市,湖内区', 3, 'huna', '07', '829', 'H', '120.211530', '22.908188'),
+(3365, 3339, '茄萣', '茄萣区', '中国,台湾,高雄市,茄萣区', 3, 'qieding', '07', '852', NULL, '120.182815', '22.906556'),
+(3366, 3339, '永安', '永安区', '中国,台湾,高雄市,永安区', 3, 'yong''an', '07', '828', 'Y', '120.225308', '22.818580'),
+(3367, 3339, '弥陀', '弥陀区', '中国,台湾,高雄市,弥陀区', 3, 'mituo', '07', '827', 'M', '120.247344', '22.782879'),
+(3368, 3339, '梓官', '梓官区', '中国,台湾,高雄市,梓官区', 3, 'ziguan', '07', '826', NULL, '120.267322', '22.760475'),
+(3369, 3339, '旗山', '旗山区', '中国,台湾,高雄市,旗山区', 3, 'qishan', '07', '842', 'Q', '120.483550', '22.888491'),
+(3370, 3339, '美浓', '美浓区', '中国,台湾,高雄市,美浓区', 3, 'meinong', '07', '843', 'M', '120.541530', '22.897880'),
+(3371, 3339, '六龟', '六龟区', '中国,台湾,高雄市,六龟区', 3, 'liugui', '07', '844', 'L', '120.633418', '22.997914'),
+(3372, 3339, '甲仙', '甲仙区', '中国,台湾,高雄市,甲仙区', 3, 'jiaxian', '07', '847', 'J', '120.591185', '23.084688'),
+(3373, 3339, '杉林', '杉林区', '中国,台湾,高雄市,杉林区', 3, 'shanlin', '07', '846', 'S', '120.538980', '22.970712'),
+(3374, 3339, '内门', '内门区', '中国,台湾,高雄市,内门区', 3, 'namen', '07', '845', 'N', '120.462351', '22.943437'),
+(3375, 3339, '茂林', '茂林区', '中国,台湾,高雄市,茂林区', 3, 'maolin', '07', '851', 'M', '120.663217', '22.886248'),
+(3376, 3339, '桃源', '桃源区', '中国,台湾,高雄市,桃源区', 3, 'taoyuan', '07', '848', 'T', '120.760049', '23.159137'),
+(3377, 3339, '那玛夏', '那玛夏区', '中国,台湾,高雄市,那玛夏区', 3, 'namaxia', '07', '849', 'N', '120.692799', '23.216964'),
+(3378, 3325, '基隆', '基隆市', '中国,台湾,基隆市', 2, 'keelung', '02', '2', 'J', '121.746248', '25.130741'),
+(3379, 3378, '中正', '中正区', '中国,台湾,基隆市,中正区', 3, 'zhongzheng', '02', '202', 'Z', '121.518267', '25.032361'),
+(3380, 3378, '七堵', '七堵区', '中国,台湾,基隆市,七堵区', 3, 'qidu', '02', '206', 'Q', '121.713032', '25.095739'),
+(3381, 3378, '暖暖', '暖暖区', '中国,台湾,基隆市,暖暖区', 3, 'nuannuan', '02', '205', 'N', '121.736102', '25.099777'),
+(3382, 3378, '仁爱', '仁爱区', '中国,台湾,基隆市,仁爱区', 3, 'renai', '02', '200', 'R', '121.740940', '25.127526'),
+(3383, 3378, '中山', '中山区', '中国,台湾,基隆市,中山区', 3, 'zhongshan', '02', '203', 'Z', '121.739132', '25.133991'),
+(3384, 3378, '安乐', '安乐区', '中国,台湾,基隆市,安乐区', 3, 'anle', '02', '204', 'A', '121.723203', '25.120910'),
+(3385, 3378, '信义', '信义区', '中国,台湾,基隆市,信义区', 3, 'xinyi', '02', '201', 'X', '121.751381', '25.129407'),
+(3386, 3325, '台中', '台中市', '中国,台湾,台中市', 2, 'taichung', '04', '4', 'T', '120.679040', '24.138620'),
+(3387, 3386, '中区', '中区', '中国,台湾,台中市,中区', 3, 'zhongqu', '04', '400', 'Z', '120.679510', '24.143830'),
+(3388, 3386, '东区', '东区', '中国,台湾,台中市,东区', 3, 'dongqu', '04', '401', 'D', '120.704', '24.13662'),
+(3389, 3386, '南区', '南区', '中国,台湾,台中市,南区', 3, 'nanqu', '04', '402', 'N', '120.188648', '22.960944'),
+(3390, 3386, '西区', '西区', '中国,台湾,台中市,西区', 3, 'xiqu', '04', '403', 'X', '120.67104', '24.14138'),
+(3391, 3386, '北区', '北区', '中国,台湾,台中市,北区', 3, 'beiqu', '04', '404', 'B', '120.682410', '24.166040'),
+(3392, 3386, '西屯', '西屯区', '中国,台湾,台中市,西屯区', 3, 'xitun', '04', '407', 'X', '120.639820', '24.181340'),
+(3393, 3386, '南屯', '南屯区', '中国,台湾,台中市,南屯区', 3, 'nantun', '04', '408', 'N', '120.643080', '24.138270'),
+(3394, 3386, '北屯', '北屯区', '中国,台湾,台中市,北屯区', 3, 'beitun', '04', '406', 'B', '120.686250', '24.182220'),
+(3395, 3386, '丰原', '丰原区', '中国,台湾,台中市,丰原区', 3, 'fengyuan', '04', '420', 'F', '120.718460', '24.242190'),
+(3396, 3386, '东势', '东势区', '中国,台湾,台中市,东势区', 3, 'dongshi', '04', '423', 'D', '120.827770', '24.258610'),
+(3397, 3386, '大甲', '大甲区', '中国,台湾,台中市,大甲区', 3, 'dajia', '04', '437', 'D', '120.622390', '24.348920'),
+(3398, 3386, '清水', '清水区', '中国,台湾,台中市,清水区', 3, 'qingshui', '04', '436', 'Q', '120.559780', '24.268650'),
+(3399, 3386, '沙鹿', '沙鹿区', '中国,台湾,台中市,沙鹿区', 3, 'shalu', '04', '433', 'S', '120.565700', '24.233480'),
+(3400, 3386, '梧栖', '梧栖区', '中国,台湾,台中市,梧栖区', 3, 'wuqi', '04', '435', 'W', '120.531520', '24.254960'),
+(3401, 3386, '后里', '后里区', '中国,台湾,台中市,后里区', 3, 'houli', '04', '421', 'H', '120.710710', '24.304910'),
+(3402, 3386, '神冈', '神冈区', '中国,台湾,台中市,神冈区', 3, 'shengang', '04', '429', 'S', '120.661550', '24.257770'),
+(3403, 3386, '潭子', '潭子区', '中国,台湾,台中市,潭子区', 3, 'tanzi', '04', '427', 'T', '120.705160', '24.209530'),
+(3404, 3386, '大雅', '大雅区', '中国,台湾,台中市,大雅区', 3, 'daya', '04', '428', 'D', '120.647780', '24.229230'),
+(3405, 3386, '新社', '新社区', '中国,台湾,台中市,新社区', 3, 'xinshe', '04', '426', 'X', '120.809500', '24.234140'),
+(3406, 3386, '石冈', '石冈区', '中国,台湾,台中市,石冈区', 3, 'shigang', '04', '422', 'S', '120.780410', '24.274980'),
+(3407, 3386, '外埔', '外埔区', '中国,台湾,台中市,外埔区', 3, 'waipu', '04', '438', 'W', '120.654370', '24.332010'),
+(3408, 3386, '大安', '大安区', '中国,台湾,台中市,大安区', 3, 'da''an', '04', '439', 'D', '120.58652', '24.34607'),
+(3409, 3386, '乌日', '乌日区', '中国,台湾,台中市,乌日区', 3, 'wuri', '04', '414', 'W', '120.623810', '24.104500'),
+(3410, 3386, '大肚', '大肚区', '中国,台湾,台中市,大肚区', 3, 'dadu', '04', '432', 'D', '120.540960', '24.153660'),
+(3411, 3386, '龙井', '龙井区', '中国,台湾,台中市,龙井区', 3, 'longjing', '04', '434', 'L', '120.545940', '24.192710'),
+(3412, 3386, '雾峰', '雾峰区', '中国,台湾,台中市,雾峰区', 3, 'wufeng', '04', '413', 'W', '120.700200', '24.061520'),
+(3413, 3386, '太平', '太平区', '中国,台湾,台中市,太平区', 3, 'taiping', '04', '411', 'T', '120.718523', '24.126472'),
+(3414, 3386, '大里', '大里区', '中国,台湾,台中市,大里区', 3, 'dali', '04', '412', 'D', '120.677860', '24.099390'),
+(3415, 3386, '和平', '和平区', '中国,台湾,台中市,和平区', 3, 'heping', '04', '424', 'H', '120.88349', '24.17477'),
+(3416, 3325, '台南', '台南市', '中国,台湾,台南市', 2, 'tainan', '06', '7', 'T', '120.279363', '23.172478'),
+(3417, 3416, '东区', '东区', '中国,台湾,台南市,东区', 3, 'dongqu', '06', '701', 'D', '120.224198', '22.980072'),
+(3418, 3416, '南区', '南区', '中国,台湾,台南市,南区', 3, 'nanqu', '06', '702', 'N', '120.188648', '22.960944'),
+(3419, 3416, '北区', '北区', '中国,台湾,台南市,北区', 3, 'beiqu', '06', '704', 'B', '120.682410', '24.166040'),
+(3420, 3416, '安南', '安南区', '中国,台湾,台南市,安南区', 3, 'annan', '06', '709', 'A', '120.184617', '23.047230'),
+(3421, 3416, '安平', '安平区', '中国,台湾,台南市,安平区', 3, 'anping', '06', '708', 'A', '120.166810', '23.000763'),
+(3422, 3416, '中西', '中西区', '中国,台湾,台南市,中西区', 3, 'zhongxi', '06', '700', 'Z', '120.205957', '22.992152'),
+(3423, 3416, '新营', '新营区', '中国,台湾,台南市,新营区', 3, 'xinying', '06', '730', 'X', '120.316698', '23.310274'),
+(3424, 3416, '盐水', '盐水区', '中国,台湾,台南市,盐水区', 3, 'yanshui', '06', '737', 'Y', '120.266398', '23.319828'),
+(3425, 3416, '白河', '白河区', '中国,台湾,台南市,白河区', 3, 'baihe', '06', '732', 'B', '120.415810', '23.351221'),
+(3426, 3416, '柳营', '柳营区', '中国,台湾,台南市,柳营区', 3, 'liuying', '06', '736', 'L', '120.311286', '23.278133'),
+(3427, 3416, '后壁', '后壁区', '中国,台湾,台南市,后壁区', 3, 'houbi', '06', '731', 'H', '120.362726', '23.366721'),
+(3428, 3416, '东山', '东山区', '中国,台湾,台南市,东山区', 3, 'dongshan', '06', '733', 'D', '120.403984', '23.326092'),
+(3429, 3416, '麻豆', '麻豆区', '中国,台湾,台南市,麻豆区', 3, 'madou', '06', '721', 'M', '120.248179', '23.181680'),
+(3430, 3416, '下营', '下营区', '中国,台湾,台南市,下营区', 3, 'xiaying', '06', '735', 'X', '120.264484', '23.235413'),
+(3431, 3416, '六甲', '六甲区', '中国,台湾,台南市,六甲区', 3, 'liujia', '06', '734', 'L', '120.347600', '23.231931'),
+(3432, 3416, '官田', '官田区', '中国,台湾,台南市,官田区', 3, 'guantian', '06', '720', 'G', '120.314374', '23.194652'),
+(3433, 3416, '大内', '大内区', '中国,台湾,台南市,大内区', 3, 'dana', '06', '742', 'D', '120.348853', '23.119460'),
+(3434, 3416, '佳里', '佳里区', '中国,台湾,台南市,佳里区', 3, 'jiali', '06', '722', 'J', '120.177211', '23.165121'),
+(3435, 3416, '学甲', '学甲区', '中国,台湾,台南市,学甲区', 3, 'xuejia', '06', '726', 'X', '120.180255', '23.232348'),
+(3436, 3416, '西港', '西港区', '中国,台湾,台南市,西港区', 3, 'xigang', '06', '723', 'X', '120.203618', '23.123057'),
+(3437, 3416, '七股', '七股区', '中国,台湾,台南市,七股区', 3, 'qigu', '06', '724', 'Q', '120.140003', '23.140545'),
+(3438, 3416, '将军', '将军区', '中国,台湾,台南市,将军区', 3, 'jiangjun', '06', '725', 'J', '120.156871', '23.199543'),
+(3439, 3416, '北门', '北门区', '中国,台湾,台南市,北门区', 3, 'beimen', '06', '727', 'B', '120.125821', '23.267148'),
+(3440, 3416, '新化', '新化区', '中国,台湾,台南市,新化区', 3, 'xinhua', '06', '712', 'X', '120.310807', '23.038533'),
+(3441, 3416, '善化', '善化区', '中国,台湾,台南市,善化区', 3, 'shanhua', '06', '741', 'S', '120.296895', '23.132261'),
+(3442, 3416, '新市', '新市区', '中国,台湾,台南市,新市区', 3, 'xinshi', '06', '744', 'X', '120.295138', '23.07897'),
+(3443, 3416, '安定', '安定区', '中国,台湾,台南市,安定区', 3, 'anding', '06', '745', 'A', '120.237083', '23.121498'),
+(3444, 3416, '山上', '山上区', '中国,台湾,台南市,山上区', 3, 'shanshang', '06', '743', 'S', '120.352908', '23.103223'),
+(3445, 3416, '玉井', '玉井区', '中国,台湾,台南市,玉井区', 3, 'yujing', '06', '714', 'Y', '120.460110', '23.123859'),
+(3446, 3416, '楠西', '楠西区', '中国,台湾,台南市,楠西区', 3, 'nanxi', '06', '715', NULL, '120.485396', '23.173454'),
+(3447, 3416, '南化', '南化区', '中国,台湾,台南市,南化区', 3, 'nanhua', '06', '716', 'N', '120.477116', '23.042614'),
+(3448, 3416, '左镇', '左镇区', '中国,台湾,台南市,左镇区', 3, 'zuozhen', '06', '713', 'Z', '120.407309', '23.057955'),
+(3449, 3416, '仁德', '仁德区', '中国,台湾,台南市,仁德区', 3, 'rende', '06', '717', 'R', '120.251520', '22.972212'),
+(3450, 3416, '归仁', '归仁区', '中国,台湾,台南市,归仁区', 3, 'guiren', '06', '711', 'G', '120.293791', '22.967081'),
+(3451, 3416, '关庙', '关庙区', '中国,台湾,台南市,关庙区', 3, 'guanmiao', '06', '718', 'G', '120.327689', '22.962949'),
+(3452, 3416, '龙崎', '龙崎区', '中国,台湾,台南市,龙崎区', 3, 'longqi', '06', '719', 'L', '120.360824', '22.965681'),
+(3453, 3416, '永康', '永康区', '中国,台湾,台南市,永康区', 3, 'yongkang', '06', '710', 'Y', '120.257069', '23.026061'),
+(3454, 3325, '新竹', '新竹市', '中国,台湾,新竹市', 2, 'hsinchu', '03', '3', 'X', '120.968798', '24.806738'),
+(3455, 3454, '东区', '东区', '中国,台湾,新竹市,东区', 3, 'dongqu', '03', '300', 'D', '120.970239', '24.801337'),
+(3456, 3454, '北区', '北区', '中国,台湾,新竹市,北区', 3, 'beiqu', '03', '', 'B', '120.682410', '24.166040'),
+(3457, 3454, '香山', '香山区', '中国,台湾,新竹市,香山区', 3, 'xiangshan', '03', '', 'X', '120.956679', '24.768933'),
+(3458, 3325, '嘉义', '嘉义市', '中国,台湾,嘉义市', 2, 'chiayi', '05', '6', 'J', '120.452538', '23.481568'),
+(3459, 3458, '东区', '东区', '中国,台湾,嘉义市,东区', 3, 'dongqu', '05', '600', 'D', '120.458009', '23.486213'),
+(3460, 3458, '西区', '西区', '中国,台湾,嘉义市,西区', 3, 'xiqu', '05', '600', 'X', '120.437493', '23.473029'),
+(3461, 3325, '新北', '新北市', '中国,台湾,新北市', 2, 'newtaipei', '02', '2', 'X', '121.465746', '25.012366'),
+(3462, 3461, '板桥', '板桥区', '中国,台湾,新北市,板桥区', 3, 'banqiao', '02', '220', 'B', '121.459084', '25.009578'),
+(3463, 3461, '三重', '三重区', '中国,台湾,新北市,三重区', 3, 'sanzhong', '02', '241', 'S', '121.488102', '25.061486'),
+(3464, 3461, '中和', '中和区', '中国,台湾,新北市,中和区', 3, 'zhonghe', '02', '235', 'Z', '121.498980', '24.999397'),
+(3465, 3461, '永和', '永和区', '中国,台湾,新北市,永和区', 3, 'yonghe', '02', '234', 'Y', '121.513660', '25.007802'),
+(3466, 3461, '新庄', '新庄区', '中国,台湾,新北市,新庄区', 3, 'xinzhuang', '02', '242', 'X', '121.450413', '25.035947'),
+(3467, 3461, '新店', '新店区', '中国,台湾,新北市,新店区', 3, 'xindian', '02', '231', 'X', '121.541750', '24.967558'),
+(3468, 3461, '树林', '树林区', '中国,台湾,新北市,树林区', 3, 'shulin', '02', '238', 'S', '121.420533', '24.990706'),
+(3469, 3461, '莺歌', '莺歌区', '中国,台湾,新北市,莺歌区', 3, 'yingge', '02', '239', NULL, '121.354573', '24.955413'),
+(3470, 3461, '三峡', '三峡区', '中国,台湾,新北市,三峡区', 3, 'sanxia', '02', '237', 'S', '121.368905', '24.934339'),
+(3471, 3461, '淡水', '淡水区', '中国,台湾,新北市,淡水区', 3, 'danshui', '02', '251', 'D', '121.440915', '25.169452'),
+(3472, 3461, '汐止', '汐止区', '中国,台湾,新北市,汐止区', 3, 'xizhi', '02', '221', 'X', '121.629470', '25.062999'),
+(3473, 3461, '瑞芳', '瑞芳区', '中国,台湾,新北市,瑞芳区', 3, 'ruifang', '02', '224', 'R', '121.810061', '25.108895'),
+(3474, 3461, '土城', '土城区', '中国,台湾,新北市,土城区', 3, 'tucheng', '02', '236', 'T', '121.443348', '24.972201'),
+(3475, 3461, '芦洲', '芦洲区', '中国,台湾,新北市,芦洲区', 3, 'luzhou', '02', '247', 'L', '121.473700', '25.084923'),
+(3476, 3461, '五股', '五股区', '中国,台湾,新北市,五股区', 3, 'wugu', '02', '248', 'W', '121.438156', '25.082743'),
+(3477, 3461, '泰山', '泰山区', '中国,台湾,新北市,泰山区', 3, 'taishan', '02', '243', 'T', '121.430811', '25.058864'),
+(3478, 3461, '林口', '林口区', '中国,台湾,新北市,林口区', 3, 'linkou', '02', '244', 'L', '121.391602', '25.077531'),
+(3479, 3461, '深坑', '深坑区', '中国,台湾,新北市,深坑区', 3, 'shenkeng', '02', '222', 'S', '121.615670', '25.002329'),
+(3480, 3461, '石碇', '石碇区', '中国,台湾,新北市,石碇区', 3, 'shiding', '02', '223', 'S', '121.658567', '24.991679'),
+(3481, 3461, '坪林', '坪林区', '中国,台湾,新北市,坪林区', 3, 'pinglin', '02', '232', 'P', '121.711185', '24.937388'),
+(3482, 3461, '三芝', '三芝区', '中国,台湾,新北市,三芝区', 3, 'sanzhi', '02', '252', 'S', '121.500866', '25.258047'),
+(3483, 3461, '石门', '石门区', '中国,台湾,新北市,石门区', 3, 'shimen', '02', '253', 'S', '121.568491', '25.290412'),
+(3484, 3461, '八里', '八里区', '中国,台湾,新北市,八里区', 3, 'bali', '02', '249', 'B', '121.398227', '25.146680'),
+(3485, 3461, '平溪', '平溪区', '中国,台湾,新北市,平溪区', 3, 'pingxi', '02', '226', 'P', '121.738255', '25.025725'),
+(3486, 3461, '双溪', '双溪区', '中国,台湾,新北市,双溪区', 3, 'shuangxi', '02', '227', 'S', '121.865676', '25.033409'),
+(3487, 3461, '贡寮', '贡寮区', '中国,台湾,新北市,贡寮区', 3, 'gongliao', '02', '228', 'G', '121.908185', '25.022388'),
+(3488, 3461, '金山', '金山区', '中国,台湾,新北市,金山区', 3, 'jinshan', '02', '208', 'J', '121.636427', '25.221883'),
+(3489, 3461, '万里', '万里区', '中国,台湾,新北市,万里区', 3, 'wanli', '02', '207', 'W', '121.688687', '25.181234'),
+(3490, 3461, '乌来', '乌来区', '中国,台湾,新北市,乌来区', 3, 'wulai', '02', '233', 'W', '121.550531', '24.865296'),
+(3491, 3325, '宜兰', '宜兰县', '中国,台湾,宜兰县', 2, 'yilan', '03', '2', 'Y', '121.500000', '24.600000'),
+(3492, 3491, '宜兰', '宜兰市', '中国,台湾,宜兰县,宜兰市', 3, 'yilan', '03', '260', 'Y', '121.753476', '24.751682'),
+(3493, 3491, '罗东', '罗东镇', '中国,台湾,宜兰县,罗东镇', 3, 'luodong', '03', '265', 'L', '121.766919', '24.677033'),
+(3494, 3491, '苏澳', '苏澳镇', '中国,台湾,宜兰县,苏澳镇', 3, 'suao', '03', '270', 'S', '121.842656', '24.594622'),
+(3495, 3491, '头城', '头城镇', '中国,台湾,宜兰县,头城镇', 3, 'toucheng', '03', '261', 'T', '121.823307', '24.859217'),
+(3496, 3491, '礁溪', '礁溪乡', '中国,台湾,宜兰县,礁溪乡', 3, 'jiaoxi', '03', '262', 'J', '121.766680', '24.822345'),
+(3497, 3491, '壮围', '壮围乡', '中国,台湾,宜兰县,壮围乡', 3, 'zhuangwei', '03', '263', 'Z', '121.781619', '24.744949'),
+(3498, 3491, '员山', '员山乡', '中国,台湾,宜兰县,员山乡', 3, 'yuanshan', '03', '264', 'Y', '121.721733', '24.741771'),
+(3499, 3491, '冬山', '冬山乡', '中国,台湾,宜兰县,冬山乡', 3, 'dongshan', '03', '269', 'D', '121.792280', '24.634514'),
+(3500, 3491, '五结', '五结乡', '中国,台湾,宜兰县,五结乡', 3, 'wujie', '03', '268', 'W', '121.798297', '24.684640'),
+(3501, 3491, '三星', '三星乡', '中国,台湾,宜兰县,三星乡', 3, 'sanxing', '03', '266', 'S', '121.003418', '23.775291'),
+(3502, 3491, '大同', '大同乡', '中国,台湾,宜兰县,大同乡', 3, 'datong', '03', '267', 'D', '121.605557', '24.675997'),
+(3503, 3491, '南澳', '南澳乡', '中国,台湾,宜兰县,南澳乡', 3, 'nanao', '03', '272', 'N', '121.799810', '24.465393'),
+(3504, 3325, '桃园', '桃园县', '中国,台湾,桃园县', 2, 'taoyuan', '03', '3', 'T', '121.083000', '25.000000'),
+(3505, 3504, '桃园', '桃园市', '中国,台湾,桃园县,桃园市', 3, 'taoyuan', '03', '330', 'T', '121.301337', '24.993777'),
+(3506, 3504, '中坜', '中坜市', '中国,台湾,桃园县,中坜市', 3, 'zhongli', '03', '320', 'Z', '121.224926', '24.965353'),
+(3507, 3504, '平镇', '平镇市', '中国,台湾,桃园县,平镇市', 3, 'pingzhen', '03', '324', 'P', '121.218359', '24.945752'),
+(3508, 3504, '八德', '八德市', '中国,台湾,桃园县,八德市', 3, 'bade', '03', '334', 'B', '121.284655', '24.928651'),
+(3509, 3504, '杨梅', '杨梅市', '中国,台湾,桃园县,杨梅市', 3, 'yangmei', '03', '326', 'Y', '121.145873', '24.907575'),
+(3510, 3504, '芦竹', '芦竹市', '中国,台湾,桃园县,芦竹市', 3, 'luzhu', '03', '338', 'L', '121.292064', '25.045392'),
+(3511, 3504, '大溪', '大溪镇', '中国,台湾,桃园县,大溪镇', 3, 'daxi', '03', '335', 'D', '121.286962', '24.880584'),
+(3512, 3504, '大园', '大园乡', '中国,台湾,桃园县,大园乡', 3, 'dayuan', '03', '337', 'D', '121.196292', '25.064471'),
+(3513, 3504, '龟山', '龟山乡', '中国,台湾,桃园县,龟山乡', 3, 'guishan', '03', '333', 'G', '121.337767', '24.992517'),
+(3514, 3504, '龙潭', '龙潭乡', '中国,台湾,桃园县,龙潭乡', 3, 'longtan', '03', '325', 'L', '121.216392', '24.863851'),
+(3515, 3504, '新屋', '新屋乡', '中国,台湾,桃园县,新屋乡', 3, 'xinwu', '03', '327', 'X', '121.105801', '24.972203'),
+(3516, 3504, '观音', '观音乡', '中国,台湾,桃园县,观音乡', 3, 'guanyin', '03', '328', 'G', '121.077519', '25.033303'),
+(3517, 3504, '复兴', '复兴乡', '中国,台湾,桃园县,复兴乡', 3, 'fuxing', '03', '336', 'F', '121.352613', '24.820908'),
+(3518, 3325, '新竹', '新竹县', '中国,台湾,新竹县', 2, 'hsinchu', '03', '3', 'X', '121.160000', '24.600000'),
+(3519, 3518, '竹北', '竹北市', '中国,台湾,新竹县,竹北市', 3, 'zhubei', '03', '302', 'Z', '121.004317', '24.839652'),
+(3520, 3518, '竹东', '竹东镇', '中国,台湾,新竹县,竹东镇', 3, 'zhudong', '03', '310', 'Z', '121.086418', '24.733601'),
+(3521, 3518, '新埔', '新埔镇', '中国,台湾,新竹县,新埔镇', 3, 'xinpu', '03', '305', 'X', '121.072804', '24.824820'),
+(3522, 3518, '关西', '关西镇', '中国,台湾,新竹县,关西镇', 3, 'guanxi', '03', '306', 'G', '121.177301', '24.788842'),
+(3523, 3518, '湖口', '湖口乡', '中国,台湾,新竹县,湖口乡', 3, 'hukou', '03', '303', 'H', '121.043691', '24.903943'),
+(3524, 3518, '新丰', '新丰乡', '中国,台湾,新竹县,新丰乡', 3, 'xinfeng', '03', '304', 'X', '120.983006', '24.899600'),
+(3525, 3518, '芎林', '芎林乡', '中国,台湾,新竹县,芎林乡', 3, 'xionglin', '03', '307', NULL, '121.076924', '24.774436'),
+(3526, 3518, '横山', '横山乡', '中国,台湾,新竹县,横山乡', 3, 'hengshan', '03', '312', 'H', '121.116244', '24.720807'),
+(3527, 3518, '北埔', '北埔乡', '中国,台湾,新竹县,北埔乡', 3, 'beipu', '03', '314', 'B', '121.053156', '24.697126'),
+(3528, 3518, '宝山', '宝山乡', '中国,台湾,新竹县,宝山乡', 3, 'baoshan', '03', '308', 'B', '120.985752', '24.760975'),
+(3529, 3518, '峨眉', '峨眉乡', '中国,台湾,新竹县,峨眉乡', 3, 'emei', '03', '315', 'E', '121.015291', '24.686127'),
+(3530, 3518, '尖石', '尖石乡', '中国,台湾,新竹县,尖石乡', 3, 'jianshi', '03', '313', 'J', '121.197802', '24.704360'),
+(3531, 3518, '五峰', '五峰乡', '中国,台湾,新竹县,五峰乡', 3, 'wufeng', '03', '311', 'W', '121.003418', '23.775291'),
+(3532, 3325, '苗栗', '苗栗县', '中国,台湾,苗栗县', 2, 'miaoli', '037', '3', 'M', '120.750000', '24.500000'),
+(3533, 3532, '苗栗', '苗栗市', '中国,台湾,苗栗县,苗栗市', 3, 'miaoli', '037', '360', 'M', '120.818869', '24.561472'),
+(3534, 3532, '苑里', '苑里镇', '中国,台湾,苗栗县,苑里镇', 3, 'yuanli', '037', '358', 'Y', '120.648907', '24.441750'),
+(3535, 3532, '通霄', '通霄镇', '中国,台湾,苗栗县,通霄镇', 3, 'tongxiao', '037', '357', 'T', '120.676700', '24.489087'),
+(3536, 3532, '竹南', '竹南镇', '中国,台湾,苗栗县,竹南镇', 3, 'zhunan', '037', '350', 'Z', '120.872641', '24.685513'),
+(3537, 3532, '头份', '头份镇', '中国,台湾,苗栗县,头份镇', 3, 'toufen', '037', '351', 'T', '120.895188', '24.687993'),
+(3538, 3532, '后龙', '后龙镇', '中国,台湾,苗栗县,后龙镇', 3, 'houlong', '037', '356', 'H', '120.786480', '24.612617'),
+(3539, 3532, '卓兰', '卓兰镇', '中国,台湾,苗栗县,卓兰镇', 3, 'zhuolan', '037', '369', 'Z', '120.823441', '24.309509'),
+(3540, 3532, '大湖', '大湖乡', '中国,台湾,苗栗县,大湖乡', 3, 'dahu', '037', '364', 'D', '120.863641', '24.422547'),
+(3541, 3532, '公馆', '公馆乡', '中国,台湾,苗栗县,公馆乡', 3, 'gongguan', '037', '363', 'G', '120.822983', '24.499108'),
+(3542, 3532, '铜锣', '铜锣乡', '中国,台湾,苗栗县,铜锣乡', 3, 'tongluo', '037', '366', 'T', '121.003418', '23.775291'),
+(3543, 3532, '南庄', '南庄乡', '中国,台湾,苗栗县,南庄乡', 3, 'nanzhuang', '037', '353', 'N', '120.994957', '24.596835'),
+(3544, 3532, '头屋', '头屋乡', '中国,台湾,苗栗县,头屋乡', 3, 'touwu', '037', '362', 'T', '120.846616', '24.574249'),
+(3545, 3532, '三义', '三义乡', '中国,台湾,苗栗县,三义乡', 3, 'sanyi', '037', '367', 'S', '120.742340', '24.350270'),
+(3546, 3532, '西湖', '西湖乡', '中国,台湾,苗栗县,西湖乡', 3, 'xihu', '037', '368', 'X', '121.003418', '23.775291'),
+(3547, 3532, '造桥', '造桥乡', '中国,台湾,苗栗县,造桥乡', 3, 'zaoqiao', '037', '361', 'Z', '120.862399', '24.637537'),
+(3548, 3532, '三湾', '三湾乡', '中国,台湾,苗栗县,三湾乡', 3, 'sanwan', '037', '352', 'S', '120.951484', '24.651051'),
+(3549, 3532, '狮潭', '狮潭乡', '中国,台湾,苗栗县,狮潭乡', 3, 'shitan', '037', '354', 'S', '120.918024', '24.540004'),
+(3550, 3532, '泰安', '泰安乡', '中国,台湾,苗栗县,泰安乡', 3, 'tai''an', '037', '365', 'T', '120.904441', '24.442600'),
+(3551, 3325, '彰化', '彰化县', '中国,台湾,彰化县', 2, 'changhua', '04', '5', 'Z', '120.416000', '24.000000'),
+(3552, 3551, '彰化市', '彰化市', '中国,台湾,彰化县,彰化市', 3, 'zhanghuashi', '04', '500', 'Z', '120.542294', '24.080911'),
+(3553, 3551, '鹿港', '鹿港镇', '中国,台湾,彰化县,鹿港镇', 3, 'lugang', '04', '505', 'L', '120.435392', '24.056937'),
+(3554, 3551, '和美', '和美镇', '中国,台湾,彰化县,和美镇', 3, 'hemei', '04', '508', 'H', '120.500265', '24.110904'),
+(3555, 3551, '线西', '线西乡', '中国,台湾,彰化县,线西乡', 3, 'xianxi', '04', '507', 'X', '120.465921', '24.128653'),
+(3556, 3551, '伸港', '伸港乡', '中国,台湾,彰化县,伸港乡', 3, 'shengang', '04', '509', 'S', '120.484224', '24.146081'),
+(3557, 3551, '福兴', '福兴乡', '中国,台湾,彰化县,福兴乡', 3, 'fuxing', '04', '506', 'F', '120.443682', '24.047883'),
+(3558, 3551, '秀水', '秀水乡', '中国,台湾,彰化县,秀水乡', 3, 'xiushui', '04', '504', 'X', '120.502658', '24.035267'),
+(3559, 3551, '花坛', '花坛乡', '中国,台湾,彰化县,花坛乡', 3, 'huatan', '04', '503', 'H', '120.538403', '24.029399'),
+(3560, 3551, '芬园', '芬园乡', '中国,台湾,彰化县,芬园乡', 3, 'fenyuan', '04', '502', 'F', '120.629024', '24.013658'),
+(3561, 3551, '员林', '员林镇', '中国,台湾,彰化县,员林镇', 3, 'yuanlin', '04', '510', 'Y', '120.574625', '23.958999'),
+(3562, 3551, '溪湖', '溪湖镇', '中国,台湾,彰化县,溪湖镇', 3, 'xihu', '04', '514', 'X', '120.479144', '23.962315'),
+(3563, 3551, '田中', '田中镇', '中国,台湾,彰化县,田中镇', 3, 'tianzhong', '04', '520', 'T', '120.580629', '23.861718'),
+(3564, 3551, '大村', '大村乡', '中国,台湾,彰化县,大村乡', 3, 'dacun', '04', '515', 'D', '120.540713', '23.993726'),
+(3565, 3551, '埔盐', '埔盐乡', '中国,台湾,彰化县,埔盐乡', 3, 'puyan', '04', '516', 'P', '120.464044', '24.000346'),
+(3566, 3551, '埔心', '埔心乡', '中国,台湾,彰化县,埔心乡', 3, 'puxin', '04', '513', 'P', '120.543568', '23.953019'),
+(3567, 3551, '永靖', '永靖乡', '中国,台湾,彰化县,永靖乡', 3, 'yongjing', '04', '512', 'Y', '120.547775', '23.924703'),
+(3568, 3551, '社头', '社头乡', '中国,台湾,彰化县,社头乡', 3, 'shetou', '04', '511', 'S', '120.582681', '23.896686'),
+(3569, 3551, '二水', '二水乡', '中国,台湾,彰化县,二水乡', 3, 'ershui', '04', '530', 'E', '120.618788', '23.806995'),
+(3570, 3551, '北斗', '北斗镇', '中国,台湾,彰化县,北斗镇', 3, 'beidou', '04', '521', 'B', '120.520449', '23.870911'),
+(3571, 3551, '二林', '二林镇', '中国,台湾,彰化县,二林镇', 3, 'erlin', '04', '526', 'E', '120.374468', '23.899751'),
+(3572, 3551, '田尾', '田尾乡', '中国,台湾,彰化县,田尾乡', 3, 'tianwei', '04', '522', 'T', '120.524717', '23.890735'),
+(3573, 3551, '埤头', '埤头乡', '中国,台湾,彰化县,埤头乡', 3, 'pitou', '04', '523', NULL, '120.462599', '23.891324'),
+(3574, 3551, '芳苑', '芳苑乡', '中国,台湾,彰化县,芳苑乡', 3, 'fangyuan', '04', '528', 'F', '120.320329', '23.924222'),
+(3575, 3551, '大城', '大城乡', '中国,台湾,彰化县,大城乡', 3, 'dacheng', '04', '527', 'D', '120.320934', '23.852382'),
+(3576, 3551, '竹塘', '竹塘乡', '中国,台湾,彰化县,竹塘乡', 3, 'zhutang', '04', '525', 'Z', '120.427499', '23.860112'),
+(3577, 3551, '溪州', '溪州乡', '中国,台湾,彰化县,溪州乡', 3, 'xizhou', '04', '524', 'X', '120.498706', '23.851229'),
+(3578, 3325, '南投', '南投县', '中国,台湾,南投县', 2, 'nantou', '049', '5', 'N', '120.830000', '23.830000'),
+(3579, 3578, '南投市', '南投市', '中国,台湾,南投县,南投市', 3, 'nantoushi', '049', '540', 'N', '120.683706', '23.909956'),
+(3580, 3578, '埔里', '埔里镇', '中国,台湾,南投县,埔里镇', 3, 'puli', '049', '545', 'P', '120.964648', '23.964789'),
+(3581, 3578, '草屯', '草屯镇', '中国,台湾,南投县,草屯镇', 3, 'caotun', '049', '542', 'C', '120.680343', '23.973947'),
+(3582, 3578, '竹山', '竹山镇', '中国,台湾,南投县,竹山镇', 3, 'zhushan', '049', '557', 'Z', '120.672007', '23.757655'),
+(3583, 3578, '集集', '集集镇', '中国,台湾,南投县,集集镇', 3, 'jiji', '049', '552', 'J', '120.783673', '23.829013'),
+(3584, 3578, '名间', '名间乡', '中国,台湾,南投县,名间乡', 3, 'mingjian', '049', '551', 'M', '120.702797', '23.838427'),
+(3585, 3578, '鹿谷', '鹿谷乡', '中国,台湾,南投县,鹿谷乡', 3, 'lugu', '049', '558', 'L', '120.752796', '23.744471'),
+(3586, 3578, '中寮', '中寮乡', '中国,台湾,南投县,中寮乡', 3, 'zhongliao', '049', '541', 'Z', '120.766654', '23.878935'),
+(3587, 3578, '鱼池', '鱼池乡', '中国,台湾,南投县,鱼池乡', 3, 'yuchi', '049', '555', 'Y', '120.936060', '23.896356'),
+(3588, 3578, '国姓', '国姓乡', '中国,台湾,南投县,国姓乡', 3, 'guoxing', '049', '544', 'G', '120.858541', '24.042298'),
+(3589, 3578, '水里', '水里乡', '中国,台湾,南投县,水里乡', 3, 'shuili', '049', '553', 'S', '120.855912', '23.812086'),
+(3590, 3578, '信义', '信义乡', '中国,台湾,南投县,信义乡', 3, 'xinyi', '049', '556', 'X', '120.855257', '23.699922'),
+(3591, 3578, '仁爱', '仁爱乡', '中国,台湾,南投县,仁爱乡', 3, 'renai', '049', '546', 'R', '121.133543', '24.024429'),
+(3592, 3325, '云林', '云林县', '中国,台湾,云林县', 2, 'yunlin', '05', '6', 'Y', '120.250000', '23.750000'),
+(3593, 3592, '斗六', '斗六市', '中国,台湾,云林县,斗六市', 3, 'douliu', '05', '640', 'D', '120.527360', '23.697651'),
+(3594, 3592, '斗南', '斗南镇', '中国,台湾,云林县,斗南镇', 3, 'dounan', '05', '630', 'D', '120.479075', '23.679731'),
+(3595, 3592, '虎尾', '虎尾镇', '中国,台湾,云林县,虎尾镇', 3, 'huwei', '05', '632', 'H', '120.445339', '23.708182'),
+(3596, 3592, '西螺', '西螺镇', '中国,台湾,云林县,西螺镇', 3, 'xiluo', '05', '648', 'X', '120.466010', '23.797984'),
+(3597, 3592, '土库', '土库镇', '中国,台湾,云林县,土库镇', 3, 'tuku', '05', '633', 'T', '120.392572', '23.677822'),
+(3598, 3592, '北港', '北港镇', '中国,台湾,云林县,北港镇', 3, 'beigang', '05', '651', 'B', '120.302393', '23.575525'),
+(3599, 3592, '古坑', '古坑乡', '中国,台湾,云林县,古坑乡', 3, 'gukeng', '05', '646', 'G', '120.562043', '23.642568'),
+(3600, 3592, '大埤', '大埤乡', '中国,台湾,云林县,大埤乡', 3, 'dapi', '05', '631', 'D', '120.430516', '23.645908'),
+(3601, 3592, '莿桐', '莿桐乡', '中国,台湾,云林县,莿桐乡', 3, 'citong', '05', '647', NULL, '120.502374', '23.760784'),
+(3602, 3592, '林内', '林内乡', '中国,台湾,云林县,林内乡', 3, 'linna', '05', '643', 'L', '120.611365', '23.758712'),
+(3603, 3592, '二仑', '二仑乡', '中国,台湾,云林县,二仑乡', 3, 'erlun', '05', '649', 'E', '120.415077', '23.771273'),
+(3604, 3592, '仑背', '仑背乡', '中国,台湾,云林县,仑背乡', 3, 'lunbei', '05', '637', 'L', '120.353895', '23.758840'),
+(3605, 3592, '麦寮', '麦寮乡', '中国,台湾,云林县,麦寮乡', 3, 'mailiao', '05', '638', 'M', '120.252043', '23.753841'),
+(3606, 3592, '东势', '东势乡', '中国,台湾,云林县,东势乡', 3, 'dongshi', '05', '635', 'D', '120.252672', '23.674679'),
+(3607, 3592, '褒忠', '褒忠乡', '中国,台湾,云林县,褒忠乡', 3, 'baozhong', '05', '634', 'B', '120.310488', '23.694245'),
+(3608, 3592, '台西', '台西乡', '中国,台湾,云林县,台西乡', 3, 'taixi', '05', '636', 'T', '120.196141', '23.702819'),
+(3609, 3592, '元长', '元长乡', '中国,台湾,云林县,元长乡', 3, 'yuanchang', '05', '655', 'Y', '120.315124', '23.649458'),
+(3610, 3592, '四湖', '四湖乡', '中国,台湾,云林县,四湖乡', 3, 'sihu', '05', '654', 'S', '120.225741', '23.637740'),
+(3611, 3592, '口湖', '口湖乡', '中国,台湾,云林县,口湖乡', 3, 'kouhu', '05', '653', 'K', '120.185370', '23.582406'),
+(3612, 3592, '水林', '水林乡', '中国,台湾,云林县,水林乡', 3, 'shuilin', '05', '652', 'S', '120.245948', '23.572634'),
+(3613, 3325, '嘉义', '嘉义县', '中国,台湾,嘉义县', 2, 'chiayi', '05', '6', 'J', '120.300000', '23.500000'),
+(3614, 3613, '太保', '太保市', '中国,台湾,嘉义县,太保市', 3, 'taibao', '05', '612', 'T', '120.332876', '23.459647'),
+(3615, 3613, '朴子', '朴子市', '中国,台湾,嘉义县,朴子市', 3, 'puzi', '05', '613', 'P', '120.247014', '23.464961'),
+(3616, 3613, '布袋', '布袋镇', '中国,台湾,嘉义县,布袋镇', 3, 'budai', '05', '625', 'B', '120.166936', '23.377979'),
+(3617, 3613, '大林', '大林镇', '中国,台湾,嘉义县,大林镇', 3, 'dalin', '05', '622', 'D', '120.471336', '23.603815'),
+(3618, 3613, '民雄', '民雄乡', '中国,台湾,嘉义县,民雄乡', 3, 'minxiong', '05', '621', 'M', '120.428577', '23.551456'),
+(3619, 3613, '溪口', '溪口乡', '中国,台湾,嘉义县,溪口乡', 3, 'xikou', '05', '623', 'X', '120.393822', '23.602223'),
+(3620, 3613, '新港', '新港乡', '中国,台湾,嘉义县,新港乡', 3, 'xingang', '05', '616', 'X', '120.347647', '23.551806'),
+(3621, 3613, '六脚', '六脚乡', '中国,台湾,嘉义县,六脚乡', 3, 'liujiao', '05', '615', 'L', '120.291083', '23.493942'),
+(3622, 3613, '东石', '东石乡', '中国,台湾,嘉义县,东石乡', 3, 'dongshi', '05', '614', 'D', '120.153822', '23.459235'),
+(3623, 3613, '义竹', '义竹乡', '中国,台湾,嘉义县,义竹乡', 3, 'yizhu', '05', '624', 'Y', '120.243423', '23.336277'),
+(3624, 3613, '鹿草', '鹿草乡', '中国,台湾,嘉义县,鹿草乡', 3, 'lucao', '05', '611', 'L', '120.308370', '23.410784'),
+(3625, 3613, '水上', '水上乡', '中国,台湾,嘉义县,水上乡', 3, 'shuishang', '05', '608', 'S', '120.397936', '23.428104'),
+(3626, 3613, '中埔', '中埔乡', '中国,台湾,嘉义县,中埔乡', 3, 'zhongpu', '05', '606', 'Z', '120.522948', '23.425148'),
+(3627, 3613, '竹崎', '竹崎乡', '中国,台湾,嘉义县,竹崎乡', 3, 'zhuqi', '05', '604', 'Z', '120.551466', '23.523184'),
+(3628, 3613, '梅山', '梅山乡', '中国,台湾,嘉义县,梅山乡', 3, 'meishan', '05', '603', 'M', '120.557192', '23.584915'),
+(3629, 3613, '番路', '番路乡', '中国,台湾,嘉义县,番路乡', 3, 'fanlu', '05', '602', 'F', '120.555043', '23.465222'),
+(3630, 3613, '大埔', '大埔乡', '中国,台湾,嘉义县,大埔乡', 3, 'dapu', '05', '607', 'D', '120.593795', '23.296715'),
+(3631, 3613, '阿里山', '阿里山乡', '中国,台湾,嘉义县,阿里山乡', 3, 'alishan', '05', '605', 'A', '120.732520', '23.467950'),
+(3632, 3325, '屏东', '屏东县', '中国,台湾,屏东县', 2, 'pingtung', '08', '9', 'P', '120.487928', '22.682802'),
+(3633, 3632, '屏东', '屏东市', '中国,台湾,屏东县,屏东市', 3, 'pingdong', '08', '900', 'P', '120.488465', '22.669723'),
+(3634, 3632, '潮州', '潮州镇', '中国,台湾,屏东县,潮州镇', 3, 'chaozhou', '08', '920', 'C', '120.542854', '22.550536'),
+(3635, 3632, '东港', '东港镇', '中国,台湾,屏东县,东港镇', 3, 'donggang', '08', '928', 'D', '120.454489', '22.466626'),
+(3636, 3632, '恒春', '恒春镇', '中国,台湾,屏东县,恒春镇', 3, 'hengchun', '08', '946', 'H', '120.745451', '22.002373'),
+(3637, 3632, '万丹', '万丹乡', '中国,台湾,屏东县,万丹乡', 3, 'wandan', '08', '913', 'W', '120.484533', '22.589839'),
+(3638, 3632, '长治', '长治乡', '中国,台湾,屏东县,长治乡', 3, 'changzhi', '08', '908', 'C', '120.527614', '22.677062'),
+(3639, 3632, '麟洛', '麟洛乡', '中国,台湾,屏东县,麟洛乡', 3, 'linluo', '08', '909', NULL, '120.527283', '22.650604'),
+(3640, 3632, '九如', '九如乡', '中国,台湾,屏东县,九如乡', 3, 'jiuru', '08', '904', 'J', '120.490142', '22.739778'),
+(3641, 3632, '里港', '里港乡', '中国,台湾,屏东县,里港乡', 3, 'ligang', '08', '905', 'L', '120.494490', '22.779220'),
+(3642, 3632, '盐埔', '盐埔乡', '中国,台湾,屏东县,盐埔乡', 3, 'yanpu', '08', '907', 'Y', '120.572849', '22.754783'),
+(3643, 3632, '高树', '高树乡', '中国,台湾,屏东县,高树乡', 3, 'gaoshu', '08', '906', 'G', '120.600214', '22.826789'),
+(3644, 3632, '万峦', '万峦乡', '中国,台湾,屏东县,万峦乡', 3, 'wanluan', '08', '923', 'W', '120.566477', '22.571965'),
+(3645, 3632, '内埔', '内埔乡', '中国,台湾,屏东县,内埔乡', 3, 'napu', '08', '912', 'N', '120.566865', '22.611967'),
+(3646, 3632, '竹田', '竹田乡', '中国,台湾,屏东县,竹田乡', 3, 'zhutian', '08', '911', 'Z', '120.544038', '22.584678'),
+(3647, 3632, '新埤', '新埤乡', '中国,台湾,屏东县,新埤乡', 3, 'xinpi', '08', '925', 'X', '120.549546', '22.469976'),
+(3648, 3632, '枋寮', '枋寮乡', '中国,台湾,屏东县,枋寮乡', 3, 'fangliao', '08', '940', NULL, '120.593438', '22.365560'),
+(3649, 3632, '新园', '新园乡', '中国,台湾,屏东县,新园乡', 3, 'xinyuan', '08', '932', 'X', '120.461739', '22.543952'),
+(3650, 3632, '崁顶', '崁顶乡', '中国,台湾,屏东县,崁顶乡', 3, 'kanding', '08', '924', NULL, '120.514571', '22.514795'),
+(3651, 3632, '林边', '林边乡', '中国,台湾,屏东县,林边乡', 3, 'linbian', '08', '927', 'L', '120.515091', '22.434015'),
+(3652, 3632, '南州', '南州乡', '中国,台湾,屏东县,南州乡', 3, 'nanzhou', '08', '926', 'N', '120.509808', '22.490192'),
+(3653, 3632, '佳冬', '佳冬乡', '中国,台湾,屏东县,佳冬乡', 3, 'jiadong', '08', '931', 'J', '120.551544', '22.417653'),
+(3654, 3632, '琉球', '琉球乡', '中国,台湾,屏东县,琉球乡', 3, 'liuqiu', '08', '929', 'L', '120.369020', '22.342366'),
+(3655, 3632, '车城', '车城乡', '中国,台湾,屏东县,车城乡', 3, 'checheng', '08', '944', 'C', '120.710979', '22.072077'),
+(3656, 3632, '满州', '满州乡', '中国,台湾,屏东县,满州乡', 3, 'manzhou', '08', '947', 'M', '120.838843', '22.020853'),
+(3657, 3632, '枋山', '枋山乡', '中国,台湾,屏东县,枋山乡', 3, 'fangshan', '08', '941', NULL, '120.656356', '22.260338'),
+(3658, 3632, '三地门', '三地门乡', '中国,台湾,屏东县,三地门乡', 3, 'sandimen', '08', '901', 'S', '120.654486', '22.713877'),
+(3659, 3632, '雾台', '雾台乡', '中国,台湾,屏东县,雾台乡', 3, 'wutai', '08', '902', 'W', '120.732318', '22.744877'),
+(3660, 3632, '玛家', '玛家乡', '中国,台湾,屏东县,玛家乡', 3, 'majia', '08', '903', 'M', '120.644130', '22.706718'),
+(3661, 3632, '泰武', '泰武乡', '中国,台湾,屏东县,泰武乡', 3, 'taiwu', '08', '921', 'T', '120.632856', '22.591819'),
+(3662, 3632, '来义', '来义乡', '中国,台湾,屏东县,来义乡', 3, 'laiyi', '08', '922', 'L', '120.633601', '22.525866'),
+(3663, 3632, '春日', '春日乡', '中国,台湾,屏东县,春日乡', 3, 'chunri', '08', '942', 'C', '120.628793', '22.370672'),
+(3664, 3632, '狮子', '狮子乡', '中国,台湾,屏东县,狮子乡', 3, 'shizi', '08', '943', 'S', '120.704617', '22.201917'),
+(3665, 3632, '牡丹', '牡丹乡', '中国,台湾,屏东县,牡丹乡', 3, 'mudan', '08', '945', 'M', '120.770108', '22.125687'),
+(3666, 3325, '台东', '台东县', '中国,台湾,台东县', 2, 'taitung', '089', '9', 'T', '120.916000', '23.000000'),
+(3667, 3666, '台东', '台东市', '中国,台湾,台东县,台东市', 3, 'taidong', '089', '950', 'T', '121.145654', '22.756045'),
+(3668, 3666, '成功', '成功镇', '中国,台湾,台东县,成功镇', 3, 'chenggong', '089', '961', 'C', '121.379571', '23.100223'),
+(3669, 3666, '关山', '关山镇', '中国,台湾,台东县,关山镇', 3, 'guanshan', '089', '956', 'G', '121.163134', '23.047450'),
+(3670, 3666, '卑南', '卑南乡', '中国,台湾,台东县,卑南乡', 3, 'beinan', '089', '954', 'B', '121.083503', '22.786039'),
+(3671, 3666, '鹿野', '鹿野乡', '中国,台湾,台东县,鹿野乡', 3, 'luye', '089', '955', 'L', '121.135982', '22.913951'),
+(3672, 3666, '池上', '池上乡', '中国,台湾,台东县,池上乡', 3, 'chishang', '089', '958', 'C', '121.215139', '23.122393'),
+(3673, 3666, '东河', '东河乡', '中国,台湾,台东县,东河乡', 3, 'donghe', '089', '959', 'D', '121.300334', '22.969934'),
+(3674, 3666, '长滨', '长滨乡', '中国,台湾,台东县,长滨乡', 3, 'changbin', '089', '962', 'C', '121.451522', '23.315041'),
+(3675, 3666, '太麻里', '太麻里乡', '中国,台湾,台东县,太麻里乡', 3, 'taimali', '089', '963', 'T', '121.007394', '22.615383'),
+(3676, 3666, '大武', '大武乡', '中国,台湾,台东县,大武乡', 3, 'dawu', '089', '965', 'D', '120.889938', '22.339919'),
+(3677, 3666, '绿岛', '绿岛乡', '中国,台湾,台东县,绿岛乡', 3, 'lvdao', '089', '951', 'L', '121.492596', '22.661676'),
+(3678, 3666, '海端', '海端乡', '中国,台湾,台东县,海端乡', 3, 'haiduan', '089', '957', 'H', '121.172008', '23.101074'),
+(3679, 3666, '延平', '延平乡', '中国,台湾,台东县,延平乡', 3, 'yanping', '089', '953', 'Y', '121.084499', '22.902358'),
+(3680, 3666, '金峰', '金峰乡', '中国,台湾,台东县,金峰乡', 3, 'jinfeng', '089', '964', 'J', '120.971292', '22.595511'),
+(3681, 3666, '达仁', '达仁乡', '中国,台湾,台东县,达仁乡', 3, 'daren', '089', '966', 'D', '120.884131', '22.294869'),
+(3682, 3666, '兰屿', '兰屿乡', '中国,台湾,台东县,兰屿乡', 3, 'lanyu', '089', '952', 'L', '121.532473', '22.056736'),
+(3683, 3325, '花莲', '花莲县', '中国,台湾,花莲县', 2, 'hualien', '03', '9', 'H', '121.300000', '23.830000'),
+(3684, 3683, '花莲', '花莲市', '中国,台湾,花莲县,花莲市', 3, 'hualian', '03', '970', 'H', '121.606810', '23.982074'),
+(3685, 3683, '凤林', '凤林镇', '中国,台湾,花莲县,凤林镇', 3, 'fenglin', '03', '975', 'F', '121.451687', '23.744648'),
+(3686, 3683, '玉里', '玉里镇', '中国,台湾,花莲县,玉里镇', 3, 'yuli', '03', '981', 'Y', '121.316445', '23.336509'),
+(3687, 3683, '新城', '新城乡', '中国,台湾,花莲县,新城乡', 3, 'xincheng', '03', '971', 'X', '121.640512', '24.128133'),
+(3688, 3683, '吉安', '吉安乡', '中国,台湾,花莲县,吉安乡', 3, 'ji''an', '03', '973', 'J', '121.568005', '23.961635'),
+(3689, 3683, '寿丰', '寿丰乡', '中国,台湾,花莲县,寿丰乡', 3, 'shoufeng', '03', '974', 'S', '121.508955', '23.870680'),
+(3690, 3683, '光复', '光复乡', '中国,台湾,花莲县,光复乡', 3, 'guangfu', '03', '976', 'G', '121.423496', '23.669084'),
+(3691, 3683, '丰滨', '丰滨乡', '中国,台湾,花莲县,丰滨乡', 3, 'fengbin', '03', '977', 'F', '121.518639', '23.597080'),
+(3692, 3683, '瑞穗', '瑞穗乡', '中国,台湾,花莲县,瑞穗乡', 3, 'ruisui', '03', '978', 'R', '121.375992', '23.496817'),
+(3693, 3683, '富里', '富里乡', '中国,台湾,花莲县,富里乡', 3, 'fuli', '03', '983', 'F', '121.250124', '23.179984'),
+(3694, 3683, '秀林', '秀林乡', '中国,台湾,花莲县,秀林乡', 3, 'xiulin', '03', '972', 'X', '121.620381', '24.116642'),
+(3695, 3683, '万荣', '万荣乡', '中国,台湾,花莲县,万荣乡', 3, 'wanrong', '03', '979', 'W', '121.407493', '23.715346'),
+(3696, 3683, '卓溪', '卓溪乡', '中国,台湾,花莲县,卓溪乡', 3, 'zhuoxi', '03', '982', 'Z', '121.303422', '23.346369'),
+(3697, 3325, '澎湖', '澎湖县', '中国,台湾,澎湖县', 2, 'penghu', '06', '8', 'P', '119.566417', '23.569733'),
+(3698, 3697, '马公', '马公市', '中国,台湾,澎湖县,马公市', 3, 'magong', '06', '880', 'M', '119.566499', '23.565845'),
+(3699, 3697, '湖西', '湖西乡', '中国,台湾,澎湖县,湖西乡', 3, 'huxi', '06', '885', 'H', '119.659666', '23.583358'),
+(3700, 3697, '白沙', '白沙乡', '中国,台湾,澎湖县,白沙乡', 3, 'baisha', '06', '884', 'B', '119.597919', '23.666060'),
+(3701, 3697, '西屿', '西屿乡', '中国,台湾,澎湖县,西屿乡', 3, 'xiyu', '06', '881', 'X', '119.506974', '23.600836'),
+(3702, 3697, '望安', '望安乡', '中国,台湾,澎湖县,望安乡', 3, 'wang''an', '06', '882', 'W', '119.500538', '23.357531'),
+(3703, 3697, '七美', '七美乡', '中国,台湾,澎湖县,七美乡', 3, 'qimei', '06', '883', 'Q', '119.423929', '23.206018'),
+(3704, 3325, '金门', '金门县', '中国,台湾,金门县', 2, 'jinmen', '082', '8', 'J', '118.317089', '24.432706'),
+(3705, 3704, '金城', '金城镇', '中国,台湾,金门县,金城镇', 3, 'jincheng', '082', '893', 'J', '118.316667', '24.416667'),
+(3706, 3704, '金湖', '金湖镇', '中国,台湾,金门县,金湖镇', 3, 'jinhu', '082', '891', 'J', '118.419743', '24.438633'),
+(3707, 3704, '金沙', '金沙镇', '中国,台湾,金门县,金沙镇', 3, 'jinsha', '082', '890', 'J', '118.427993', '24.481109'),
+(3708, 3704, '金宁', '金宁乡', '中国,台湾,金门县,金宁乡', 3, 'jinning', '082', '892', 'J', '118.334506', '24.45672'),
+(3709, 3704, '烈屿', '烈屿乡', '中国,台湾,金门县,烈屿乡', 3, 'lieyu', '082', '894', 'L', '118.247255', '24.433102'),
+(3710, 3704, '乌丘', '乌丘乡', '中国,台湾,金门县,乌丘乡', 3, 'wuqiu', '082', '896', 'W', '118.319578', '24.435038'),
+(3711, 3325, '连江', '连江县', '中国,台湾,连江县', 2, 'lienchiang', '0836', '2', 'L', '119.539704', '26.197364'),
+(3712, 3711, '南竿', '南竿乡', '中国,台湾,连江县,南竿乡', 3, 'nangan', '0836', '209', 'N', '119.944267', '26.144035'),
+(3713, 3711, '北竿', '北竿乡', '中国,台湾,连江县,北竿乡', 3, 'beigan', '0836', '210', 'B', '120.000572', '26.221983'),
+(3714, 3711, '莒光', '莒光乡', '中国,台湾,连江县,莒光乡', 3, 'juguang', '0836', '211', NULL, '119.940405', '25.976256'),
+(3715, 3711, '东引', '东引乡', '中国,台湾,连江县,东引乡', 3, 'dongyin', '0836', '212', 'D', '120.493955', '26.366164'),
+(3716, 0, '香港', '香港特别行政区', '中国,香港特别行政区', 1, 'hongkong', '', '', 'X', '114.173355', '22.320048'),
+(3717, 3716, '香港岛', '香港岛', '中国,香港特别行政区,香港岛', 2, 'hongkongisland', '00852', '999077', 'X', '114.177314', '22.266416'),
+(3718, 3717, '中西区', '中西区', '中国,香港特别行政区,香港岛,中西区', 3, 'centralandwesterndistrict', '00852', '999077', 'Z', '114.154374', '22.281981'),
+(3719, 3717, '湾仔区', '湾仔区', '中国,香港特别行政区,香港岛,湾仔区', 3, 'wanchaidistrict', '00852', '999077', 'W', '114.182915', '22.276389'),
+(3720, 3717, '东区', '东区', '中国,香港特别行政区,香港岛,东区', 3, 'easterndistrict', '00852', '999077', 'D', '114.255993', '22.262755'),
+(3721, 3717, '南区', '南区', '中国,香港特别行政区,香港岛,南区', 3, 'southerndistrict', '00852', '999077', 'N', '114.174134', '22.24676'),
+(3722, 3716, '九龙', '九龙', '中国,香港特别行政区,九龙', 2, 'kowloon', '00852', '999077', 'J', '114.17495', '22.327115'),
+(3723, 3722, '油尖旺', '油尖旺区', '中国,香港特别行政区,九龙,油尖旺区', 3, 'yautsimmong', '00852', '999077', 'Y', '114.173332', '22.311704'),
+(3724, 3722, '深水埗', '深水埗区', '中国,香港特别行政区,九龙,深水埗区', 3, 'shamshuipo', '00852', '999077', NULL, '114.16721', '22.328171'),
+(3725, 3722, '九龙城', '九龙城区', '中国,香港特别行政区,九龙,九龙城区', 3, 'jiulongcheng', '00852', '999077', 'J', '114.195053', '22.32673'),
+(3726, 3722, '黄大仙', '黄大仙区', '中国,香港特别行政区,九龙,黄大仙区', 3, 'wongtaisin', '00852', '999077', 'H', '114.19924', '22.336313'),
+(3727, 3722, '观塘', '观塘区', '中国,香港特别行政区,九龙,观塘区', 3, 'kwuntong', '00852', '999077', 'G', '114.231268', '22.30943'),
+(3728, 3716, '新界', '新界', '中国,香港特别行政区,新界', 2, 'newterritories', '00852', '999077', 'X', '114.202408', '22.341766'),
+(3729, 3728, '荃湾', '荃湾区', '中国,香港特别行政区,新界,荃湾区', 3, 'tsuenwan', '00852', '999077', NULL, '114.122952', '22.370973'),
+(3730, 3728, '屯门', '屯门区', '中国,香港特别行政区,新界,屯门区', 3, 'tuenmun', '00852', '999077', 'T', '113.977416', '22.391047'),
+(3731, 3728, '元朗', '元朗区', '中国,香港特别行政区,新界,元朗区', 3, 'yuenlong', '00852', '999077', 'Y', '114.039796', '22.443342'),
+(3732, 3728, '北区', '北区', '中国,香港特别行政区,新界,北区', 3, 'northdistrict', '00852', '999077', 'B', '114.148959', '22.494086'),
+(3733, 3728, '大埔', '大埔区', '中国,香港特别行政区,新界,大埔区', 3, 'taipo', '00852', '999077', 'D', '114.171743', '22.445653'),
+(3734, 3728, '西贡', '西贡区', '中国,香港特别行政区,新界,西贡区', 3, 'saikung', '00852', '999077', 'X', '114.27854', '22.37944'),
+(3735, 3728, '沙田', '沙田区', '中国,香港特别行政区,新界,沙田区', 3, 'shatin', '00852', '999077', 'S', '114.191941', '22.379294'),
+(3736, 3728, '葵青', '葵青区', '中国,香港特别行政区,新界,葵青区', 3, 'kwaitsing', '00852', '999077', 'K', '114.13932', '22.363877'),
+(3737, 3728, '离岛', '离岛区', '中国,香港特别行政区,新界,离岛区', 3, 'outlyingislands', '00852', '999077', 'L', '113.945842', '22.281508'),
+(3738, 0, '澳门', '澳门特别行政区', '中国,澳门特别行政区', 1, 'macau', '', '', 'A', '113.54909', '22.198951'),
+(3739, 3738, '澳门半岛', '澳门半岛', '中国,澳门特别行政区,澳门半岛', 2, 'macaupeninsula', '00853', '999078', 'A', '113.549134', '22.198751'),
+(3740, 3739, '花地玛堂区', '花地玛堂区', '中国,澳门特别行政区,澳门半岛,花地玛堂区', 3, 'nossasenhoradefatima', '00853', '999078', 'H', '113.552284', '22.208067'),
+(3741, 3739, '圣安多尼堂区', '圣安多尼堂区', '中国,澳门特别行政区,澳门半岛,圣安多尼堂区', 3, 'santoantonio', '00853', '999078', 'S', '113.564301', '22.12381'),
+(3742, 3739, '大堂', '大堂区', '中国,澳门特别行政区,澳门半岛,大堂区', 3, 'sé', '00853', '999078', 'D', '113.552971', '22.188359'),
+(3743, 3739, '望德堂区', '望德堂区', '中国,澳门特别行政区,澳门半岛,望德堂区', 3, 'saolazaro', '00853', '999078', 'W', '113.550568', '22.194081'),
+(3744, 3739, '风顺堂区', '风顺堂区', '中国,澳门特别行政区,澳门半岛,风顺堂区', 3, 'saolourenco', '00853', '999078', 'F', '113.541928', '22.187368'),
+(3745, 3738, '氹仔岛', '氹仔岛', '中国,澳门特别行政区,氹仔岛', 2, 'taipa', '00853', '999078', NULL, '113.577669', '22.156838'),
+(3746, 3745, '嘉模堂区', '嘉模堂区', '中国,澳门特别行政区,氹仔岛,嘉模堂区', 3, 'ourladyofcarmel''sparish', '00853', '999078', 'J', '113.565303', '22.149029'),
+(3747, 3738, '路环岛', '路环岛', '中国,澳门特别行政区,路环岛', 2, 'coloane', '00853', '999078', 'L', '113.564857', '22.116226'),
+(3748, 3747, '圣方济各堂区', '圣方济各堂区', '中国,澳门特别行政区,路环岛,圣方济各堂区', 3, 'stfrancisxavier''sparish', '00853', '999078', 'S', '113.559954', '22.123486');
+COMMIT;
+
+CREATE TABLE IF NOT EXISTS `__PREFIX__version`  (
+  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `oldversion` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '旧版本号',
+  `newversion` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '新版本号',
+  `packagesize` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '包大小',
+  `content` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '升级内容',
+  `downloadurl` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '下载地址',
+  `enforce` tinyint(1) UNSIGNED NOT NULL DEFAULT 0 COMMENT '强制更新',
+  `createtime` int(10) NOT NULL DEFAULT 0 COMMENT '创建时间',
+  `updatetime` int(10) UNSIGNED NOT NULL DEFAULT 0 COMMENT '更新时间',
+  `weigh` int(10) NOT NULL DEFAULT 0 COMMENT '权重',
+  `status` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '状态',
+  PRIMARY KEY (`id`) USING BTREE
+) ENGINE = InnoDB AUTO_INCREMENT = 1 DEFAULT CHARSET=utf8 COMMENT = '版本表';
+
+BEGIN;
+INSERT INTO `__PREFIX__version` (`id`, `oldversion`, `newversion`, `packagesize`, `content`, `downloadurl`, `enforce`, `createtime`, `updatetime`, `weigh`, `status`) VALUES
+(1, '1.1.1,2', '1.2.1', '20M', '更新内容', 'https://www.fastadmin.net/download.html', 1, 1520425318, 0, 0, 'normal');
+COMMIT;

+ 33 - 0
addons/example/view/demo/demo1.html

@@ -0,0 +1,33 @@
+<!-- Page Content -->
+    <div class="container">
+
+        <!-- Page Heading/Breadcrumbs -->
+        <div class="row">
+            <div class="col-lg-12">
+                <h1 class="page-header">无需登录页面
+                    <small>开发者示例</small>
+                </h1>
+                <ol class="breadcrumb">
+                    <li><a href="{:addon_url('example/index/index')}">插件首页</a>
+                    </li>
+                    <li class="active">无需登录页面</li>
+                </ol>
+            </div>
+        </div>
+        <!-- /.row -->
+
+        <!-- Content Row -->
+        <div class="row">
+            <div class="col-lg-12">
+                <p class="well">当前登录页面无需登录即可查看,当前请求的name值为:{$Request.param.name}</p>
+                {if $user}
+                <p class="well text-danger">但是如果你登录后可以浏览到这段隐藏的信息</p>
+                {/if}
+            </div>
+        </div>
+        <!-- /.row -->
+
+        <hr>
+
+    </div>
+    <!-- /.container -->

+ 31 - 0
addons/example/view/demo/demo2.html

@@ -0,0 +1,31 @@
+<!-- Page Content -->
+<div class="container">
+
+    <!-- Page Heading/Breadcrumbs -->
+    <div class="row">
+        <div class="col-lg-12">
+            <h1 class="page-header">需登录页面
+                <small>开发者示例</small>
+            </h1>
+            <ol class="breadcrumb">
+                <li><a href="{:addon_url('example/index/index')}">插件首页</a>
+                </li>
+                <li class="active">需登录页面</li>
+            </ol>
+        </div>
+    </div>
+    <!-- /.row -->
+
+    <!-- Content Row -->
+    <div class="row">
+        <div class="col-lg-12">
+            <p class="well">当前登录页面需要登录后才可以查看,你可以退出后再访问此页面,会提醒登录,当前请求的name值为:{$Request.param.name}</p>
+            <p class="well">你好!{$user.nickname},<a href="{:url('index/user/logout')}">注销登录</a></p>
+        </div>
+    </div>
+    <!-- /.row -->
+
+    <hr>
+
+</div>
+<!-- /.container -->

+ 67 - 0
addons/example/view/demo/index.html

@@ -0,0 +1,67 @@
+<!-- Page Content -->
+    <div class="container">
+
+        <!-- Page Heading/Breadcrumbs -->
+        <div class="row">
+            <div class="col-lg-12">
+                <h1 class="page-header">使用模板标签和变量
+                    <small>开发者示例</small>
+                </h1>
+                <ol class="breadcrumb">
+                    <li><a href="{:addon_url('example/index/index')}">插件首页</a>
+                    </li>
+                    <li class="active">使用模板标签和变量</li>
+                </ol>
+            </div>
+        </div>
+        <!-- /.row -->
+
+        <!-- Content Row -->
+        <div class="row">
+            <div class="col-lg-12">
+                <p class="well">当前请求的name值为:{$Request.param.name}</p>
+                {literal}
+                <pre>
+在插件视图中可以使用所有ThinkPHP5内支持的模板标签和变量,如
+
+{$Think.server.script_name} // 输出$_SERVER['SCRIPT_NAME']变量
+{$Think.session.user_id} // 输出$_SESSION['user_id']变量
+{$Think.get.pageNumber} // 输出$_GET['pageNumber']变量
+{$Think.cookie.name}  // 输出$_COOKIE['name']变量
+
+// 调用Request对象的get方法 传入参数为id
+{$Request.get.id}
+// 调用Request对象的param方法 传入参数为name
+{$Request.param.name}
+// 调用Request对象的param方法 传入参数为user.nickname
+{$Request.param.user.nickname}
+// 调用Request对象的root方法
+{$Request.root}
+// 调用Request对象的root方法,并且传入参数true
+{$Request.root.true}
+// 调用Request对象的path方法
+{$Request.path}
+// 调用Request对象的module方法
+{$Request.module}
+// 调用Request对象的controller方法
+{$Request.controller}
+// 调用Request对象的action方法
+{$Request.action}
+// 调用Request对象的ext方法
+{$Request.ext}
+// 调用Request对象的host方法
+{$Request.host}
+// 调用Request对象的ip方法
+{$Request.ip}
+// 调用Request对象的header方法
+{$Request.header.accept-encoding}
+                </pre>
+                {/literal}
+            </div>
+        </div>
+        <!-- /.row -->
+
+        <hr>
+
+    </div>
+    <!-- /.container -->

+ 236 - 0
addons/example/view/index/index.html

@@ -0,0 +1,236 @@
+<!-- Header Carousel -->
+<header id="myCarousel" class="carousel slide">
+    <!-- Indicators -->
+    <ol class="carousel-indicators">
+        <li data-target="#myCarousel" data-slide-to="0" class="active"></li>
+        <li data-target="#myCarousel" data-slide-to="1"></li>
+        <li data-target="#myCarousel" data-slide-to="2"></li>
+        <li data-target="#myCarousel" data-slide-to="3"></li>
+    </ol>
+
+    <!-- Wrapper for slides -->
+    <div class="carousel-inner">
+        <div class="item active">
+            <a href="https://www.fastadmin.net/store/cms.html" target="_blank">
+                <div class="fill" style="background-image:url('https://bg.fastadmin.net?text=random&color=3498db');"></div>
+                <div class="carousel-body">
+                    <div class="container">
+                        <h1 class="display-1 text-white">CMS内容管理模块</h1>
+                        <h2 class="display-4 text-white">简单强大的内容管理系统,可自定义内容模型、标签、伪静态、全文搜索、百度推送等功能<br>包含完整的小程序CMS客户端,拥有完善的资讯模块、产品模块、评论模块、会员模块</h2>
+                    </div>
+                </div>
+            </a>
+        </div>
+        <div class="item">
+            <a href="https://www.fastadmin.net/store/blog.html" target="_blank">
+                <div class="fill" style="background-image:url('https://bg.fastadmin.net?text=random&color=2ecc71');"></div>
+                <div class="carousel-body">
+                    <div class="container">
+                        <h1 class="display-1 text-white">简单博客模块</h1>
+                        <h2 class="display-4 text-white">响应式博客插件,包含日志、评论、分类、归档、全文搜索、百度推送等功能<br/>包含完整的小程序博客客户端,拥有博客日志列表、日志详情、评论等功能</h2>
+                    </div>
+                </div>
+            </a>
+        </div>
+        <div class="item">
+            <a href="https://www.fastadmin.net/store/vote.html" target="_blank">
+                <div class="fill" style="background-image:url('https://bg.fastadmin.net?text=random&color=0082ff');"></div>
+                <div class="carousel-body">
+                    <div class="container">
+                        <h1 class="display-1 text-white">在线投票系统</h1>
+                        <h2 class="display-4 text-white">基于FastAdmin+ThinkPHP开发的响应式在线投票系统,支持微信公众号投票和PC端投票<br/>具有高防刷票机制和实时排行榜等诸多特性,提供全部前后台无加密源代码</h2>
+                    </div>
+                </div>
+            </a>
+        </div>
+        <div class="item">
+            <a href="https://www.fastadmin.net/store/docs.html" target="_blank">
+                <div class="fill" style="background-image:url('https://bg.fastadmin.net?text=random&color=9c88ff');"></div>
+                <div class="carousel-body">
+                    <div class="container">
+                        <h1 class="display-1 text-white">Markdown文档生成</h1>
+                        <h2 class="display-4 text-white">将Github或本地Git环境中的Markdown文件解析并生成HTML,可在线浏览或导出为HTML离线浏览</h2>
+                    </div>
+                </div>
+            </a>
+        </div>
+    </div>
+</header>
+
+<!-- Page Content -->
+<div class="container">
+
+    <!-- Marketing Icons Section -->
+    <div class="row">
+        <div class="col-lg-12">
+            <h2 class="page-header">
+                基础模块
+            </h2>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-user"></i> 前台模块</h4>
+                </div>
+                <div class="panel-body">
+                    <p>FastAdmin有基础的前台模块,可快速的进行二次开发,前台模块中包含基础的会员模块,前台模块中的会员账号和API模块中的会员账号是同一账号体系</p>
+                    <a href="{:url('index/index/index')}" target="_blank" class="btn btn-primary">立即访问</a>
+                    <a href="{:url('index/user/index')}" target="_blank" class="btn btn-default">会员中心</a>
+                </div>
+            </div>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-gift"></i> API模块</h4>
+                </div>
+                <div class="panel-body">
+                    <p>FastAdmin有基础的API模块,可快速的进行二次开发,API模块中包含基础的会员模块,初始化模块、短信发送模块、验证模块</p>
+                    <a href="{:url('api/index/index')}" target="_blank" class="btn btn-primary">立即访问</a>
+                    <a href="{:url('api/common/init')}?version=1.0.0" target="_blank" class="btn btn-default">初始化接口</a>
+                </div>
+            </div>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-compass"></i> API文档</h4>
+                </div>
+                <div class="panel-body">
+                    <p>我们提供了一键生成API文档的功能,当写完API接口以后,可通过执行php think api一键生成我们所需要的API文档,并且可以直接在线测试</p>
+                    <a href="{:url('/')}api.html" target="_blank" class="btn btn-primary">立即访问</a>
+                    <a href="https://doc.fastadmin.net/docs/command.html#一键生成API文档" target="_blank" class="btn btn-default">一键生成文档</a>
+                </div>
+            </div>
+        </div>
+    </div>
+    <div class="row">
+        <div class="col-lg-12">
+            <h2 class="page-header">
+                功能示例
+            </h2>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-check"></i> 使用模板标签和变量</h4>
+                </div>
+                <div class="panel-body">
+                    <p>在FastAdmin插件的视图中我们可以像前后台开发一样,向视图中渲染我们的自定义变量,然后在视图中进行访问。同时FastAdmin的插件视图中支持所有ThinkPHP5官方的系统模板标签和变量。轻轻松松的开发我们的插件</p>
+                    <a href="{:addon_url('example/demo/index',[':name'=>'s1'])}" class="btn btn-success">查看示例</a>
+                </div>
+            </div>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-gift"></i> 访问不需要登录的页面</h4>
+                </div>
+                <div class="panel-body">
+                    <p>在开发的过程有许多页面是不需要会员登录就可以访问的页面,比如新闻列表、新闻详情、评论列表、产品列表、产品展示、关于我们等等页面。在FastAdmin中可以使用noNeedLogin很方便的控制我们请求方法的访问权限</p>
+                    <a href="{:addon_url('example/demo/demo1',[':name'=>'s2'])}" class="btn btn-success">立即访问</a>
+                </div>
+            </div>
+        </div>
+        <div class="col-md-4">
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <h4><i class="fa fa-fw fa-compass"></i> 访问需要登录的页面</h4>
+                </div>
+                <div class="panel-body">
+                    <p>通常我们在开发中,如果页面与会员信息相关联,则通常需要控制页面在会员登录后才可以访问,FastAdmin中前台的权限控制可以很快捷的在插件中使用。我们可以直接重新定义noNeedLogin排除我们不需要登录的方法即可。</p>
+                    <a href="{:addon_url('example/demo/demo2',[':name'=>'s3'])}" class="btn btn-success">立即访问</a>
+                </div>
+            </div>
+        </div>
+    </div>
+    <!-- /.row -->
+
+    <div class="row addonlist">
+        <div class="col-lg-12">
+            <h2 class="page-header">
+                模块&插件
+                <span class="pull-right small" style="margin-top:5px;">
+                <small>
+                    <a href="https://www.fastadmin.net/store.html" target="_blank">更多</a>
+                </small>
+                </span>
+            </h2>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/cms.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/cms.png" alt="">
+                <p>CMS内容管理模块</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/blog.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/blog.png" alt="">
+                <p>简洁博客模块</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/ask.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/ask.png" alt="">
+                <p>付费问答社区</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/docs.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/docs.png" alt="">
+                <p>文档生成模块</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/vote.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/vote.png" alt="">
+                <p>在线投票系统</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/qiniu.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/qiniu.png" alt="">
+                <p>七牛上传插件</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/alioss.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/alioss.png" alt="">
+                <p>阿里云储存</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/alisms.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/alisms.png" alt="">
+                <p>阿里云短信</p>
+            </a>
+        </div>
+        <div class="col-md-4 col-sm-6">
+            <a href="https://www.fastadmin.net/store/nkeditor.html" target="_blank">
+                <img class="img-responsive img-addon img-hover" src="https://cdn.fastadmin.net/uploads/addons/nkeditor.png" alt="">
+                <p>富文本编辑器</p>
+            </a>
+        </div>
+        <div class="col-xs-12 text-center">
+            <a href="https://www.fastadmin.net/store.html" class="btn btn-primary" target="_blank">前往插件市场</a>
+        </div>
+    </div>
+    <!-- /.row -->
+
+    <hr>
+
+    <!-- Call to Action Section -->
+    <div class="well">
+        <div class="row">
+            <div class="col-md-8">
+                <p>感谢你对FastAdmin的支持!如果你在使用FastAdmin开发插件的过程中有任何疑问或需要寻求帮助,请前往FastAdmin问答社区与小伙伴们一起交流。</p>
+            </div>
+            <div class="col-md-4">
+                <a class="btn btn-lg btn-default btn-block" href="https://ask.fastadmin.net" target="_blank">前往问答社区</a>
+            </div>
+        </div>
+    </div>
+
+    <hr>
+
+</div>

+ 124 - 0
addons/example/view/layout/default.html

@@ -0,0 +1,124 @@
+<!DOCTYPE html>
+<html lang="en">
+
+    <head>
+
+        <meta charset="utf-8">
+        <meta http-equiv="X-UA-Compatible" content="IE=edge">
+        <meta name="viewport" content="width=device-width, initial-scale=1">
+        <meta name="description" content="">
+        <meta name="author" content="">
+
+        <title>开发者示例 - {$site.name}</title>
+
+        <!-- Bootstrap Core CSS -->
+        <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
+
+        <!-- Custom CSS -->
+        <link href="__ADDON__/css/common.css" rel="stylesheet">
+
+        <!-- Custom Fonts -->
+        <link href="https://cdn.bootcss.com/font-awesome/4.6.3/css/font-awesome.min.css" rel="stylesheet">
+
+        <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
+        <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
+        <!--[if lt IE 9]>
+            <script src="https://cdn.bootcss.com/html5shiv/3.7.0/html5shiv.min.js"></script>
+            <script src="https://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
+        <![endif]-->
+
+    </head>
+
+    <body>
+
+        <!-- Navigation -->
+        <nav class="navbar navbar-inverse navbar-fixed-top" role="navigation">
+            <div class="container">
+                <!-- Brand and toggle get grouped for better mobile display -->
+                <div class="navbar-header">
+                    <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
+                        <span class="sr-only">Toggle navigation</span>
+                        <span class="icon-bar"></span>
+                        <span class="icon-bar"></span>
+                        <span class="icon-bar"></span>
+                    </button>
+                    <a class="navbar-brand" href="{:addon_url('example/index/index')}">{$site.name}</a>
+                </div>
+                <!-- Collect the nav links, forms, and other content for toggling -->
+                <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
+                    <ul class="nav navbar-nav navbar-right">
+                        <li>
+                            <a href="{:addon_url('example/index/index')}">插件首页</a>
+                        </li>
+                        <li>
+                            <a href="{:addon_url('example/demo/demo1', [':name'=>'s1'])}">无需登录页面</a>
+                        </li>
+                        <li>
+                            <a href="{:addon_url('example/demo/demo2', [':name'=>'s2'])}">需登录页面</a>
+                        </li>
+                        {if $user}
+                        <li class="dropdown">
+                            <a href="#" class="dropdown-toggle" data-toggle="dropdown">欢迎你! {$user.nickname}<b class="caret"></b></a>
+                            <ul class="dropdown-menu">
+                                <li>
+                                    <a href="{:url('index/user/index')}">会员中心</a>
+                                </li>
+                                <li>
+                                    <a href="{:url('index/user/profile')}">个人资料</a>
+                                </li>
+                                <li>
+                                    <a href="{:url('index/user/logout')}">退出登录</a>
+                                </li>
+                            </ul>
+                        </li>
+                        {else /}
+                        <li class="dropdown">
+                            <a href="#" class="dropdown-toggle" data-toggle="dropdown">会员中心 <b class="caret"></b></a>
+                            <ul class="dropdown-menu">
+                                <li>
+                                    <a href="{:url('index/user/login')}">登录</a>
+                                </li>
+                                <li>
+                                    <a href="{:url('index/user/register')}">注册</a>
+                                </li>
+                            </ul>
+                        </li>
+                        {/if}
+                    </ul>
+                </div>
+                <!-- /.navbar-collapse -->
+            </div>
+            <!-- /.container -->
+        </nav>
+
+        {__CONTENT__}
+
+        <div class="container">
+            <!-- Footer -->
+            <footer>
+                <div class="row">
+                    <div class="col-lg-12">
+                        <p>Copyright &copy; {$site.name} 2020</p>
+                    </div>
+                </div>
+            </footer>
+
+        </div>
+        <!-- /.container -->
+
+        <!-- jQuery -->
+        <script src="https://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script>
+
+        <!-- Bootstrap Core JavaScript -->
+        <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
+
+        <!-- Script to Activate the Carousel -->
+        <script>
+            $('.carousel').carousel({
+                interval: 5000 //changes the speed
+            })
+        </script>
+
+    </body>
+
+</html>

File diff suppressed because it is too large
+ 0 - 0
addons/umeditor/.addonrc


+ 40 - 0
addons/umeditor/Umeditor.php

@@ -0,0 +1,40 @@
+<?php
+
+namespace addons\umeditor;
+
+use think\Addons;
+
+/**
+ * 插件
+ */
+class Umeditor extends Addons
+{
+
+    /**
+     * 插件安装方法
+     * @return bool
+     */
+    public function install()
+    {
+        return true;
+    }
+
+    /**
+     * 插件卸载方法
+     * @return bool
+     */
+    public function uninstall()
+    {
+        return true;
+    }
+
+    /**
+     * @param $params
+     */
+    public function configInit(&$params)
+    {
+        $config = $this->getConfig();
+        $params['umeditor'] = ['classname' => $config['classname']??'.editor'];
+    }
+
+}

+ 131 - 0
addons/umeditor/bootstrap.js

@@ -0,0 +1,131 @@
+window.UMEDITOR_HOME_URL = Config.__CDN__ + "/assets/addons/umeditor/";
+require.config({
+    paths: {
+        'umeditor': '../addons/umeditor/umeditor.min',
+        'umeditor.config': '../addons/umeditor/umeditor.config',
+        'umeditor.lang': '../addons/umeditor/lang/zh-cn/zh-cn',
+    },
+    shim: {
+        'umeditor': {
+            deps: [
+                'umeditor.config',
+                'css!../addons/umeditor/themes/default/css/umeditor.min.css'
+            ],
+            exports: 'UM',
+        },
+        'umeditor.lang': ['umeditor']
+    }
+});
+
+require(['form', 'upload'], function (Form, Upload) {
+    //监听上传文本框的事件
+    $(document).on("edui.file.change", ".edui-image-file", function (e, up, me, input, callback) {
+        for (var i = 0; i < this.files.length; i++) {
+            Upload.api.send(this.files[i], function (data) {
+                var url = data.url;
+                me.uploadComplete(JSON.stringify({url: url, state: "SUCCESS"}));
+            });
+        }
+        up.updateInput(input);
+        me.toggleMask("Loading....");
+        callback && callback();
+    });
+    var _bindevent = Form.events.bindevent;
+    Form.events.bindevent = function (form) {
+        _bindevent.apply(this, [form]);
+        require(['umeditor', 'umeditor.lang'], function (UME, undefined) {
+
+            //重写编辑器加载
+            UME.plugins['autoupload'] = function () {
+                var me = this;
+                me.setOpt('pasteImageEnabled', true);
+                me.setOpt('dropFileEnabled', true);
+                var sendAndInsertImage = function (file, editor) {
+                    try {
+                        Upload.api.send(file, function (data) {
+                            var url = Fast.api.cdnurl(data.url, true);
+                            editor.execCommand('insertimage', {
+                                src: url,
+                                _src: url
+                            });
+                        });
+                    } catch (er) {
+                    }
+                };
+
+                function getPasteImage(e) {
+                    return e.clipboardData && e.clipboardData.items && e.clipboardData.items.length == 1 && /^image\//.test(e.clipboardData.items[0].type) ? e.clipboardData.items : null;
+                }
+
+                function getDropImage(e) {
+                    return e.dataTransfer && e.dataTransfer.files ? e.dataTransfer.files : null;
+                }
+
+                me.addListener('ready', function () {
+                    if (window.FormData && window.FileReader) {
+                        var autoUploadHandler = function (e) {
+                            var hasImg = false,
+                                items;
+                            //获取粘贴板文件列表或者拖放文件列表
+                            items = e.type == 'paste' ? getPasteImage(e.originalEvent) : getDropImage(e.originalEvent);
+                            if (items) {
+                                var len = items.length,
+                                    file;
+                                while (len--) {
+                                    file = items[len];
+                                    if (file.getAsFile)
+                                        file = file.getAsFile();
+                                    if (file && file.size > 0 && /image\/\w+/i.test(file.type)) {
+                                        sendAndInsertImage(file, me);
+                                        hasImg = true;
+                                    }
+                                }
+                                if (hasImg)
+                                    return false;
+                            }
+
+                        };
+                        me.getOpt('pasteImageEnabled') && me.$body.on('paste', autoUploadHandler);
+                        me.getOpt('dropFileEnabled') && me.$body.on('drop', autoUploadHandler);
+
+                        //取消拖放图片时出现的文字光标位置提示
+                        me.$body.on('dragover', function (e) {
+                            if (e.originalEvent.dataTransfer.types[0] == 'Files') {
+                                return false;
+                            }
+                        });
+                    }
+                });
+
+            };
+            $.extend(window.UMEDITOR_CONFIG.whiteList, {
+                div: ['style', 'class', 'id', 'data-tpl', 'data-source', 'data-id'],
+                span: ['style', 'class', 'id', 'data-id']
+            });
+            $(Config.umeditor.classname || '.editor', form).each(function () {
+                var id = $(this).attr("id");
+                $(this).removeClass('form-control');
+                var options = $(this).data("umeditor-options");
+                UME.list[id] = UME.getEditor(id, $.extend(true, {}, {
+                    initialFrameWidth: '100%',
+                    zIndex: 90,
+                    autoHeightEnabled: true,
+                    initialFrameHeight: 300,
+                    xssFilterRules: false,
+                    outputXssFilter: false,
+                    inputXssFilter: false,
+                    autoFloatEnabled: false,
+                    imageUrl: '',
+                    imagePath: Config.upload.cdnurl,
+                    imageUploadCallback: function (file, fn) {
+                        var me = this;
+                        Upload.api.send(file, function (data) {
+                            var url = data.url;
+                            fn && fn.call(me, url, data);
+                        });
+                    }
+                }, options || {}));
+            });
+        });
+    }
+});

+ 16 - 0
addons/umeditor/config.php

@@ -0,0 +1,16 @@
+<?php
+
+return [
+    [
+        'name'    => 'classname',
+        'title'   => '渲染文本框元素',
+        'type'    => 'string',
+        'content' => [],
+        'value'   => '.editor',
+        'rule'    => 'required',
+        'msg'     => '',
+        'tip'     => '用于对指定的元素渲染,一般情况下无需修改',
+        'ok'      => '',
+        'extend'  => '',
+    ],
+];

+ 10 - 0
addons/umeditor/info.ini

@@ -0,0 +1,10 @@
+name = umeditor
+title = 百度UMeditor编辑器
+intro = 百度出品的UMeditor编辑器
+author = FastAdmin
+website = https://www.fastadmin.net
+version = 1.0.16
+state = 1
+url = /addons/umeditor
+license = basic
+licenseto = 19079

+ 1 - 0
application/.htaccess

@@ -0,0 +1 @@
+deny from all

+ 14 - 0
application/admin/behavior/AdminLog.php

@@ -0,0 +1,14 @@
+<?php
+
+namespace app\admin\behavior;
+
+class AdminLog
+{
+    public function run(&$params)
+    {
+        //只记录POST请求的日志
+        if (request()->isPost() && config('fastadmin.auto_record_log')) {
+            \app\admin\model\AdminLog::record();
+        }
+    }
+}

+ 344 - 0
application/admin/command/Addon.php

@@ -0,0 +1,344 @@
+<?php
+
+namespace app\admin\command;
+
+use think\addons\AddonException;
+use think\addons\Service;
+use think\Config;
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Db;
+use think\Exception;
+use think\exception\PDOException;
+
+class Addon extends Command
+{
+
+    protected function configure()
+    {
+        $this
+            ->setName('addon')
+            ->addOption('name', 'a', Option::VALUE_REQUIRED, 'addon name', null)
+            ->addOption('action', 'c', Option::VALUE_REQUIRED, 'action(create/enable/disable/uninstall/refresh/package/move)', 'create')
+            ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force override', null)
+            ->addOption('release', 'r', Option::VALUE_OPTIONAL, 'addon release version', null)
+            ->addOption('uid', 'u', Option::VALUE_OPTIONAL, 'fastadmin uid', null)
+            ->addOption('token', 't', Option::VALUE_OPTIONAL, 'fastadmin token', null)
+            ->addOption('domain', 'd', Option::VALUE_OPTIONAL, 'domain', null)
+            ->addOption('local', 'l', Option::VALUE_OPTIONAL, 'local package', null)
+            ->setDescription('Addon manager');
+    }
+
+    protected function execute(Input $input, Output $output)
+    {
+        $name = $input->getOption('name') ?: '';
+        $action = $input->getOption('action') ?: '';
+        if (stripos($name, 'addons' . DS) !== false) {
+            $name = explode(DS, $name)[1];
+        }
+        //强制覆盖
+        $force = $input->getOption('force');
+        //版本
+        $release = $input->getOption('release') ?: '';
+        //uid
+        $uid = $input->getOption('uid') ?: '';
+        //token
+        $token = $input->getOption('token') ?: '';
+
+        include dirname(__DIR__) . DS . 'common.php';
+
+        if (!$name && !in_array($action, ['refresh'])) {
+            throw new Exception('Addon name could not be empty');
+        }
+        if (!$action || !in_array($action, ['create', 'disable', 'enable', 'install', 'uninstall', 'refresh', 'upgrade', 'package', 'move'])) {
+            throw new Exception('Please input correct action name');
+        }
+
+        // 查询一次SQL,判断连接是否正常
+        Db::execute("SELECT 1");
+
+        $addonDir = ADDON_PATH . $name . DS;
+        switch ($action) {
+            case 'create':
+                //非覆盖模式时如果存在则报错
+                if (is_dir($addonDir) && !$force) {
+                    throw new Exception("addon already exists!\nIf you need to create again, use the parameter --force=true ");
+                }
+                //如果存在先移除
+                if (is_dir($addonDir)) {
+                    rmdirs($addonDir);
+                }
+                mkdir($addonDir, 0755, true);
+                mkdir($addonDir . DS . 'controller', 0755, true);
+                $menuList = \app\common\library\Menu::export($name);
+                $createMenu = $this->getCreateMenu($menuList);
+                $prefix = Config::get('database.prefix');
+                $createTableSql = '';
+                try {
+                    $result = Db::query("SHOW CREATE TABLE `" . $prefix . $name . "`;");
+                    if (isset($result[0]) && isset($result[0]['Create Table'])) {
+                        $createTableSql = $result[0]['Create Table'];
+                    }
+                } catch (PDOException $e) {
+
+                }
+
+                $data = [
+                    'name'               => $name,
+                    'addon'              => $name,
+                    'addonClassName'     => ucfirst($name),
+                    'addonInstallMenu'   => $createMenu ? "\$menu = " . var_export_short($createMenu) . ";\n\tMenu::create(\$menu);" : '',
+                    'addonUninstallMenu' => $menuList ? 'Menu::delete("' . $name . '");' : '',
+                    'addonEnableMenu'    => $menuList ? 'Menu::enable("' . $name . '");' : '',
+                    'addonDisableMenu'   => $menuList ? 'Menu::disable("' . $name . '");' : '',
+                ];
+                $this->writeToFile("addon", $data, $addonDir . ucfirst($name) . '.php');
+                $this->writeToFile("config", $data, $addonDir . 'config.php');
+                $this->writeToFile("info", $data, $addonDir . 'info.ini');
+                $this->writeToFile("controller", $data, $addonDir . 'controller' . DS . 'Index.php');
+                if ($createTableSql) {
+                    $createTableSql = str_replace("`" . $prefix, '`__PREFIX__', $createTableSql);
+                    file_put_contents($addonDir . 'install.sql', $createTableSql);
+                }
+
+                $output->info("Create Successed!");
+                break;
+            case 'disable':
+            case 'enable':
+                try {
+                    //调用启用、禁用的方法
+                    Service::$action($name, 0);
+                } catch (AddonException $e) {
+                    if ($e->getCode() != -3) {
+                        throw new Exception($e->getMessage());
+                    }
+                    if (!$force) {
+                        //如果有冲突文件则提醒
+                        $data = $e->getData();
+                        foreach ($data['conflictlist'] as $k => $v) {
+                            $output->warning($v);
+                        }
+                        $output->info("Are you sure you want to " . ($action == 'enable' ? 'override' : 'delete') . " all those files?  Type 'yes' to continue: ");
+                        $line = fgets(defined('STDIN') ? STDIN : fopen('php://stdin', 'r'));
+                        if (trim($line) != 'yes') {
+                            throw new Exception("Operation is aborted!");
+                        }
+                    }
+                    //调用启用、禁用的方法
+                    Service::$action($name, 1);
+                } catch (Exception $e) {
+                    throw new Exception($e->getMessage());
+                }
+                $output->info(ucfirst($action) . " Successed!");
+                break;
+            case 'uninstall':
+                //非覆盖模式时如果存在则报错
+                if (!$force) {
+                    throw new Exception("If you need to uninstall addon, use the parameter --force=true ");
+                }
+                try {
+                    Service::uninstall($name, 0);
+                } catch (AddonException $e) {
+                    if ($e->getCode() != -3) {
+                        throw new Exception($e->getMessage());
+                    }
+                    if (!$force) {
+                        //如果有冲突文件则提醒
+                        $data = $e->getData();
+                        foreach ($data['conflictlist'] as $k => $v) {
+                            $output->warning($v);
+                        }
+                        $output->info("Are you sure you want to delete all those files?  Type 'yes' to continue: ");
+                        $line = fgets(defined('STDIN') ? STDIN : fopen('php://stdin', 'r'));
+                        if (trim($line) != 'yes') {
+                            throw new Exception("Operation is aborted!");
+                        }
+                    }
+                    Service::uninstall($name, 1);
+                } catch (Exception $e) {
+                    throw new Exception($e->getMessage());
+                }
+
+                $output->info("Uninstall Successed!");
+                break;
+            case 'refresh':
+                Service::refresh();
+                $output->info("Refresh Successed!");
+                break;
+            case 'package':
+                $infoFile = $addonDir . 'info.ini';
+                if (!is_file($infoFile)) {
+                    throw new Exception(__('Addon info file was not found'));
+                }
+
+                $info = get_addon_info($name);
+                if (!$info) {
+                    throw new Exception(__('Addon info file data incorrect'));
+                }
+                $infoname = isset($info['name']) ? $info['name'] : '';
+                if (!$infoname || !preg_match("/^[a-z]+$/i", $infoname) || $infoname != $name) {
+                    throw new Exception(__('Addon info name incorrect'));
+                }
+
+                $infoversion = isset($info['version']) ? $info['version'] : '';
+                if (!$infoversion || !preg_match("/^\d+\.\d+\.\d+$/i", $infoversion)) {
+                    throw new Exception(__('Addon info version incorrect'));
+                }
+
+                $addonTmpDir = RUNTIME_PATH . 'addons' . DS;
+                if (!is_dir($addonTmpDir)) {
+                    @mkdir($addonTmpDir, 0755, true);
+                }
+                $addonFile = $addonTmpDir . $infoname . '-' . $infoversion . '.zip';
+                if (!class_exists('ZipArchive')) {
+                    throw new Exception(__('ZinArchive not install'));
+                }
+                $zip = new \ZipArchive;
+                $zip->open($addonFile, \ZipArchive::CREATE | \ZipArchive::OVERWRITE);
+
+                $files = new \RecursiveIteratorIterator(
+                    new \RecursiveDirectoryIterator($addonDir), \RecursiveIteratorIterator::LEAVES_ONLY
+                );
+
+                foreach ($files as $name => $file) {
+                    if (!$file->isDir()) {
+                        $filePath = $file->getRealPath();
+                        $relativePath = str_replace(DS, '/', substr($filePath, strlen($addonDir)));
+                        if (!in_array($file->getFilename(), ['.git', '.DS_Store', 'Thumbs.db'])) {
+                            $zip->addFile($filePath, $relativePath);
+                        }
+                    }
+                }
+                $zip->close();
+                $output->info("Package Successed!");
+                break;
+            case 'move':
+                $movePath = [
+                    'adminOnlySelfDir' => ['admin/behavior', 'admin/controller', 'admin/library', 'admin/model', 'admin/validate', 'admin/view'],
+                    'adminAllSubDir'   => ['admin/lang'],
+                    'publicDir'        => ['public/assets/addons', 'public/assets/js/backend']
+                ];
+                $paths = [];
+                $appPath = str_replace('/', DS, APP_PATH);
+                $rootPath = str_replace('/', DS, ROOT_PATH);
+                foreach ($movePath as $k => $items) {
+                    switch ($k) {
+                        case 'adminOnlySelfDir':
+                            foreach ($items as $v) {
+                                $v = str_replace('/', DS, $v);
+                                $oldPath = $appPath . $v . DS . $name;
+                                $newPath = $rootPath . "addons" . DS . $name . DS . "application" . DS . $v . DS . $name;
+                                $paths[$oldPath] = $newPath;
+                            }
+                            break;
+                        case 'adminAllSubDir':
+                            foreach ($items as $v) {
+                                $v = str_replace('/', DS, $v);
+                                $vPath = $appPath . $v;
+                                $list = scandir($vPath);
+                                foreach ($list as $_v) {
+                                    if (!in_array($_v, ['.', '..']) && is_dir($vPath . DS . $_v)) {
+                                        $oldPath = $appPath . $v . DS . $_v . DS . $name;
+                                        $newPath = $rootPath . "addons" . DS . $name . DS . "application" . DS . $v . DS . $_v . DS . $name;
+                                        $paths[$oldPath] = $newPath;
+                                    }
+                                }
+                            }
+                            break;
+                        case 'publicDir':
+                            foreach ($items as $v) {
+                                $v = str_replace('/', DS, $v);
+                                $oldPath = $rootPath . $v . DS . $name;
+                                $newPath = $rootPath . 'addons' . DS . $name . DS . $v . DS . $name;
+                                $paths[$oldPath] = $newPath;
+                            }
+                            break;
+                    }
+                }
+                foreach ($paths as $oldPath => $newPath) {
+                    if (is_dir($oldPath)) {
+                        if ($force) {
+                            if (is_dir($newPath)) {
+                                $list = scandir($newPath);
+                                foreach ($list as $_v) {
+                                    if (!in_array($_v, ['.', '..'])) {
+                                        $file = $newPath . DS . $_v;
+                                        @chmod($file, 0777);
+                                        @unlink($file);
+                                    }
+                                }
+                                @rmdir($newPath);
+                            }
+                        }
+                        copydirs($oldPath, $newPath);
+                    }
+                }
+                break;
+            default:
+                break;
+        }
+    }
+
+    /**
+     * 获取创建菜单的数组
+     * @param array $menu
+     * @return array
+     */
+    protected function getCreateMenu($menu)
+    {
+        $result = [];
+        foreach ($menu as $k => & $v) {
+            $arr = [
+                'name'  => $v['name'],
+                'title' => $v['title'],
+            ];
+            if ($v['icon'] != 'fa fa-circle-o') {
+                $arr['icon'] = $v['icon'];
+            }
+            if ($v['ismenu']) {
+                $arr['ismenu'] = $v['ismenu'];
+            }
+            if (isset($v['childlist']) && $v['childlist']) {
+                $arr['sublist'] = $this->getCreateMenu($v['childlist']);
+            }
+            $result[] = $arr;
+        }
+        return $result;
+    }
+
+    /**
+     * 写入到文件
+     * @param string $name
+     * @param array  $data
+     * @param string $pathname
+     * @return mixed
+     */
+    protected function writeToFile($name, $data, $pathname)
+    {
+        $search = $replace = [];
+        foreach ($data as $k => $v) {
+            $search[] = "{%{$k}%}";
+            $replace[] = $v;
+        }
+        $stub = file_get_contents($this->getStub($name));
+        $content = str_replace($search, $replace, $stub);
+
+        if (!is_dir(dirname($pathname))) {
+            mkdir(strtolower(dirname($pathname)), 0755, true);
+        }
+        return file_put_contents($pathname, $content);
+    }
+
+    /**
+     * 获取基础模板
+     * @param string $name
+     * @return string
+     */
+    protected function getStub($name)
+    {
+        return __DIR__ . '/Addon/stubs/' . $name . '.stub';
+    }
+
+}

+ 54 - 0
application/admin/command/Addon/stubs/addon.stub

@@ -0,0 +1,54 @@
+<?php
+
+namespace addons\{%name%};
+
+use app\common\library\Menu;
+use think\Addons;
+
+/**
+ * 插件
+ */
+class {%addonClassName%} extends Addons
+{
+
+    /**
+     * 插件安装方法
+     * @return bool
+     */
+    public function install()
+    {
+        {%addonInstallMenu%}
+        return true;
+    }
+
+    /**
+     * 插件卸载方法
+     * @return bool
+     */
+    public function uninstall()
+    {
+        {%addonUninstallMenu%}
+        return true;
+    }
+
+    /**
+     * 插件启用方法
+     * @return bool
+     */
+    public function enable()
+    {
+        {%addonEnableMenu%}
+        return true;
+    }
+
+    /**
+     * 插件禁用方法
+     * @return bool
+     */
+    public function disable()
+    {
+        {%addonDisableMenu%}
+        return true;
+    }
+
+}

+ 44 - 0
application/admin/command/Addon/stubs/config.stub

@@ -0,0 +1,44 @@
+<?php
+
+return [
+    [
+        //配置唯一标识
+        'name'    => 'usernmae',
+        //显示的标题
+        'title'   => '用户名',
+        //类型
+        'type'    => 'string',
+        //分组
+        'group'    => '',
+        //动态显示
+        'visible'    => '',
+        //数据字典
+        'content' => [
+        ],
+        //值
+        'value'   => '',
+        //验证规则
+        'rule'    => 'required',
+        //错误消息
+        'msg'     => '',
+        //提示消息
+        'tip'     => '',
+        //成功消息
+        'ok'      => '',
+        //扩展信息
+        'extend'  => ''
+    ],
+    [
+        'name'    => 'password',
+        'title'   => '密码',
+        'type'    => 'string',
+        'content' => [
+        ],
+        'value'   => '',
+        'rule'    => 'required',
+        'msg'     => '',
+        'tip'     => '',
+        'ok'      => '',
+        'extend'  => ''
+    ],
+];

+ 15 - 0
application/admin/command/Addon/stubs/controller.stub

@@ -0,0 +1,15 @@
+<?php
+
+namespace addons\{%addon%}\controller;
+
+use think\addons\Controller;
+
+class Index extends Controller
+{
+
+    public function index()
+    {
+        $this->error("当前插件暂无前台页面");
+    }
+
+}

+ 7 - 0
application/admin/command/Addon/stubs/info.stub

@@ -0,0 +1,7 @@
+name = {%name%}
+title = 插件名称{%name%}
+intro = 插件介绍
+author = yourname
+website = https://www.fastadmin.net
+version = 1.0.0
+state = 1

+ 195 - 0
application/admin/command/Api.php

@@ -0,0 +1,195 @@
+<?php
+
+namespace app\admin\command;
+
+use app\admin\command\Api\library\Builder;
+use think\Config;
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Exception;
+
+class Api extends Command
+{
+    protected function configure()
+    {
+        $site = Config::get('site');
+        $this
+            ->setName('api')
+            ->addOption('url', 'u', Option::VALUE_OPTIONAL, 'default api url', '')
+            ->addOption('module', 'm', Option::VALUE_OPTIONAL, 'module name(admin/index/api)', 'api')
+            ->addOption('output', 'o', Option::VALUE_OPTIONAL, 'output index file name', 'api.html')
+            ->addOption('template', 'e', Option::VALUE_OPTIONAL, '', 'index.html')
+            ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force override general file', false)
+            ->addOption('title', 't', Option::VALUE_OPTIONAL, 'document title', $site['name'] ?? '')
+            ->addOption('class', 'c', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'extend class', null)
+            ->addOption('language', 'l', Option::VALUE_OPTIONAL, 'language', 'zh-cn')
+            ->addOption('addon', 'a', Option::VALUE_OPTIONAL, 'addon name', null)
+            ->addOption('controller', 'r', Option::VALUE_REQUIRED | Option::VALUE_IS_ARRAY, 'controller name', null)
+            ->setDescription('Build Api document from controller');
+    }
+
+    protected function execute(Input $input, Output $output)
+    {
+        $apiDir = __DIR__ . DS . 'Api' . DS;
+
+        $force = $input->getOption('force');
+        $url = $input->getOption('url');
+        $language = $input->getOption('language');
+        $template = $input->getOption('template');
+        if (!preg_match("/^([a-z0-9]+)\.html\$/i", $template)) {
+            throw new Exception('template file not correct');
+        }
+        $language = $language ? $language : 'zh-cn';
+        $langFile = $apiDir . 'lang' . DS . $language . '.php';
+        if (!is_file($langFile)) {
+            throw new Exception('language file not found');
+        }
+        $lang = include_once $langFile;
+        // 目标目录
+        $output_dir = ROOT_PATH . 'public' . DS;
+        $output_file = $output_dir . $input->getOption('output');
+        if (is_file($output_file) && !$force) {
+            throw new Exception("api index file already exists!\nIf you need to rebuild again, use the parameter --force=true ");
+        }
+        // 模板文件
+        $template_dir = $apiDir . 'template' . DS;
+        $template_file = $template_dir . $template;
+        if (!is_file($template_file)) {
+            throw new Exception('template file not found');
+        }
+        // 额外的类
+        $classes = $input->getOption('class');
+        // 标题
+        $title = $input->getOption('title');
+        // 模块
+        $module = $input->getOption('module');
+        // 插件
+        $addon = $input->getOption('addon');
+
+        $moduleDir = $addonDir = '';
+        if ($addon) {
+            $addonInfo = get_addon_info($addon);
+            if (!$addonInfo) {
+                throw new Exception('addon not found');
+            }
+            $moduleDir = ADDON_PATH . $addon . DS;
+        } else {
+            $moduleDir = APP_PATH . $module . DS;
+        }
+        if (!is_dir($moduleDir)) {
+            throw new Exception('module not found');
+        }
+
+        if (version_compare(PHP_VERSION, '7.0.0', '<')) {
+            throw new Exception("Requires PHP version 7.0 or newer");
+        }
+
+        //控制器名
+        $controller = $input->getOption('controller') ?: [];
+        if (!$controller) {
+            $controllerDir = $moduleDir . Config::get('url_controller_layer') . DS;
+            $files = new \RecursiveIteratorIterator(
+                new \RecursiveDirectoryIterator($controllerDir),
+                \RecursiveIteratorIterator::LEAVES_ONLY
+            );
+
+            foreach ($files as $name => $file) {
+                if (!$file->isDir() && $file->getExtension() == 'php') {
+                    $filePath = $file->getRealPath();
+                    $classes[] = $this->get_class_from_file($filePath);
+                }
+            }
+        } else {
+            foreach ($controller as $index => $item) {
+                $filePath = $moduleDir . Config::get('url_controller_layer') . DS . $item . '.php';
+                $classes[] = $this->get_class_from_file($filePath);
+            }
+        }
+
+        $classes = array_unique(array_filter($classes));
+
+        $config = [
+            'sitename'    => config('site.name'),
+            'title'       => $title,
+            'author'      => config('site.name'),
+            'description' => '',
+            'apiurl'      => $url,
+            'language'    => $language,
+        ];
+
+        $builder = new Builder($classes);
+        $content = $builder->render($template_file, ['config' => $config, 'lang' => $lang]);
+
+        if (!file_put_contents($output_file, $content)) {
+            throw new Exception('Cannot save the content to ' . $output_file);
+        }
+        $output->info("Build Successed!");
+    }
+
+    /**
+     * get full qualified class name
+     *
+     * @param string $path_to_file
+     * @return string
+     * @author JBYRNE http://jarretbyrne.com/2015/06/197/
+     */
+    protected function get_class_from_file($path_to_file)
+    {
+        //Grab the contents of the file
+        $contents = file_get_contents($path_to_file);
+
+        //Start with a blank namespace and class
+        $namespace = $class = "";
+
+        //Set helper values to know that we have found the namespace/class token and need to collect the string values after them
+        $getting_namespace = $getting_class = false;
+
+        //Go through each token and evaluate it as necessary
+        foreach (token_get_all($contents) as $token) {
+
+            //If this token is the namespace declaring, then flag that the next tokens will be the namespace name
+            if (is_array($token) && $token[0] == T_NAMESPACE) {
+                $getting_namespace = true;
+            }
+
+            //If this token is the class declaring, then flag that the next tokens will be the class name
+            if (is_array($token) && $token[0] == T_CLASS) {
+                $getting_class = true;
+            }
+
+            //While we're grabbing the namespace name...
+            if ($getting_namespace === true) {
+
+                //If the token is a string or the namespace separator...
+                if (is_array($token) && in_array($token[0], [T_STRING, T_NS_SEPARATOR])) {
+
+                    //Append the token's value to the name of the namespace
+                    $namespace .= $token[1];
+                } elseif ($token === ';') {
+
+                    //If the token is the semicolon, then we're done with the namespace declaration
+                    $getting_namespace = false;
+                }
+            }
+
+            //While we're grabbing the class name...
+            if ($getting_class === true) {
+
+                //If the token is a string, it's the name of the class
+                if (is_array($token) && $token[0] == T_STRING) {
+
+                    //Store the token's value as the class name
+                    $class = $token[1];
+
+                    //Got what we need, stope here
+                    break;
+                }
+            }
+        }
+
+        //Build the fully-qualified class name and return it
+        return $namespace ? $namespace . '\\' . $class : $class;
+    }
+}

+ 25 - 0
application/admin/command/Api/lang/zh-cn.php

@@ -0,0 +1,25 @@
+<?php
+
+return [
+    'Info'             => '基础信息',
+    'Sandbox'          => '在线测试',
+    'Sampleoutput'     => '返回示例',
+    'Headers'          => 'Headers',
+    'Parameters'       => '参数',
+    'Body'             => '正文',
+    'Name'             => '名称',
+    'Type'             => '类型',
+    'Required'         => '必选',
+    'Description'      => '描述',
+    'Send'             => '提交',
+    'Reset'            => '重置',
+    'Tokentips'        => 'Token在会员注册或登录后都会返回,WEB端同时存在于Cookie中',
+    'Apiurltips'       => 'API接口URL',
+    'Savetips'         => '点击保存后Token和Api url都将保存在本地Localstorage中',
+    'Authorization'    => '权限',
+    'NeedLogin'        => '登录',
+    'NeedRight'        => '鉴权',
+    'ReturnHeaders'    => '响应头',
+    'ReturnParameters' => '返回参数',
+    'Response'         => '响应输出',
+];

+ 253 - 0
application/admin/command/Api/library/Builder.php

@@ -0,0 +1,253 @@
+<?php
+
+namespace app\admin\command\Api\library;
+
+use think\Config;
+
+/**
+ * @website https://github.com/calinrada/php-apidoc
+ * @author  Calin Rada <rada.calin@gmail.com>
+ * @author  Karson <karson@fastadmin.net>
+ */
+class Builder
+{
+
+    /**
+     *
+     * @var \think\View
+     */
+    public $view = null;
+
+    /**
+     * parse classes
+     * @var array
+     */
+    protected $classes = [];
+
+    /**
+     *
+     * @param array $classes
+     */
+    public function __construct($classes = [])
+    {
+        $this->classes = array_merge($this->classes, $classes);
+        $this->view = new \think\View(Config::get('template'), Config::get('view_replace_str'));
+    }
+
+    protected function extractAnnotations()
+    {
+        foreach ($this->classes as $class) {
+            $classAnnotation = Extractor::getClassAnnotations($class);
+            // 如果忽略
+            if (isset($classAnnotation['ApiInternal'])) {
+                continue;
+            }
+            Extractor::getClassMethodAnnotations($class);
+            //Extractor::getClassPropertyValues($class);
+        }
+        $allClassAnnotation = Extractor::getAllClassAnnotations();
+        $allClassMethodAnnotation = Extractor::getAllClassMethodAnnotations();
+        //$allClassPropertyValue = Extractor::getAllClassPropertyValues();
+
+//        foreach ($allClassMethodAnnotation as $className => &$methods) {
+//            foreach ($methods as &$method) {
+//                //权重判断
+//                if ($method && !isset($method['ApiWeigh']) && isset($allClassAnnotation[$className]['ApiWeigh'])) {
+//                    $method['ApiWeigh'] = $allClassAnnotation[$className]['ApiWeigh'];
+//                }
+//            }
+//        }
+//        unset($methods);
+        return [$allClassAnnotation, $allClassMethodAnnotation];
+    }
+
+    protected function generateHeadersTemplate($docs)
+    {
+        if (!isset($docs['ApiHeaders'])) {
+            return [];
+        }
+
+        $headerslist = array();
+        foreach ($docs['ApiHeaders'] as $params) {
+            $tr = array(
+                'name'        => $params['name'] ?? '',
+                'type'        => $params['type'] ?? 'string',
+                'sample'      => $params['sample'] ?? '',
+                'required'    => $params['required'] ?? false,
+                'description' => $params['description'] ?? '',
+            );
+            $headerslist[] = $tr;
+        }
+
+        return $headerslist;
+    }
+
+    protected function generateParamsTemplate($docs)
+    {
+        if (!isset($docs['ApiParams'])) {
+            return [];
+        }
+
+        $paramslist = array();
+        foreach ($docs['ApiParams'] as $params) {
+            $tr = array(
+                'name'        => $params['name'],
+                'type'        => $params['type'] ?? 'string',
+                'sample'      => $params['sample'] ?? '',
+                'required'    => $params['required'] ?? true,
+                'description' => $params['description'] ?? '',
+            );
+            $paramslist[] = $tr;
+        }
+
+        return $paramslist;
+    }
+
+    protected function generateReturnHeadersTemplate($docs)
+    {
+        if (!isset($docs['ApiReturnHeaders'])) {
+            return [];
+        }
+
+        $headerslist = array();
+        foreach ($docs['ApiReturnHeaders'] as $params) {
+            $tr = array(
+                'name'        => $params['name'] ?? '',
+                'type'        => 'string',
+                'sample'      => $params['sample'] ?? '',
+                'required'    => isset($params['required']) && $params['required'] ? 'Yes' : 'No',
+                'description' => $params['description'] ?? '',
+            );
+            $headerslist[] = $tr;
+        }
+
+        return $headerslist;
+    }
+
+    protected function generateReturnParamsTemplate($st_params)
+    {
+        if (!isset($st_params['ApiReturnParams'])) {
+            return [];
+        }
+
+        $paramslist = array();
+        foreach ($st_params['ApiReturnParams'] as $params) {
+            $tr = array(
+                'name'        => $params['name'] ?? '',
+                'type'        => $params['type'] ?? 'string',
+                'sample'      => $params['sample'] ?? '',
+                'description' => $params['description'] ?? '',
+            );
+            $paramslist[] = $tr;
+        }
+
+        return $paramslist;
+    }
+
+    protected function generateBadgeForMethod($data)
+    {
+        $method = strtoupper(is_array($data['ApiMethod'][0]) ? $data['ApiMethod'][0]['data'] : $data['ApiMethod'][0]);
+        $labes = array(
+            'POST'    => 'label-primary',
+            'GET'     => 'label-success',
+            'PUT'     => 'label-warning',
+            'DELETE'  => 'label-danger',
+            'PATCH'   => 'label-default',
+            'OPTIONS' => 'label-info'
+        );
+
+        return isset($labes[$method]) ? $labes[$method] : $labes['GET'];
+    }
+
+    public function parse()
+    {
+        list($allClassAnnotations, $allClassMethodAnnotations) = $this->extractAnnotations();
+
+        $sectorArr = [];
+        foreach ($allClassAnnotations as $index => &$allClassAnnotation) {
+            // 如果设置隐藏,则不显示在文档
+            if (isset($allClassAnnotation['ApiInternal'])) {
+                continue;
+            }
+            $sector = isset($allClassAnnotation['ApiSector']) ? $allClassAnnotation['ApiSector'][0] : $allClassAnnotation['ApiTitle'][0];
+            $sectorArr[$sector] = isset($allClassAnnotation['ApiWeigh']) ? $allClassAnnotation['ApiWeigh'][0] : 0;
+        }
+        unset($allClassAnnotation);
+
+        arsort($sectorArr);
+        $routes = include_once CONF_PATH . 'route.php';
+        $subdomain = false;
+        if (config('url_domain_deploy') && isset($routes['__domain__']) && isset($routes['__domain__']['api']) && $routes['__domain__']['api']) {
+            $subdomain = true;
+        }
+        $counter = 0;
+        $section = null;
+        $weigh = 0;
+        $docsList = [];
+        foreach ($allClassMethodAnnotations as $class => $methods) {
+            foreach ($methods as $name => $docs) {
+                if (isset($docs['ApiSector'][0])) {
+                    $section = is_array($docs['ApiSector'][0]) ? $docs['ApiSector'][0]['data'] : $docs['ApiSector'][0];
+                } else {
+                    $section = $class;
+                }
+                if (0 === count($docs)) {
+                    continue;
+                }
+                $route = is_array($docs['ApiRoute'][0]) ? $docs['ApiRoute'][0]['data'] : $docs['ApiRoute'][0];
+                if ($subdomain) {
+                    $route = substr($route, 4);
+                }
+                $docsList[$section][$name] = [
+                    'id'                => $counter,
+                    'method'            => is_array($docs['ApiMethod'][0]) ? $docs['ApiMethod'][0]['data'] : $docs['ApiMethod'][0],
+                    'methodLabel'       => $this->generateBadgeForMethod($docs),
+                    'section'           => $section,
+                    'route'             => $route,
+                    'title'             => is_array($docs['ApiTitle'][0]) ? $docs['ApiTitle'][0]['data'] : $docs['ApiTitle'][0],
+                    'summary'           => is_array($docs['ApiSummary'][0]) ? $docs['ApiSummary'][0]['data'] : $docs['ApiSummary'][0],
+                    'body'              => isset($docs['ApiBody'][0]) ? (is_array($docs['ApiBody'][0]) ? $docs['ApiBody'][0]['data'] : $docs['ApiBody'][0]) : '',
+                    'headersList'       => $this->generateHeadersTemplate($docs),
+                    'paramsList'        => $this->generateParamsTemplate($docs),
+                    'returnHeadersList' => $this->generateReturnHeadersTemplate($docs),
+                    'returnParamsList'  => $this->generateReturnParamsTemplate($docs),
+                    'weigh'             => is_array($docs['ApiWeigh'][0]) ? $docs['ApiWeigh'][0]['data'] : $docs['ApiWeigh'][0],
+                    'return'            => isset($docs['ApiReturn']) ? (is_array($docs['ApiReturn'][0]) ? $docs['ApiReturn'][0]['data'] : $docs['ApiReturn'][0]) : '',
+                    'needLogin'         => $docs['ApiPermissionLogin'][0],
+                    'needRight'         => $docs['ApiPermissionRight'][0],
+                ];
+                $counter++;
+            }
+        }
+
+        //重建排序
+        foreach ($docsList as $index => &$methods) {
+            $methodSectorArr = [];
+            foreach ($methods as $name => $method) {
+                $methodSectorArr[$name] = isset($method['weigh']) ? $method['weigh'] : 0;
+            }
+            arsort($methodSectorArr);
+            $methods = array_merge(array_flip(array_keys($methodSectorArr)), $methods);
+        }
+        $docsList = array_merge(array_flip(array_keys($sectorArr)), $docsList);
+        return $docsList;
+    }
+
+    public function getView()
+    {
+        return $this->view;
+    }
+
+    /**
+     * 渲染
+     * @param string $template
+     * @param array  $vars
+     * @return string
+     */
+    public function render($template, $vars = [])
+    {
+        $docsList = $this->parse();
+
+        return $this->view->display(file_get_contents($template), array_merge($vars, ['docsList' => $docsList]));
+    }
+}

+ 544 - 0
application/admin/command/Api/library/Extractor.php

@@ -0,0 +1,544 @@
+<?php
+
+namespace app\admin\command\Api\library;
+
+use Exception;
+
+/**
+ * Class imported from https://github.com/eriknyk/Annotations
+ * @author  Erik Amaru Ortiz https://github.com/eriknyk‎
+ *
+ * @license http://opensource.org/licenses/bsd-license.php The BSD License
+ * @author  Calin Rada <rada.calin@gmail.com>
+ */
+class Extractor
+{
+
+    /**
+     * Static array to store already parsed annotations
+     * @var array
+     */
+    private static $annotationCache;
+
+    private static $classAnnotationCache;
+
+    private static $classMethodAnnotationCache;
+
+    private static $classPropertyValueCache;
+
+    /**
+     * Indicates that annotations should has strict behavior, 'false' by default
+     * @var boolean
+     */
+    private $strict = false;
+
+    /**
+     * Stores the default namespace for Objects instance, usually used on methods like getMethodAnnotationsObjects()
+     * @var string
+     */
+    public $defaultNamespace = '';
+
+    /**
+     * Sets strict variable to true/false
+     * @param bool $value boolean value to indicate that annotations to has strict behavior
+     */
+    public function setStrict($value)
+    {
+        $this->strict = (bool)$value;
+    }
+
+    /**
+     * Sets default namespace to use in object instantiation
+     * @param string $namespace default namespace
+     */
+    public function setDefaultNamespace($namespace)
+    {
+        $this->defaultNamespace = $namespace;
+    }
+
+    /**
+     * Gets default namespace used in object instantiation
+     * @return string $namespace default namespace
+     */
+    public function getDefaultAnnotationNamespace()
+    {
+        return $this->defaultNamespace;
+    }
+
+    /**
+     * Gets all anotations with pattern @SomeAnnotation() from a given class
+     *
+     * @param string $className class name to get annotations
+     * @return array  self::$classAnnotationCache all annotated elements
+     */
+    public static function getClassAnnotations($className)
+    {
+        if (!isset(self::$classAnnotationCache[$className])) {
+            $class = new \ReflectionClass($className);
+            $annotationArr = self::parseAnnotations($class->getDocComment());
+            $annotationArr['ApiTitle'] = !isset($annotationArr['ApiTitle'][0]) || !trim($annotationArr['ApiTitle'][0]) ? [$class->getShortName()] : $annotationArr['ApiTitle'];
+            self::$classAnnotationCache[$className] = $annotationArr;
+        }
+
+        return self::$classAnnotationCache[$className];
+    }
+
+    /**
+     * 获取类所有方法的属性配置
+     * @param $className
+     * @return mixed
+     * @throws \ReflectionException
+     */
+    public static function getClassMethodAnnotations($className)
+    {
+        $class = new \ReflectionClass($className);
+
+        foreach ($class->getMethods() as $object) {
+            self::$classMethodAnnotationCache[$className][$object->name] = self::getMethodAnnotations($className, $object->name);
+        }
+
+        return self::$classMethodAnnotationCache[$className];
+    }
+
+    public static function getClassPropertyValues($className)
+    {
+        $class = new \ReflectionClass($className);
+
+        foreach ($class->getProperties() as $object) {
+            self::$classPropertyValueCache[$className][$object->name] = self::getClassPropertyValue($className, $object->name);
+        }
+
+        return self::$classMethodAnnotationCache[$className];
+    }
+
+    public static function getAllClassAnnotations()
+    {
+        return self::$classAnnotationCache;
+    }
+
+    public static function getAllClassMethodAnnotations()
+    {
+        return self::$classMethodAnnotationCache;
+    }
+
+    public static function getAllClassPropertyValues()
+    {
+        return self::$classPropertyValueCache;
+    }
+
+    public static function getClassPropertyValue($className, $property)
+    {
+        $_SERVER['REQUEST_METHOD'] = 'GET';
+        $reflectionClass = new \ReflectionClass($className);
+        $reflectionProperty = $reflectionClass->getProperty($property);
+        $reflectionProperty->setAccessible(true);
+        return $reflectionProperty->getValue($reflectionClass->newInstanceWithoutConstructor());
+    }
+
+    /**
+     * Gets all anotations with pattern @SomeAnnotation() from a determinated method of a given class
+     *
+     * @param string $className  class name
+     * @param string $methodName method name to get annotations
+     * @return array  self::$annotationCache all annotated elements of a method given
+     */
+    public static function getMethodAnnotations($className, $methodName)
+    {
+        if (!isset(self::$annotationCache[$className . '::' . $methodName])) {
+            try {
+                $method = new \ReflectionMethod($className, $methodName);
+                $class = new \ReflectionClass($className);
+                if (!$method->isPublic() || $method->isConstructor()) {
+                    $annotations = array();
+                } else {
+                    $annotations = self::consolidateAnnotations($method, $class);
+                }
+            } catch (\ReflectionException $e) {
+                $annotations = array();
+            }
+
+            self::$annotationCache[$className . '::' . $methodName] = $annotations;
+        }
+
+        return self::$annotationCache[$className . '::' . $methodName];
+    }
+
+    /**
+     * Gets all anotations with pattern @SomeAnnotation() from a determinated method of a given class
+     * and instance its abcAnnotation class
+     *
+     * @param string $className  class name
+     * @param string $methodName method name to get annotations
+     * @return array  self::$annotationCache all annotated objects of a method given
+     */
+    public function getMethodAnnotationsObjects($className, $methodName)
+    {
+        $annotations = $this->getMethodAnnotations($className, $methodName);
+        $objects = array();
+
+        $i = 0;
+
+        foreach ($annotations as $annotationClass => $listParams) {
+            $annotationClass = ucfirst($annotationClass);
+            $class = $this->defaultNamespace . $annotationClass . 'Annotation';
+
+            // verify is the annotation class exists, depending if Annotations::strict is true
+            // if not, just skip the annotation instance creation.
+            if (!class_exists($class)) {
+                if ($this->strict) {
+                    throw new Exception(sprintf('Runtime Error: Annotation Class Not Found: %s', $class));
+                } else {
+                    // silent skip & continue
+                    continue;
+                }
+            }
+
+            if (empty($objects[$annotationClass])) {
+                $objects[$annotationClass] = new $class();
+            }
+
+            foreach ($listParams as $params) {
+                if (is_array($params)) {
+                    foreach ($params as $key => $value) {
+                        $objects[$annotationClass]->set($key, $value);
+                    }
+                } else {
+                    $objects[$annotationClass]->set($i++, $params);
+                }
+            }
+        }
+
+        return $objects;
+    }
+
+    private static function consolidateAnnotations($method, $class)
+    {
+        $dockblockClass = $class->getDocComment();
+        $docblockMethod = $method->getDocComment();
+        $methodName = $method->getName();
+
+        $methodAnnotations = self::parseAnnotations($docblockMethod);
+        $methodAnnotations['ApiTitle'] = !isset($methodAnnotations['ApiTitle'][0]) || !trim($methodAnnotations['ApiTitle'][0]) ? [$method->getName()] : $methodAnnotations['ApiTitle'];
+
+        $classAnnotations = self::parseAnnotations($dockblockClass);
+        $classAnnotations['ApiTitle'] = !isset($classAnnotations['ApiTitle'][0]) || !trim($classAnnotations['ApiTitle'][0]) ? [$class->getShortName()] : $classAnnotations['ApiTitle'];
+
+        if (isset($methodAnnotations['ApiInternal']) || $methodName == '_initialize' || $methodName == '_empty') {
+            return [];
+        }
+
+        $properties = $class->getDefaultProperties();
+        $noNeedLogin = isset($properties['noNeedLogin']) ? (is_array($properties['noNeedLogin']) ? $properties['noNeedLogin'] : [$properties['noNeedLogin']]) : [];
+        $noNeedRight = isset($properties['noNeedRight']) ? (is_array($properties['noNeedRight']) ? $properties['noNeedRight'] : [$properties['noNeedRight']]) : [];
+
+        preg_match_all("/\*[\s]+(.*)(\\r\\n|\\r|\\n)/U", str_replace('/**', '', $docblockMethod), $methodArr);
+        preg_match_all("/\*[\s]+(.*)(\\r\\n|\\r|\\n)/U", str_replace('/**', '', $dockblockClass), $classArr);
+
+        if (!isset($methodAnnotations['ApiMethod'])) {
+            $methodAnnotations['ApiMethod'] = ['get'];
+        }
+        if (!isset($methodAnnotations['ApiWeigh'])) {
+            $methodAnnotations['ApiWeigh'] = [0];
+        }
+        if (!isset($methodAnnotations['ApiSummary'])) {
+            $methodAnnotations['ApiSummary'] = $methodAnnotations['ApiTitle'];
+        }
+
+        if ($methodAnnotations) {
+            foreach ($classAnnotations as $name => $valueClass) {
+                if (count($valueClass) !== 1) {
+                    continue;
+                }
+
+                if ($name === 'ApiRoute') {
+                    if (isset($methodAnnotations[$name])) {
+                        $methodAnnotations[$name] = [rtrim($valueClass[0], '/') . $methodAnnotations[$name][0]];
+                    } else {
+                        $methodAnnotations[$name] = [rtrim($valueClass[0], '/') . '/' . $method->getName()];
+                    }
+                }
+
+                if ($name === 'ApiSector') {
+                    $methodAnnotations[$name] = $valueClass;
+                }
+            }
+        }
+        if (!isset($methodAnnotations['ApiRoute'])) {
+            $urlArr = [];
+            $className = $class->getName();
+
+            list($prefix, $suffix) = explode('\\' . \think\Config::get('url_controller_layer') . '\\', $className);
+            $prefixArr = explode('\\', $prefix);
+            $suffixArr = explode('\\', $suffix);
+            if ($prefixArr[0] == \think\Config::get('app_namespace')) {
+                $prefixArr[0] = '';
+            }
+            $urlArr = array_merge($urlArr, $prefixArr);
+            $urlArr[] = implode('.', array_map(function ($item) {
+                return \think\Loader::parseName($item);
+            }, $suffixArr));
+            $urlArr[] = $method->getName();
+
+            $methodAnnotations['ApiRoute'] = [implode('/', $urlArr)];
+        }
+        if (!isset($methodAnnotations['ApiSector'])) {
+            $methodAnnotations['ApiSector'] = isset($classAnnotations['ApiSector']) ? $classAnnotations['ApiSector'] : $classAnnotations['ApiTitle'];
+        }
+        if (!isset($methodAnnotations['ApiParams'])) {
+            $params = self::parseCustomAnnotations($docblockMethod, 'param');
+            foreach ($params as $k => $v) {
+                $arr = explode(' ', preg_replace("/[\s]+/", " ", $v));
+                $methodAnnotations['ApiParams'][] = [
+                    'name'        => isset($arr[1]) ? str_replace('$', '', $arr[1]) : '',
+                    'nullable'    => false,
+                    'type'        => isset($arr[0]) ? $arr[0] : 'string',
+                    'description' => isset($arr[2]) ? $arr[2] : ''
+                ];
+            }
+        }
+        $methodAnnotations['ApiPermissionLogin'] = [!in_array('*', $noNeedLogin) && !in_array($methodName, $noNeedLogin)];
+        $methodAnnotations['ApiPermissionRight'] = !$methodAnnotations['ApiPermissionLogin'][0] ? [false] : [!in_array('*', $noNeedRight) && !in_array($methodName, $noNeedRight)];
+        return $methodAnnotations;
+    }
+
+    /**
+     * Parse annotations
+     *
+     * @param string $docblock
+     * @param string $name
+     * @return array  parsed annotations params
+     */
+    private static function parseCustomAnnotations($docblock, $name = 'param')
+    {
+        $annotations = array();
+
+        $docblock = substr($docblock, 3, -2);
+        if (preg_match_all('/@' . $name . '(?:\s*(?:\(\s*)?(.*?)(?:\s*\))?)??\s*(?:\n|\*\/)/', $docblock, $matches)) {
+            foreach ($matches[1] as $k => $v) {
+                $annotations[] = $v;
+            }
+        }
+        return $annotations;
+    }
+
+    /**
+     * Parse annotations
+     *
+     * @param string $docblock
+     * @return array  parsed annotations params
+     */
+    private static function parseAnnotations($docblock)
+    {
+        $annotations = array();
+
+        // Strip away the docblock header and footer to ease parsing of one line annotations
+        $docblock = substr($docblock, 3, -2);
+        if (preg_match_all('/@(?<name>[A-Za-z_-]+)[\s\t]*\((?<args>(?:(?!\)).)*)\)\r?/s', $docblock, $matches)) {
+            $numMatches = count($matches[0]);
+            for ($i = 0; $i < $numMatches; ++$i) {
+                $name = $matches['name'][$i];
+                $value = '';
+                // annotations has arguments
+                if (isset($matches['args'][$i])) {
+                    $argsParts = trim($matches['args'][$i]);
+                    if ($name == 'ApiReturn') {
+                        $value = $argsParts;
+                    } elseif ($matches['args'][$i] != '') {
+                        $argsParts = preg_replace("/\{(\w+)\}/", '#$1#', $argsParts);
+                        $value = self::parseArgs($argsParts);
+                        if (is_string($value)) {
+                            $value = preg_replace("/\#(\w+)\#/", '{$1}', $argsParts);
+                        }
+                    }
+                }
+
+                $annotations[$name][] = $value;
+            }
+        }
+        if (stripos($docblock, '@ApiInternal') !== false) {
+            $annotations['ApiInternal'] = [true];
+        }
+        if (!isset($annotations['ApiTitle'])) {
+            preg_match_all("/\*[\s]+(.*)(\\r\\n|\\r|\\n)/U", str_replace('/**', '', $docblock), $matchArr);
+            $title = isset($matchArr[1]) && isset($matchArr[1][0]) ? $matchArr[1][0] : '';
+            $annotations['ApiTitle'] = [$title];
+        }
+
+        return $annotations;
+    }
+
+    /**
+     * Parse individual annotation arguments
+     *
+     * @param string $content arguments string
+     * @return array  annotated arguments
+     */
+    private static function parseArgs($content)
+    {
+        // Replace initial stars
+        $content = preg_replace('/^\s*\*/m', '', $content);
+
+        $data = array();
+        $len = strlen($content);
+        $i = 0;
+        $var = '';
+        $val = '';
+        $level = 1;
+
+        $prevDelimiter = '';
+        $nextDelimiter = '';
+        $nextToken = '';
+        $composing = false;
+        $type = 'plain';
+        $delimiter = null;
+        $quoted = false;
+        $tokens = array('"', '"', '{', '}', ',', '=');
+
+        while ($i <= $len) {
+            $prev_c = substr($content, $i - 1, 1);
+            $c = substr($content, $i++, 1);
+
+            if ($c === '"' && $prev_c !== "\\") {
+                $delimiter = $c;
+                //open delimiter
+                if (!$composing && empty($prevDelimiter) && empty($nextDelimiter)) {
+                    $prevDelimiter = $nextDelimiter = $delimiter;
+                    $val = '';
+                    $composing = true;
+                    $quoted = true;
+                } else {
+                    // close delimiter
+                    if ($c !== $nextDelimiter) {
+                        throw new Exception(sprintf(
+                            "Parse Error: enclosing error -> expected: [%s], given: [%s]",
+                            $nextDelimiter,
+                            $c
+                        ));
+                    }
+
+                    // validating syntax
+                    if ($i < $len) {
+                        if (',' !== substr($content, $i, 1) && '\\' !== $prev_c) {
+                            throw new Exception(sprintf(
+                                "Parse Error: missing comma separator near: ...%s<--",
+                                substr($content, ($i - 10), $i)
+                            ));
+                        }
+                    }
+
+                    $prevDelimiter = $nextDelimiter = '';
+                    $composing = false;
+                    $delimiter = null;
+                }
+            } elseif (!$composing && in_array($c, $tokens)) {
+                switch ($c) {
+                    case '=':
+                        $prevDelimiter = $nextDelimiter = '';
+                        $level = 2;
+                        $composing = false;
+                        $type = 'assoc';
+                        $quoted = false;
+                        break;
+                    case ',':
+                        $level = 3;
+
+                        // If composing flag is true yet,
+                        // it means that the string was not enclosed, so it is parsing error.
+                        if ($composing === true && !empty($prevDelimiter) && !empty($nextDelimiter)) {
+                            throw new Exception(sprintf(
+                                "Parse Error: enclosing error -> expected: [%s], given: [%s]",
+                                $nextDelimiter,
+                                $c
+                            ));
+                        }
+
+                        $prevDelimiter = $nextDelimiter = '';
+                        break;
+                    case '{':
+                        $subc = '';
+                        $subComposing = true;
+
+                        while ($i <= $len) {
+                            $c = substr($content, $i++, 1);
+
+                            if (isset($delimiter) && $c === $delimiter) {
+                                throw new Exception(sprintf(
+                                    "Parse Error: Composite variable is not enclosed correctly."
+                                ));
+                            }
+
+                            if ($c === '}') {
+                                $subComposing = false;
+                                break;
+                            }
+                            $subc .= $c;
+                        }
+
+                        // if the string is composing yet means that the structure of var. never was enclosed with '}'
+                        if ($subComposing) {
+                            throw new Exception(sprintf(
+                                "Parse Error: Composite variable is not enclosed correctly. near: ...%s'",
+                                $subc
+                            ));
+                        }
+
+                        $val = self::parseArgs($subc);
+                        break;
+                }
+            } else {
+                if ($level == 1) {
+                    $var .= $c;
+                } elseif ($level == 2) {
+                    $val .= $c;
+                }
+            }
+
+            if ($level === 3 || $i === $len) {
+                if ($type == 'plain' && $i === $len) {
+                    $data = self::castValue($var);
+                } else {
+                    $data[trim($var)] = self::castValue($val, !$quoted);
+                }
+
+                $level = 1;
+                $var = $val = '';
+                $composing = false;
+                $quoted = false;
+            }
+        }
+
+        return $data;
+    }
+
+    /**
+     * Try determinate the original type variable of a string
+     *
+     * @param string  $val  string containing possibles variables that can be cast to bool or int
+     * @param boolean $trim indicate if the value passed should be trimmed after to try cast
+     * @return mixed   returns the value converted to original type if was possible
+     */
+    private static function castValue($val, $trim = false)
+    {
+        if (is_array($val)) {
+            foreach ($val as $key => $value) {
+                $val[$key] = self::castValue($value);
+            }
+        } elseif (is_string($val)) {
+            if ($trim) {
+                $val = trim($val);
+            }
+            $val = stripslashes($val);
+            $tmp = strtolower($val);
+
+            if ($tmp === 'false' || $tmp === 'true') {
+                $val = $tmp === 'true';
+            } elseif (is_numeric($val)) {
+                return $val + 0;
+            }
+
+            unset($tmp);
+        }
+
+        return $val;
+    }
+}

+ 654 - 0
application/admin/command/Api/template/index.html

@@ -0,0 +1,654 @@
+<!DOCTYPE html>
+<html lang="{$config.language}">
+    <head>
+        <meta charset="utf-8">
+        <meta http-equiv="X-UA-Compatible" content="IE=edge">
+        <meta name="viewport" content="width=device-width, initial-scale=1.0">
+        <meta name="description" content="">
+        <title>{$config.title}</title>
+
+        <!-- Bootstrap Core CSS -->
+        <link href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
+
+        <!-- Plugin CSS -->
+        <link href="https://cdn.staticfile.org/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
+
+        <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
+        <!--[if lt IE 9]>
+        <script src="https://cdn.staticfile.org/html5shiv/3.7.3/html5shiv.min.js"></script>
+        <script src="https://cdn.staticfile.org/respond.js/1.4.2/respond.min.js"></script>
+        <![endif]-->
+
+        <style type="text/css">
+            body {
+                padding-top: 70px; margin-bottom: 15px;
+                -webkit-font-smoothing: antialiased;
+                -moz-osx-font-smoothing: grayscale;
+                font-family: "Roboto", "SF Pro SC", "SF Pro Display", "SF Pro Icons", "PingFang SC", BlinkMacSystemFont, -apple-system, "Segoe UI", "Microsoft Yahei", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
+                font-weight: 400;
+            }
+            h2        { font-size: 1.2em; }
+            hr        { margin-top: 10px; }
+            .tab-pane { padding-top: 10px; }
+            .mt0      { margin-top: 0px; }
+            .footer   { font-size: 12px; color: #666; }
+            .docs-list .label    { display: inline-block; min-width: 65px; padding: 0.3em 0.6em 0.3em; }
+            .string   { color: green; }
+            .number   { color: darkorange; }
+            .boolean  { color: blue; }
+            .null     { color: magenta; }
+            .key      { color: red; }
+            .popover  { max-width: 400px; max-height: 400px; overflow-y: auto;}
+            .list-group.panel > .list-group-item {
+            }
+            .list-group-item:last-child {
+                border-radius:0;
+            }
+            h4.panel-title a {
+                font-weight:normal;
+                font-size:14px;
+            }
+            h4.panel-title a .text-muted {
+                font-size:12px;
+                font-weight:normal;
+                font-family: 'Verdana';
+            }
+            #sidebar {
+                width: 220px;
+                position: fixed;
+                margin-left: -240px;
+                overflow-y:auto;
+            }
+            #sidebar > .list-group {
+                margin-bottom:0;
+            }
+            #sidebar > .list-group > a{
+                text-indent:0;
+            }
+            #sidebar .child > a .tag{
+                position: absolute;
+                right: 10px;
+                top: 11px;
+            }
+            #sidebar .child > a .pull-right{
+                margin-left:3px;
+            }
+            #sidebar .child {
+                border:1px solid #ddd;
+                border-bottom:none;
+            }
+            #sidebar .child:last-child {
+                border-bottom:1px solid #ddd;
+            }
+            #sidebar .child > a {
+                border:0;
+                min-height: 40px;
+            }
+            #sidebar .list-group a.current {
+                background:#f5f5f5;
+            }
+            @media (max-width: 1620px){
+                #sidebar {
+                    margin:0;
+                }
+                #accordion {
+                    padding-left:235px;
+                }
+            }
+            @media (max-width: 768px){
+                #sidebar {
+                    display: none;
+                }
+                #accordion {
+                    padding-left:0px;
+                }
+            }
+            .label-primary {
+                background-color: #248aff;
+            }
+            .docs-list .panel .panel-body .table {
+                margin-bottom: 0;
+            }
+
+        </style>
+    </head>
+    <body>
+        <!-- Fixed navbar -->
+        <div class="navbar navbar-default navbar-fixed-top" role="navigation">
+            <div class="container">
+                <div class="navbar-header">
+                    <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
+                        <span class="sr-only">Toggle navigation</span>
+                        <span class="icon-bar"></span>
+                        <span class="icon-bar"></span>
+                        <span class="icon-bar"></span>
+                    </button>
+                    <a class="navbar-brand" href="./" target="_blank">{$config.title}</a>
+                </div>
+                <div class="navbar-collapse collapse">
+                    <form class="navbar-form navbar-right">
+                        <div class="form-group">
+                            Token:
+                        </div>
+                        <div class="form-group">
+                            <input type="text" class="form-control input-sm" data-toggle="tooltip" title="{$lang.Tokentips}" placeholder="token" id="token" />
+                        </div>
+                        <div class="form-group">
+                            Apiurl:
+                        </div>
+                        <div class="form-group">
+                            <input id="apiUrl" type="text" class="form-control input-sm" data-toggle="tooltip" title="{$lang.Apiurltips}" placeholder="https://api.mydomain.com" value="{$config.apiurl}" />
+                        </div>
+                        <div class="form-group">
+                            <button type="button" class="btn btn-success btn-sm" data-toggle="tooltip" title="{$lang.Savetips}" id="save_data">
+                                <span class="glyphicon glyphicon-floppy-disk" aria-hidden="true"></span>
+                            </button>
+                        </div>
+                    </form>
+                </div><!--/.nav-collapse -->
+            </div>
+        </div>
+
+        <div class="container">
+            <!-- menu -->
+            <div id="sidebar">
+                <div class="list-group panel">
+                    {foreach name="docsList" id="docs"}
+                    <a href="#{$key}" class="list-group-item" data-toggle="collapse" data-parent="#sidebar">{$key}  <i class="fa fa-caret-down"></i></a>
+                    <div class="child collapse" id="{$key}">
+                        {foreach name="docs" id="api" }
+                        <a href="javascript:;" data-id="{$api.id}" class="list-group-item">{$api.title}
+                            <span class="tag">
+                                {if $api.needRight}
+                                    <span class="label label-danger pull-right">鉴</span>
+                                {/if}
+                                {if $api.needLogin}
+                                    <span class="label label-success pull-right noneedlogin">登</span>
+                                {/if}
+                            </span>
+                        </a>
+                        {/foreach}
+                    </div>
+                    {/foreach}
+                </div>
+            </div>
+            <div class="panel-group docs-list" id="accordion">
+                {foreach name="docsList" id="docs"}
+                <h2>{$key}</h2>
+                <hr>
+                {foreach name="docs" id="api" }
+                <div class="panel panel-default">
+                    <div class="panel-heading" id="heading-{$api.id}">
+                        <h4 class="panel-title">
+                            <span class="label {$api.methodLabel}">{$api.method|strtoupper}</span>
+                            <a data-toggle="collapse" data-parent="#accordion{$api.id}" href="#collapseOne{$api.id}"> {$api.title} <span class="text-muted">{$api.route}</span></a>
+                        </h4>
+                    </div>
+                    <div id="collapseOne{$api.id}" class="panel-collapse collapse">
+                        <div class="panel-body">
+
+                            <!-- Nav tabs -->
+                            <ul class="nav nav-tabs" id="doctab{$api.id}">
+                                <li class="active"><a href="#info{$api.id}" data-toggle="tab">{$lang.Info}</a></li>
+                                <li><a href="#sandbox{$api.id}" data-toggle="tab">{$lang.Sandbox}</a></li>
+                                <li><a href="#sample{$api.id}" data-toggle="tab">{$lang.Sampleoutput}</a></li>
+                            </ul>
+
+                            <!-- Tab panes -->
+                            <div class="tab-content">
+
+                                <div class="tab-pane active" id="info{$api.id}">
+                                    <div class="well">
+                                        {$api.summary}
+                                    </div>
+                                    <div class="panel panel-default">
+                                        <div class="panel-heading"><strong>{$lang.Authorization}</strong></div>
+                                        <div class="panel-body">
+                                            <table class="table table-hover">
+                                                <tbody>
+                                                <tr>
+                                                    <td>{$lang.NeedLogin}</td>
+                                                    <td>{$api.needLogin?'是':'否'}</td>
+                                                </tr>
+                                                <tr>
+                                                    <td>{$lang.NeedRight}</td>
+                                                    <td>{$api.needRight?'是':'否'}</td>
+                                                </tr>
+                                                </tbody>
+                                            </table>
+                                        </div>
+                                    </div>
+                                    <div class="panel panel-default">
+                                        <div class="panel-heading"><strong>{$lang.Headers}</strong></div>
+                                        <div class="panel-body">
+                                            {if $api.headersList}
+                                            <table class="table table-hover">
+                                                <thead>
+                                                    <tr>
+                                                        <th>{$lang.Name}</th>
+                                                        <th>{$lang.Type}</th>
+                                                        <th>{$lang.Required}</th>
+                                                        <th>{$lang.Description}</th>
+                                                    </tr>
+                                                </thead>
+                                                <tbody>
+                                                    {foreach name="api['headersList']" id="header"}
+                                                    <tr>
+                                                        <td>{$header.name}</td>
+                                                        <td>{$header.type}</td>
+                                                        <td>{$header.required?'是':'否'}</td>
+                                                        <td>{$header.description}</td>
+                                                    </tr>
+                                                    {/foreach}
+                                                </tbody>
+                                            </table>
+                                            {else /}
+                                            无
+                                            {/if}
+                                        </div>
+                                    </div>
+                                    <div class="panel panel-default">
+                                        <div class="panel-heading"><strong>{$lang.Parameters}</strong></div>
+                                        <div class="panel-body">
+                                            {if $api.paramsList}
+                                            <table class="table table-hover">
+                                                <thead>
+                                                    <tr>
+                                                        <th>{$lang.Name}</th>
+                                                        <th>{$lang.Type}</th>
+                                                        <th>{$lang.Required}</th>
+                                                        <th>{$lang.Description}</th>
+                                                    </tr>
+                                                </thead>
+                                                <tbody>
+                                                    {foreach name="api['paramsList']" id="param"}
+                                                    <tr>
+                                                        <td>{$param.name}</td>
+                                                        <td>{$param.type}</td>
+                                                        <td>{:$param.required?'是':'否'}</td>
+                                                        <td>{$param.description}</td>
+                                                    </tr>
+                                                    {/foreach}
+                                                </tbody>
+                                            </table>
+                                            {else /}
+                                            无
+                                            {/if}
+                                        </div>
+                                    </div>
+                                    <div class="panel panel-default">
+                                        <div class="panel-heading"><strong>{$lang.Body}</strong></div>
+                                        <div class="panel-body">
+                                            {$api.body|default='无'}
+                                        </div>
+                                    </div>
+                                </div><!-- #info -->
+
+                                <div class="tab-pane" id="sandbox{$api.id}">
+                                    <div class="row">
+                                        <div class="col-md-12">
+                                            {if $api.headersList}
+                                            <div class="panel panel-default">
+                                                <div class="panel-heading"><strong>{$lang.Headers}</strong></div>
+                                                <div class="panel-body">
+                                                    <div class="headers">
+                                                        {foreach name="api['headersList']" id="param"}
+                                                        <div class="form-group">
+                                                            <label class="control-label" for="{$param.name}">{$param.name}</label>
+                                                            <input type="{$param.type}" class="form-control input-sm" id="{$param.name}" {if $param.required}required{/if} placeholder="{$param.description} - Ex: {$param.sample}" name="{$param.name}">
+                                                        </div>
+                                                        {/foreach}
+                                                    </div>
+                                                </div>
+                                            </div>
+                                            {/if}
+                                            <div class="panel panel-default">
+                                                <div class="panel-heading"><strong>{$lang.Parameters}</strong>
+                                                <div class="pull-right">
+                                                    <a href="javascript:" class="btn btn-xs btn-info btn-append">追加</a>
+                                                </div>
+                                                </div>
+                                                <div class="panel-body">
+                                                    <form enctype="application/x-www-form-urlencoded" role="form" action="{$api.route}" method="{$api.method}" name="form{$api.id}" id="form{$api.id}">
+                                                        {if $api.paramsList}
+                                                        {foreach name="api['paramsList']" id="param"}
+                                                        <div class="form-group">
+                                                            <label class="control-label" for="{$param.name}">{$param.name}</label>
+                                                            <input type="{$param.type}" class="form-control input-sm" id="{$param.name}" {if $param.required}required{/if} placeholder="{$param.description}{if $param.sample} - 例: {$param.sample}{/if}" name="{$param.name}">
+                                                        </div>
+                                                        {/foreach}
+                                                        {else /}
+                                                        <div class="form-group">
+                                                            无
+                                                        </div>
+                                                        {/if}
+                                                        <div class="form-group form-group-submit">
+                                                            <button type="submit" class="btn btn-success send" rel="{$api.id}">{$lang.Send}</button>
+                                                            <button type="reset" class="btn btn-info" rel="{$api.id}">{$lang.Reset}</button>
+                                                        </div>
+                                                    </form>
+                                                </div>
+                                            </div>
+                                            <div class="panel panel-default">
+                                                <div class="panel-heading"><strong>{$lang.Response}</strong></div>
+                                                <div class="panel-body">
+                                                    <div class="row">
+                                                        <div class="col-md-12" style="overflow-x:auto">
+                                                            <pre id="response_headers{$api.id}"></pre>
+                                                            <pre id="response{$api.id}"></pre>
+                                                        </div>
+                                                    </div>
+                                                </div>
+                                            </div>
+                                            <div class="panel panel-default">
+                                                <div class="panel-heading"><strong>{$lang.ReturnParameters}</strong></div>
+                                                <div class="panel-body">
+                                                    {if $api.returnParamsList}
+                                                    <table class="table table-hover">
+                                                        <thead>
+                                                            <tr>
+                                                                <th>{$lang.Name}</th>
+                                                                <th>{$lang.Type}</th>
+                                                                <th>{$lang.Description}</th>
+                                                            </tr>
+                                                        </thead>
+                                                        <tbody>
+                                                            {foreach name="api['returnParamsList']" id="param"}
+                                                            <tr>
+                                                                <td>{$param.name}</td>
+                                                                <td>{$param.type}</td>
+                                                                <td>{$param.description}</td>
+                                                            </tr>
+                                                            {/foreach}
+                                                        </tbody>
+                                                    </table>
+                                                    {else /}
+                                                    无
+                                                    {/if}
+                                                </div>
+                                            </div>
+                                        </div>
+                                    </div>
+                                </div><!-- #sandbox -->
+
+                                <div class="tab-pane" id="sample{$api.id}">
+                                    <div class="row">
+                                        <div class="col-md-12">
+                                            <pre id="sample_response{$api.id}">{$api.return|default='无'}</pre>
+                                        </div>
+                                    </div>
+                                </div><!-- #sample -->
+
+                            </div><!-- .tab-content -->
+                        </div>
+                    </div>
+                </div>
+                {/foreach}
+                {/foreach}
+            </div>
+
+            <hr>
+
+            <div class="row mt0 footer">
+                <div class="col-md-6" align="left">
+
+                </div>
+                <div class="col-md-6" align="right">
+                    Generated on {:date('Y-m-d H:i:s')} <a href="./" target="_blank">{$config.sitename}</a>
+                </div>
+            </div>
+
+        </div> <!-- /container -->
+
+        <!-- jQuery -->
+        <script src="https://cdn.staticfile.org/jquery/2.1.4/jquery.min.js"></script>
+
+        <!-- Bootstrap Core JavaScript -->
+        <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
+
+        <script type="text/javascript">
+            function syntaxHighlight(json) {
+                if (typeof json != 'string') {
+                    json = JSON.stringify(json, undefined, 2);
+                }
+                json = json.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
+                return json.replace(/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g, function (match) {
+                    var cls = 'number';
+                    if (/^"/.test(match)) {
+                        if (/:$/.test(match)) {
+                            cls = 'key';
+                        } else {
+                            cls = 'string';
+                        }
+                    } else if (/true|false/.test(match)) {
+                        cls = 'boolean';
+                    } else if (/null/.test(match)) {
+                        cls = 'null';
+                    }
+                    return '<span class="' + cls + '">' + match + '</span>';
+                });
+            }
+
+            function prepareStr(str) {
+                try {
+                    return syntaxHighlight(JSON.stringify(JSON.parse(str.replace(/'/g, '"')), null, 2));
+                } catch (e) {
+                    return str;
+                }
+            }
+            var storage = (function () {
+                var uid = new Date;
+                var storage;
+                var result;
+                try {
+                    (storage = window.localStorage).setItem(uid, uid);
+                    result = storage.getItem(uid) == uid;
+                    storage.removeItem(uid);
+                    return result && storage;
+                } catch (exception) {
+                }
+            }());
+
+            $.fn.serializeObject = function ()
+            {
+                var o = {};
+                var a = this.serializeArray();
+                $.each(a, function () {
+                    if (!this.value) {
+                        return;
+                    }
+                    if (o[this.name] !== undefined) {
+                        if (!o[this.name].push) {
+                            o[this.name] = [o[this.name]];
+                        }
+                        o[this.name].push(this.value || '');
+                    } else {
+                        o[this.name] = this.value || '';
+                    }
+                });
+                return o;
+            };
+
+            $(document).ready(function () {
+
+                if (storage) {
+                    storage.getItem('token') && $('#token').val(storage.getItem('token'));
+                    storage.getItem('apiUrl') && $('#apiUrl').val(storage.getItem('apiUrl'));
+                }
+
+                $('[data-toggle="tooltip"]').tooltip({
+                    placement: 'bottom'
+                });
+
+                $(window).on("resize", function(){
+                    $("#sidebar").css("max-height", $(window).height()-80);
+                });
+
+                $(window).trigger("resize");
+
+                $(document).on("click", "#sidebar .list-group > .list-group-item", function(){
+                    $("#sidebar .list-group > .list-group-item").removeClass("current");
+                    $(this).addClass("current");
+                });
+                $(document).on("click", "#sidebar .child a", function(){
+                    var heading = $("#heading-"+$(this).data("id"));
+                    if(!heading.next().hasClass("in")){
+                        $("a", heading).trigger("click");
+                    }
+                    $("html,body").animate({scrollTop:heading.offset().top-70});
+                });
+
+                $('code[id^=response]').hide();
+
+                $.each($('pre[id^=sample_response],pre[id^=sample_post_body]'), function () {
+                    if ($(this).html() == 'NA') {
+                        return;
+                    }
+                    var str = prepareStr($(this).html());
+                    $(this).html(str);
+                });
+
+                $("[data-toggle=popover]").popover({placement: 'right'});
+
+                $('[data-toggle=popover]').on('shown.bs.popover', function () {
+                    var $sample = $(this).parent().find(".popover-content"),
+                            str = $(this).data('content');
+                    if (typeof str == "undefined" || str === "") {
+                        return;
+                    }
+                    var str = prepareStr(str);
+                    $sample.html('<pre>' + str + '</pre>');
+                });
+
+                $(document).on('click', '#save_data', function (e) {
+                    if (storage) {
+                        storage.setItem('token', $('#token').val());
+                        storage.setItem('apiUrl', $('#apiUrl').val());
+                    } else {
+                        alert('Your browser does not support local storage');
+                    }
+                });
+                $(document).on('click', '.btn-append', function (e) {
+                    $($("#appendtpl").html()).insertBefore($(this).closest(".panel").find(".form-group-submit"));
+                    return false;
+                });
+                $(document).on('click', '.btn-remove', function (e) {
+                    $(this).closest(".form-group").remove();
+                    return false;
+                });
+                $(document).on('keyup', '.input-custom-name', function (e) {
+                    $(this).closest(".row").find(".input-custom-value").attr("name", $(this).val());
+                    return false;
+                });
+
+                $(document).on('click', '.send', function (e) {
+                    e.preventDefault();
+                    var form = $(this).closest('form');
+                    //added /g to get all the matched params instead of only first
+                    var matchedParamsInRoute = $(form).attr('action').match(/[^{]+(?=\})/g);
+                    var theId = $(this).attr('rel');
+                    //keep a copy of action attribute in order to modify the copy
+                    //instead of the initial attribute
+                    var url = $(form).attr('action');
+                    var method = $(form).prop('method').toLowerCase() || 'get';
+
+                    var formData = new FormData();
+
+                    $(form).find('input').each(function (i, input) {
+                        if ($(input).attr('type').toLowerCase() == 'file') {
+                            formData.append($(input).attr('name'), $(input)[0].files[0]);
+                            method = 'post';
+                        } else {
+                            formData.append($(input).attr('name'), $(input).val())
+                        }
+                    });
+
+                    var index, key, value;
+
+                    if (matchedParamsInRoute) {
+                        var params = {};
+                        formData.forEach(function(value, key){
+                            params[key] = value;
+                        });
+                        for (index = 0; index < matchedParamsInRoute.length; ++index) {
+                            try {
+                                key = matchedParamsInRoute[index];
+                                value = params[key];
+                                if (typeof value == "undefined")
+                                    value = "";
+                                url = url.replace("\{" + key + "\}", value);
+                                formData.delete(key);
+                            } catch (err) {
+                                console.log(err);
+                            }
+                        }
+                    }
+
+                    var headers = {};
+
+                    var token = $('#token').val();
+                    if (token.length > 0) {
+                        headers['token'] = token;
+                    }
+
+                    $("#sandbox" + theId + " .headers input[type=text]").each(function () {
+                        val = $(this).val();
+                        if (val.length > 0) {
+                            headers[$(this).prop('name')] = val;
+                        }
+                    });
+
+                    $.ajax({
+                        url: $('#apiUrl').val() + url,
+                        data: method == 'get' ? $(form).serialize() : formData,
+                        type: method,
+                        dataType: 'json',
+                        contentType: false,
+                        processData: false,
+                        headers: headers,
+                        xhrFields: {
+                            withCredentials: true
+                        },
+                        success: function (data, textStatus, xhr) {
+                            if (typeof data === 'object') {
+                                var str = JSON.stringify(data, null, 2);
+                                $('#response' + theId).html(syntaxHighlight(str));
+                            } else {
+                                $('#response' + theId).html(data || '');
+                            }
+                            $('#response_headers' + theId).html('HTTP ' + xhr.status + ' ' + xhr.statusText + '<br/><br/>' + xhr.getAllResponseHeaders());
+                            $('#response' + theId).show();
+                        },
+                        error: function (xhr, textStatus, error) {
+                            try {
+                                var str = JSON.stringify($.parseJSON(xhr.responseText), null, 2);
+                            } catch (e) {
+                                var str = xhr.responseText;
+                            }
+                            $('#response_headers' + theId).html('HTTP ' + xhr.status + ' ' + xhr.statusText + '<br/><br/>' + xhr.getAllResponseHeaders());
+                            $('#response' + theId).html(syntaxHighlight(str));
+                            $('#response' + theId).show();
+                        }
+                    });
+                    return false;
+                });
+            });
+        </script>
+        <script type="text/html" id="appendtpl">
+            <div class="form-group">
+                <label class="control-label">自定义</label>
+                <div class="row">
+                    <div class="col-xs-4">
+                        <input type="text" class="form-control input-sm input-custom-name" placeholder="名称">
+                    </div>
+                    <div class="col-xs-6">
+                        <input type="text" class="form-control input-sm input-custom-value" placeholder="值">
+                    </div>
+                    <div class="col-xs-2 text-center">
+                        <a href="javascript:" class="btn btn-sm btn-danger btn-remove">删除</a>
+                    </div>
+                </div>
+            </div>
+        </script>
+    </body>
+</html>

+ 1770 - 0
application/admin/command/Crud.php

@@ -0,0 +1,1770 @@
+<?php
+
+namespace app\admin\command;
+
+use fast\Form;
+use think\Config;
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Db;
+use think\Exception;
+use think\exception\ErrorException;
+use think\exception\PDOException;
+use think\Lang;
+use think\Loader;
+
+class Crud extends Command
+{
+    protected $stubList = [];
+
+    protected $internalKeywords = [
+        'abstract',
+        'and',
+        'array',
+        'as',
+        'break',
+        'callable',
+        'case',
+        'catch',
+        'class',
+        'clone',
+        'const',
+        'continue',
+        'declare',
+        'default',
+        'die',
+        'do',
+        'echo',
+        'else',
+        'elseif',
+        'empty',
+        'enddeclare',
+        'endfor',
+        'endforeach',
+        'endif',
+        'endswitch',
+        'endwhile',
+        'eval',
+        'exit',
+        'extends',
+        'final',
+        'for',
+        'foreach',
+        'function',
+        'global',
+        'goto',
+        'if',
+        'implements',
+        'include',
+        'include_once',
+        'instanceof',
+        'insteadof',
+        'interface',
+        'isset',
+        'list',
+        'namespace',
+        'new',
+        'or',
+        'print',
+        'private',
+        'protected',
+        'public',
+        'require',
+        'require_once',
+        'return',
+        'static',
+        'switch',
+        'throw',
+        'trait',
+        'try',
+        'unset',
+        'use',
+        'var',
+        'while',
+        'xor'
+    ];
+
+    /**
+     * 受保护的系统表, crud不会生效
+     */
+    protected $systemTables = [
+        'admin',
+        'admin_log',
+        'auth_group',
+        'auth_group_access',
+        'auth_rule',
+        'attachment',
+        'config',
+        'category',
+        'ems',
+        'sms',
+        'user',
+        'user_group',
+        'user_rule',
+        'user_score_log',
+        'user_token',
+    ];
+
+    /**
+     * Selectpage搜索字段关联
+     */
+    protected $fieldSelectpageMap = [
+        'nickname' => ['user_id', 'user_ids', 'admin_id', 'admin_ids']
+    ];
+
+    /**
+     * Enum类型识别为单选框的结尾字符,默认会识别为单选下拉列表
+     */
+    protected $enumRadioSuffix = ['data', 'state', 'status'];
+
+    /**
+     * Set类型识别为复选框的结尾字符,默认会识别为多选下拉列表
+     */
+    protected $setCheckboxSuffix = ['data', 'state', 'status'];
+
+    /**
+     * Int类型识别为日期时间的结尾字符,默认会识别为日期文本框
+     */
+    protected $intDateSuffix = ['time'];
+
+    /**
+     * 开关后缀
+     */
+    protected $switchSuffix = ['switch'];
+
+    /**
+     * 富文本后缀
+     */
+    protected $editorSuffix = ['content'];
+
+    /**
+     * 城市后缀
+     */
+    protected $citySuffix = ['city'];
+
+    /**
+     * 时间区间后缀
+     */
+    protected $rangeSuffix = ['range'];
+
+    /**
+     * JSON后缀
+     */
+    protected $jsonSuffix = ['json'];
+
+    /**
+     * 标签后缀
+     */
+    protected $tagSuffix = ['tag', 'tags'];
+
+    /**
+     * Selectpage对应的后缀
+     */
+    protected $selectpageSuffix = ['_id', '_ids'];
+
+    /**
+     * Selectpage多选对应的后缀
+     */
+    protected $selectpagesSuffix = ['_ids'];
+
+    /**
+     * 以指定字符结尾的字段格式化函数
+     */
+    protected $fieldFormatterSuffix = [
+        'status' => ['type' => ['varchar', 'enum'], 'name' => 'status'],
+        'icon'   => 'icon',
+        'flag'   => 'flag',
+        'url'    => 'url',
+        'image'  => 'image',
+        'images' => 'images',
+        'file'   => 'file',
+        'files'  => 'files',
+        'avatar' => 'image',
+        'switch' => 'toggle',
+        'tag'    => 'flag',
+        'tags'   => 'flag',
+        'time'   => ['type' => ['int', 'timestamp'], 'name' => 'datetime'],
+    ];
+
+    /**
+     * 识别为图片字段
+     */
+    protected $imageField = ['image', 'images', 'avatar', 'avatars'];
+
+    /**
+     * 识别为文件字段
+     */
+    protected $fileField = ['file', 'files'];
+
+    /**
+     * 保留字段
+     */
+    protected $reservedField = ['admin_id'];
+
+    /**
+     * 排除字段
+     */
+    protected $ignoreFields = [];
+
+    /**
+     * 排序字段
+     */
+    protected $sortField = 'weigh';
+
+    /**
+     * 筛选字段
+     * @var string
+     */
+    protected $headingFilterField = 'status';
+
+    /**
+     * 添加时间字段
+     * @var string
+     */
+    protected $createTimeField = 'createtime';
+
+    /**
+     * 更新时间字段
+     * @var string
+     */
+    protected $updateTimeField = 'updatetime';
+
+    /**
+     * 软删除时间字段
+     * @var string
+     */
+    protected $deleteTimeField = 'deletetime';
+
+    /**
+     * 编辑器的Class
+     */
+    protected $editorClass = 'editor';
+
+    /**
+     * langList的key最长字节数
+     */
+    protected $fieldMaxLen = 0;
+
+    protected function configure()
+    {
+        $this
+            ->setName('crud')
+            ->addOption('table', 't', Option::VALUE_REQUIRED, 'table name without prefix', null)
+            ->addOption('controller', 'c', Option::VALUE_OPTIONAL, 'controller name', null)
+            ->addOption('model', 'm', Option::VALUE_OPTIONAL, 'model name', null)
+            ->addOption('fields', 'i', Option::VALUE_OPTIONAL, 'model visible fields', null)
+            ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force override or force delete,without tips', null)
+            ->addOption('local', 'l', Option::VALUE_OPTIONAL, 'local model', 1)
+            ->addOption('import', 'a', Option::VALUE_OPTIONAL, 'enable import function', 0)
+            ->addOption('relation', 'r', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation table name without prefix', null)
+            ->addOption('relationmodel', 'e', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation model name', null)
+            ->addOption('relationforeignkey', 'k', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation foreign key', null)
+            ->addOption('relationprimarykey', 'p', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation primary key', null)
+            ->addOption('relationfields', 's', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation table fields', null)
+            ->addOption('relationmode', 'o', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation table mode,hasone/belongsto/hasmany', null)
+            ->addOption('relationcontroller', 'w', Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'relation table controller,only work at hasmany mode', null)
+            ->addOption('delete', 'd', Option::VALUE_OPTIONAL, 'delete all files generated by CRUD', null)
+            ->addOption('menu', 'u', Option::VALUE_OPTIONAL, 'create menu when CRUD completed', null)
+            ->addOption('setcheckboxsuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate checkbox component with suffix', null)
+            ->addOption('enumradiosuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate radio component with suffix', null)
+            ->addOption('imagefield', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate image component with suffix', null)
+            ->addOption('filefield', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate file component with suffix', null)
+            ->addOption('intdatesuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate date component with suffix', null)
+            ->addOption('switchsuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate switch component with suffix', null)
+            ->addOption('citysuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate citypicker component with suffix', null)
+            ->addOption('jsonsuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate fieldlist component with suffix', null)
+            ->addOption('tagsuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate tag component with suffix', null)
+            ->addOption('editorsuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate editor component with suffix', null)
+            ->addOption('selectpagesuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate selectpage component with suffix', null)
+            ->addOption('selectpagessuffix', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'automatically generate multiple selectpage component with suffix', null)
+            ->addOption('ignorefields', null, Option::VALUE_OPTIONAL | Option::VALUE_IS_ARRAY, 'ignore fields', null)
+            ->addOption('sortfield', null, Option::VALUE_OPTIONAL, 'sort field', null)
+            ->addOption('headingfilterfield', null, Option::VALUE_OPTIONAL, 'heading filter field', null)
+            ->addOption('fixedcolumns', null, Option::VALUE_OPTIONAL, 'fixed columns', null)
+            ->addOption('editorclass', null, Option::VALUE_OPTIONAL, 'automatically generate editor class', null)
+            ->addOption('db', null, Option::VALUE_OPTIONAL, 'database config name', 'database')
+            ->setDescription('Build CRUD controller and model from table');
+    }
+
+    protected function execute(Input $input, Output $output)
+    {
+        $adminPath = dirname(__DIR__) . DS;
+        //数据库
+        $db = $input->getOption('db');
+        //表名
+        $table = $input->getOption('table') ?: '';
+        //自定义控制器
+        $controller = $input->getOption('controller');
+        //自定义模型
+        $model = $input->getOption('model');
+        $model = $model ? $model : $controller;
+        //验证器类
+        $validate = $model;
+        //自定义显示字段
+        $fields = $input->getOption('fields');
+        //强制覆盖
+        $force = $input->getOption('force');
+        //是否为本地model,为0时表示为全局model将会把model放在app/common/model中
+        $local = $input->getOption('local');
+        //是否启用导入功能
+        $import = $input->getOption('import');
+
+        if (!$table) {
+            throw new Exception('table name can\'t empty');
+        }
+
+
+        //是否生成菜单
+        $menu = $input->getOption("menu");
+        //关联表
+        $relation = $input->getOption('relation');
+        //自定义关联表模型
+        $relationModels = $input->getOption('relationmodel');
+        //模式
+        $relationMode = $mode = $input->getOption('relationmode');
+        //外键
+        $relationForeignKey = $input->getOption('relationforeignkey');
+        //主键
+        $relationPrimaryKey = $input->getOption('relationprimarykey');
+        //关联表显示字段
+        $relationFields = $input->getOption('relationfields');
+        //关联表显示字段
+        $relationController = $input->getOption('relationcontroller');
+        //复选框后缀
+        $setcheckboxsuffix = $input->getOption('setcheckboxsuffix');
+        //单选框后缀
+        $enumradiosuffix = $input->getOption('enumradiosuffix');
+        //图片后缀
+        $imagefield = $input->getOption('imagefield');
+        //文件后缀
+        $filefield = $input->getOption('filefield');
+        //标签后缀
+        $tagsuffix = $input->getOption('tagsuffix');
+        //日期后缀
+        $intdatesuffix = $input->getOption('intdatesuffix');
+        //开关后缀
+        $switchsuffix = $input->getOption('switchsuffix');
+        //富文本编辑器
+        $editorsuffix = $input->getOption('editorsuffix');
+        //城市后缀
+        $citysuffix = $input->getOption('citysuffix');
+        //JSON配置后缀
+        $jsonsuffix = $input->getOption('jsonsuffix');
+        //selectpage后缀
+        $selectpagesuffix = $input->getOption('selectpagesuffix');
+        //selectpage多选后缀
+        $selectpagessuffix = $input->getOption('selectpagessuffix');
+        //排除字段
+        $ignoreFields = $input->getOption('ignorefields');
+        //排序字段
+        $sortfield = $input->getOption('sortfield');
+        //顶部筛选过滤字段
+        $headingfilterfield = $input->getOption('headingfilterfield');
+        //固定列数量
+        $fixedcolumns = $input->getOption('fixedcolumns');
+        //编辑器Class
+        $editorclass = $input->getOption('editorclass');
+        if ($setcheckboxsuffix) {
+            $this->setCheckboxSuffix = $setcheckboxsuffix;
+        }
+        if ($enumradiosuffix) {
+            $this->enumRadioSuffix = $enumradiosuffix;
+        }
+        if ($imagefield) {
+            $this->imageField = $imagefield;
+        }
+        if ($filefield) {
+            $this->fileField = $filefield;
+        }
+        if ($tagsuffix) {
+            $this->tagSuffix = $tagsuffix;
+        }
+        if ($intdatesuffix) {
+            $this->intDateSuffix = $intdatesuffix;
+        }
+        if ($switchsuffix) {
+            $this->switchSuffix = $switchsuffix;
+        }
+        if ($editorsuffix) {
+            $this->editorSuffix = $editorsuffix;
+        }
+        if ($citysuffix) {
+            $this->citySuffix = $citysuffix;
+        }
+        if ($jsonsuffix) {
+            $this->jsonSuffix = $jsonsuffix;
+        }
+        if ($selectpagesuffix) {
+            $this->selectpageSuffix = $selectpagesuffix;
+        }
+        if ($selectpagessuffix) {
+            $this->selectpagesSuffix = $selectpagessuffix;
+        }
+        if ($ignoreFields) {
+            $this->ignoreFields = $ignoreFields;
+        }
+        if ($editorclass) {
+            $this->editorClass = $editorclass;
+        }
+        if ($sortfield) {
+            $this->sortField = $sortfield;
+        }
+        if ($headingfilterfield) {
+            $this->headingFilterField = $headingfilterfield;
+        }
+
+        $this->reservedField = array_merge($this->reservedField, [$this->createTimeField, $this->updateTimeField, $this->deleteTimeField]);
+
+        $dbconnect = Db::connect($db);
+        $dbname = Config::get($db . '.database');
+        $prefix = Config::get($db . '.prefix');
+
+        //系统表无法生成,防止后台错乱
+        if (in_array(str_replace($prefix, "", $table), $this->systemTables)) {
+            throw new Exception('system table can\'t be crud');
+        }
+
+        //模块
+        $moduleName = 'admin';
+        $modelModuleName = $local ? $moduleName : 'common';
+        $validateModuleName = $local ? $moduleName : 'common';
+
+        //检查主表
+        $modelName = $table = stripos($table, $prefix) === 0 ? substr($table, strlen($prefix)) : $table;
+        $modelTableType = 'table';
+        $modelTableTypeName = $modelTableName = $modelName;
+        $modelTableInfo = $dbconnect->query("SHOW TABLE STATUS LIKE '{$modelTableName}'", [], true);
+        if (!$modelTableInfo) {
+            $modelTableType = 'name';
+            $modelTableName = $prefix . $modelName;
+            $modelTableInfo = $dbconnect->query("SHOW TABLE STATUS LIKE '{$modelTableName}'", [], true);
+            if (!$modelTableInfo) {
+                throw new Exception("table not found");
+            }
+        }
+        $modelTableInfo = $modelTableInfo[0];
+
+        $relations = [];
+        //检查关联表
+        if ($relation) {
+            $relationArr = $relation;
+            $relations = [];
+
+            foreach ($relationArr as $index => $relationTable) {
+                $relationName = stripos($relationTable, $prefix) === 0 ? substr($relationTable, strlen($prefix)) : $relationTable;
+                $relationTableType = 'table';
+                $relationTableTypeName = $relationTableName = $relationName;
+                $relationTableInfo = $dbconnect->query("SHOW TABLE STATUS LIKE '{$relationTableName}'", [], true);
+                if (!$relationTableInfo) {
+                    $relationTableType = 'name';
+                    $relationTableName = $prefix . $relationName;
+                    $relationTableInfo = $dbconnect->query("SHOW TABLE STATUS LIKE '{$relationTableName}'", [], true);
+                    if (!$relationTableInfo) {
+                        throw new Exception("relation table not found");
+                    }
+                }
+                $relationTableInfo = $relationTableInfo[0];
+                $relationModel = isset($relationModels[$index]) ? $relationModels[$index] : '';
+
+                list($relationNamespace, $relationName, $relationFile) = $this->getModelData($modelModuleName, $relationModel, $relationName);
+
+                $relations[] = [
+                    //关联表基础名
+                    'relationName'          => $relationName,
+                    //关联表类命名空间
+                    'relationNamespace'     => $relationNamespace,
+                    //关联模型名
+                    'relationModel'         => $relationModel,
+                    //关联文件
+                    'relationFile'          => $relationFile,
+                    //关联表名称
+                    'relationTableName'     => $relationTableName,
+                    //关联表信息
+                    'relationTableInfo'     => $relationTableInfo,
+                    //关联模型表类型(name或table)
+                    'relationTableType'     => $relationTableType,
+                    //关联模型表类型名称
+                    'relationTableTypeName' => $relationTableTypeName,
+                    //关联模式
+                    'relationFields'        => isset($relationFields[$index]) ? explode(',', $relationFields[$index]) : [],
+                    //关联模式
+                    'relationMode'          => isset($relationMode[$index]) ? $relationMode[$index] : 'belongsto',
+                    //关联模型控制器
+                    'relationController'    => isset($relationController[$index]) ? $relationController[$index] : '',
+                    //关联表外键
+                    'relationForeignKey'    => isset($relationForeignKey[$index]) ? $relationForeignKey[$index] : '',
+                    //关联表主键
+                    'relationPrimaryKey'    => isset($relationPrimaryKey[$index]) ? $relationPrimaryKey[$index] : '',
+                ];
+            }
+        }
+
+        //根据表名匹配对应的Fontawesome图标
+        $iconPath = ROOT_PATH . str_replace('/', DS, '/public/assets/libs/font-awesome/less/variables.less');
+        $iconName = is_file($iconPath) && stripos(file_get_contents($iconPath), '@fa-var-' . $table . ':') ? 'fa fa-' . $table : 'fa fa-circle-o';
+
+        //控制器
+        list($controllerNamespace, $controllerName, $controllerFile, $controllerArr) = $this->getControllerData($moduleName, $controller, $table);
+        //模型
+        list($modelNamespace, $modelName, $modelFile, $modelArr) = $this->getModelData($modelModuleName, $model, $table);
+        //验证器
+        list($validateNamespace, $validateName, $validateFile, $validateArr) = $this->getValidateData($validateModuleName, $validate, $table);
+
+        //处理基础文件名,取消所有下划线并转换为小写
+        $baseNameArr = $controllerArr;
+        $baseFileName = Loader::parseName(array_pop($baseNameArr), 0);
+        array_push($baseNameArr, $baseFileName);
+        $controllerBaseName = strtolower(implode(DS, $baseNameArr));
+        //$controllerUrl = strtolower(implode('/', $baseNameArr));
+        $controllerUrl = $this->getControllerUrl($moduleName, $baseNameArr);
+
+        //视图文件
+        $viewArr = $controllerArr;
+        $lastValue = array_pop($viewArr);
+        $viewArr[] = Loader::parseName($lastValue, 0);
+        array_unshift($viewArr, 'view');
+        $viewDir = $adminPath . strtolower(implode(DS, $viewArr)) . DS;
+
+        //最终将生成的文件路径
+        $javascriptFile = ROOT_PATH . 'public' . DS . 'assets' . DS . 'js' . DS . 'backend' . DS . $controllerBaseName . '.js';
+        $addFile = $viewDir . 'add.html';
+        $editFile = $viewDir . 'edit.html';
+        $indexFile = $viewDir . 'index.html';
+        $recyclebinFile = $viewDir . 'recyclebin.html';
+        $langFile = $adminPath . 'lang' . DS . Lang::detect() . DS . $controllerBaseName . '.php';
+
+        //是否为删除模式
+        $delete = $input->getOption('delete');
+        if ($delete) {
+            $readyFiles = [$controllerFile, $modelFile, $validateFile, $addFile, $editFile, $indexFile, $recyclebinFile, $langFile, $javascriptFile];
+            foreach ($readyFiles as $k => $v) {
+                $output->warning($v);
+            }
+            if (!$force) {
+                $output->info("Are you sure you want to delete all those files?  Type 'yes' to continue: ");
+                $line = fgets(defined('STDIN') ? STDIN : fopen('php://stdin', 'r'));
+                if (trim($line) != 'yes') {
+                    throw new Exception("Operation is aborted!");
+                }
+            }
+            foreach ($readyFiles as $k => $v) {
+                if (file_exists($v)) {
+                    unlink($v);
+                }
+                //删除空文件夹
+                switch ($v) {
+                    case $modelFile:
+                        $this->removeEmptyBaseDir($v, $modelArr);
+                        break;
+                    case $validateFile:
+                        $this->removeEmptyBaseDir($v, $validateArr);
+                        break;
+                    case $addFile:
+                    case $editFile:
+                    case $indexFile:
+                    case $recyclebinFile:
+                        $this->removeEmptyBaseDir($v, $viewArr);
+                        break;
+                    default:
+                        $this->removeEmptyBaseDir($v, $controllerArr);
+                }
+            }
+
+            //继续删除菜单
+            if ($menu) {
+                exec("php think menu -c {$controllerUrl} -d 1 -f 1");
+            }
+
+            $output->info("Delete Successed");
+            return;
+        }
+
+        //非覆盖模式时如果存在控制器文件则报错
+        if (is_file($controllerFile) && !$force) {
+            throw new Exception("controller already exists!\nIf you need to rebuild again, use the parameter --force=true ");
+        }
+
+        //非覆盖模式时如果存在模型文件则报错
+        if (is_file($modelFile) && !$force) {
+            throw new Exception("model already exists!\nIf you need to rebuild again, use the parameter --force=true ");
+        }
+
+        //非覆盖模式时如果存在验证文件则报错
+        if (is_file($validateFile) && !$force) {
+            throw new Exception("validate already exists!\nIf you need to rebuild again, use the parameter --force=true ");
+        }
+
+        require $adminPath . 'common.php';
+
+        //从数据库中获取表字段信息
+        $sql = "SELECT * FROM `information_schema`.`columns` "
+            . "WHERE TABLE_SCHEMA = ? AND table_name = ? "
+            . "ORDER BY ORDINAL_POSITION";
+        //加载主表的列
+        $columnList = $dbconnect->query($sql, [$dbname, $modelTableName]);
+        $fieldArr = [];
+        foreach ($columnList as $k => $v) {
+            $fieldArr[] = $v['COLUMN_NAME'];
+        }
+
+        // 加载关联表的列
+        foreach ($relations as $index => &$relation) {
+            $relationColumnList = $dbconnect->query($sql, [$dbname, $relation['relationTableName']]);
+
+            $relationFieldList = [];
+            foreach ($relationColumnList as $k => $v) {
+                $relationFieldList[] = $v['COLUMN_NAME'];
+            }
+            if (!$relation['relationPrimaryKey']) {
+                foreach ($relationColumnList as $k => $v) {
+                    if ($v['COLUMN_KEY'] == 'PRI') {
+                        $relation['relationPrimaryKey'] = $v['COLUMN_NAME'];
+                        break;
+                    }
+                }
+            }
+            // 如果主键为空
+            if (!$relation['relationPrimaryKey']) {
+                throw new Exception('Relation Primary key not found!');
+            }
+            // 如果主键不在表字段中
+            if (!in_array($relation['relationPrimaryKey'], $relationFieldList)) {
+                throw new Exception('Relation Primary key not found in table!');
+            }
+            $relation['relationColumnList'] = $relationColumnList;
+            $relation['relationFieldList'] = $relationFieldList;
+        }
+        unset($relation);
+
+        $addList = [];
+        $editList = [];
+        $javascriptList = [];
+        $langList = [];
+        $operateButtonList = [];
+        $field = 'id';
+        $order = 'id';
+        $priDefined = false;
+        $priKeyArr = [];
+        $relationPrimaryKey = '';
+        foreach ($columnList as $k => $v) {
+            if ($v['COLUMN_KEY'] == 'PRI') {
+                $priKeyArr[] = $v['COLUMN_NAME'];
+            }
+        }
+        if (!$priKeyArr) {
+            throw new Exception('Primary key not found!');
+        }
+        if (count($priKeyArr) > 1) {
+            throw new Exception('Multiple primary key not support!');
+        }
+        $priKey = reset($priKeyArr);
+
+        $order = $priKey;
+
+        //如果是关联模型
+        foreach ($relations as $index => &$relation) {
+            if ($relation['relationMode'] == 'hasone') {
+                $relationForeignKey = $relation['relationForeignKey'] ? $relation['relationForeignKey'] : $table . "_id";
+                $relationPrimaryKey = $relation['relationPrimaryKey'] ? $relation['relationPrimaryKey'] : $priKey;
+
+                if (!in_array($relationForeignKey, $relation['relationFieldList'])) {
+                    throw new Exception('relation table [' . $relation['relationTableName'] . '] must be contain field [' . $relationForeignKey . ']');
+                }
+                if (!in_array($relationPrimaryKey, $fieldArr)) {
+                    throw new Exception('table [' . $modelTableName . '] must be contain field [' . $relationPrimaryKey . ']');
+                }
+            } elseif ($relation['relationMode'] == 'belongsto') {
+                $relationForeignKey = $relation['relationForeignKey'] ? $relation['relationForeignKey'] : Loader::parseName($relation['relationName']) . "_id";
+                $relationPrimaryKey = $relation['relationPrimaryKey'] ? $relation['relationPrimaryKey'] : $relation['relationPriKey'];
+                if (!in_array($relationForeignKey, $fieldArr)) {
+                    throw new Exception('table [' . $modelTableName . '] must be contain field [' . $relationForeignKey . ']');
+                }
+                if (!in_array($relationPrimaryKey, $relation['relationFieldList'])) {
+                    throw new Exception('relation table [' . $relation['relationTableName'] . '] must be contain field [' . $relationPrimaryKey . ']');
+                }
+            } elseif ($relation['relationMode'] == 'hasmany') {
+                $relationForeignKey = $relation['relationForeignKey'] ? $relation['relationForeignKey'] : $table . "_id";
+                $relationPrimaryKey = $relation['relationPrimaryKey'] ? $relation['relationPrimaryKey'] : $priKey;
+                if (!in_array($relationForeignKey, $relation['relationFieldList'])) {
+                    throw new Exception('relation table [' . $relation['relationTableName'] . '] must be contain field [' . $relationForeignKey . ']');
+                }
+                if (!in_array($relationPrimaryKey, $fieldArr)) {
+                    throw new Exception('table [' . $modelTableName . '] must be contain field [' . $relationPrimaryKey . ']');
+                }
+                $relation['relationColumnList'] = [];
+                $relation['relationFieldList'] = [];
+            }
+            $relation['relationForeignKey'] = $relationForeignKey;
+            $relation['relationPrimaryKey'] = $relationPrimaryKey;
+            $relation['relationClassName'] = $modelNamespace != $relation['relationNamespace'] ? $relation['relationNamespace'] . '\\' . $relation['relationName'] : $relation['relationName'];
+        }
+        unset($relation);
+
+        try {
+            Form::setEscapeHtml(false);
+            $setAttrArr = [];
+            $getAttrArr = [];
+            $getEnumArr = [];
+            $appendAttrList = [];
+            $controllerAssignList = [];
+            $headingHtml = '{:build_heading()}';
+            $controllerImport = '';
+            $importHtml = '';
+            $recyclebinHtml = '';
+
+            if ($import) {
+                $controllerImport = $this->getReplacedStub('mixins/import', []);
+                $importHtml = '<a href="javascript:;" class="btn btn-danger btn-import {:$auth->check(\'' . $controllerUrl . '/import\')?\'\':\'hide\'}" title="{:__(\'Import\')}" id="btn-import-file" data-url="ajax/upload" data-mimetype="csv,xls,xlsx" data-multiple="false"><i class="fa fa-upload"></i> {:__(\'Import\')}</a>';
+            }
+
+            //循环所有字段,开始构造视图的HTML和JS信息
+            foreach ($columnList as $k => $v) {
+                $field = $v['COLUMN_NAME'];
+                $itemArr = [];
+                // 这里构建Enum和Set类型的列表数据
+                if (in_array($v['DATA_TYPE'], ['enum', 'set', 'tinyint']) || $this->headingFilterField == $field) {
+                    if ($v['DATA_TYPE'] !== 'tinyint') {
+                        $itemArr = substr($v['COLUMN_TYPE'], strlen($v['DATA_TYPE']) + 1, -1);
+                        $itemArr = explode(',', str_replace("'", '', $itemArr));
+                    }
+                    $itemArr = $this->getItemArray($itemArr, $field, $v['COLUMN_COMMENT']);
+                    //如果类型为tinyint且有使用备注数据
+                    if ($itemArr && !in_array($v['DATA_TYPE'], ['enum', 'set'])) {
+                        $v['DATA_TYPE'] = 'enum';
+                    }
+                }
+                // 语言列表
+                if ($v['COLUMN_COMMENT'] != '') {
+                    $langList[] = $this->getLangItem($field, $v['COLUMN_COMMENT']);
+                }
+                $inputType = '';
+                //保留字段不能修改和添加
+                if ($v['COLUMN_KEY'] != 'PRI' && !in_array($field, $this->reservedField) && !in_array($field, $this->ignoreFields)) {
+                    $inputType = $this->getFieldType($v);
+
+                    // 如果是number类型时增加一个步长
+                    $step = $inputType == 'number' && $v['NUMERIC_SCALE'] > 0 ? "0." . str_repeat(0, $v['NUMERIC_SCALE'] - 1) . "1" : 0;
+
+                    $attrArr = ['id' => "c-{$field}"];
+                    $cssClassArr = ['form-control'];
+                    $fieldName = "row[{$field}]";
+                    $defaultValue = $v['COLUMN_DEFAULT'];
+                    $editValue = "{\$row.{$field}|htmlentities}";
+                    // 如果默认值非null,则是一个必选项
+                    if ($v['IS_NULLABLE'] == 'NO') {
+                        $attrArr['data-rule'] = 'required';
+                    }
+
+                    //如果字段类型为无符号型,则设置<input min=0>
+                    if (stripos($v['COLUMN_TYPE'], 'unsigned') !== false) {
+                        $attrArr['min'] = 0;
+                    }
+
+                    if ($inputType == 'select') {
+                        $cssClassArr[] = 'selectpicker';
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        if ($v['DATA_TYPE'] == 'set') {
+                            $attrArr['multiple'] = '';
+                            $fieldName .= "[]";
+                        }
+                        $attrArr['name'] = $fieldName;
+
+                        $this->getEnum($getEnumArr, $controllerAssignList, $field, $itemArr, $v['DATA_TYPE'] == 'set' ? 'multiple' : 'select');
+
+                        $itemArr = $this->getLangArray($itemArr, false);
+                        //添加一个获取器
+                        $this->getAttr($getAttrArr, $field, $v['DATA_TYPE'] == 'set' ? 'multiple' : 'select');
+                        if ($v['DATA_TYPE'] == 'set') {
+                            $this->setAttr($setAttrArr, $field, $inputType);
+                        }
+                        $this->appendAttr($appendAttrList, $field);
+                        $formAddElement = $this->getReplacedStub('html/select', ['field' => $field, 'fieldName' => $fieldName, 'fieldList' => $this->getFieldListName($field), 'attrStr' => Form::attributes($attrArr), 'selectedValue' => $defaultValue]);
+                        $formEditElement = $this->getReplacedStub('html/select', ['field' => $field, 'fieldName' => $fieldName, 'fieldList' => $this->getFieldListName($field), 'attrStr' => Form::attributes($attrArr), 'selectedValue' => "\$row.{$field}"]);
+                    } elseif ($inputType == 'datetime') {
+                        $cssClassArr[] = 'datetimepicker';
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $format = "YYYY-MM-DD HH:mm:ss";
+                        $phpFormat = "Y-m-d H:i:s";
+                        $fieldFunc = '';
+                        switch ($v['DATA_TYPE']) {
+                            case 'year':
+                                $format = "YYYY";
+                                $phpFormat = 'Y';
+                                break;
+                            case 'date':
+                                $format = "YYYY-MM-DD";
+                                $phpFormat = 'Y-m-d';
+                                break;
+                            case 'time':
+                                $format = "HH:mm:ss";
+                                $phpFormat = 'H:i:s';
+                                break;
+                            case 'timestamp':
+                                $fieldFunc = 'datetime';
+                            // no break
+                            case 'datetime':
+                                $format = "YYYY-MM-DD HH:mm:ss";
+                                $phpFormat = 'Y-m-d H:i:s';
+                                break;
+                            default:
+                                $fieldFunc = 'datetime';
+                                $this->getAttr($getAttrArr, $field, $inputType);
+                                $this->setAttr($setAttrArr, $field, $inputType);
+                                $this->appendAttr($appendAttrList, $field);
+                                break;
+                        }
+                        $defaultDateTime = "{:date('{$phpFormat}')}";
+                        $attrArr['data-date-format'] = $format;
+                        $attrArr['data-use-current'] = "true";
+                        $formAddElement = Form::text($fieldName, $defaultDateTime, $attrArr);
+                        $formEditElement = Form::text($fieldName, ($fieldFunc ? "{:\$row.{$field}?{$fieldFunc}(\$row.{$field}):''}" : "{\$row.{$field}{$fieldFunc}}"), $attrArr);
+                    } elseif ($inputType == 'datetimerange') {
+                        $cssClassArr[] = 'datetimerange';
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $attrArr['data-locale'] = '{"format":"YYYY-MM-DD HH:mm:ss"}';
+                        $fieldFunc = '';
+                        $defaultDateTime = "";
+                        $formAddElement = Form::text($fieldName, $defaultDateTime, $attrArr);
+                        $formEditElement = Form::text($fieldName, $editValue, $attrArr);
+                    } elseif ($inputType == 'checkbox' || $inputType == 'radio') {
+                        unset($attrArr['data-rule']);
+                        $fieldName = $inputType == 'checkbox' ? $fieldName .= "[]" : $fieldName;
+                        $attrArr['name'] = "row[{$fieldName}]";
+
+                        $this->getEnum($getEnumArr, $controllerAssignList, $field, $itemArr, $inputType);
+                        $itemArr = $this->getLangArray($itemArr, false);
+                        //添加一个获取器
+                        $this->getAttr($getAttrArr, $field, $inputType);
+                        if ($inputType == 'checkbox') {
+                            $this->setAttr($setAttrArr, $field, $inputType);
+                        }
+                        $this->appendAttr($appendAttrList, $field);
+                        $defaultValue = $inputType == 'radio' && !$defaultValue ? key($itemArr) : $defaultValue;
+
+                        $formAddElement = $this->getReplacedStub('html/' . $inputType, ['field' => $field, 'fieldName' => $fieldName, 'fieldList' => $this->getFieldListName($field), 'attrStr' => Form::attributes($attrArr), 'selectedValue' => $defaultValue]);
+                        $formEditElement = $this->getReplacedStub('html/' . $inputType, ['field' => $field, 'fieldName' => $fieldName, 'fieldList' => $this->getFieldListName($field), 'attrStr' => Form::attributes($attrArr), 'selectedValue' => "\$row.{$field}"]);
+                    } elseif ($inputType == 'textarea' && !$this->isMatchSuffix($field, $this->selectpagesSuffix) && !$this->isMatchSuffix($field, $this->imageField)) {
+                        $cssClassArr[] = $this->isMatchSuffix($field, $this->editorSuffix) ? $this->editorClass : '';
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $attrArr['rows'] = 5;
+                        $formAddElement = Form::textarea($fieldName, $defaultValue, $attrArr);
+                        $formEditElement = Form::textarea($fieldName, $editValue, $attrArr);
+                    } elseif ($inputType == 'switch') {
+                        unset($attrArr['data-rule']);
+                        if ($defaultValue === '1' || $defaultValue === 'Y') {
+                            $yes = $defaultValue;
+                            $no = $defaultValue === '1' ? '0' : 'N';
+                        } else {
+                            $no = $defaultValue;
+                            $yes = $defaultValue === '0' ? '1' : 'Y';
+                        }
+                        if (!$itemArr) {
+                            $itemArr = [$yes => 'Yes', $no => 'No'];
+                        }
+                        $stateNoClass = 'fa-flip-horizontal text-gray';
+                        $formAddElement = $this->getReplacedStub('html/' . $inputType, ['field' => $field, 'fieldName' => $fieldName, 'fieldYes' => $yes, 'fieldNo' => $no, 'attrStr' => Form::attributes($attrArr), 'fieldValue' => $defaultValue, 'fieldSwitchClass' => $defaultValue == $no ? $stateNoClass : '']);
+                        $formEditElement = $this->getReplacedStub('html/' . $inputType, ['field' => $field, 'fieldName' => $fieldName, 'fieldYes' => $yes, 'fieldNo' => $no, 'attrStr' => Form::attributes($attrArr), 'fieldValue' => "{\$row.{$field}}", 'fieldSwitchClass' => "{eq name=\"\$row.{$field}\" value=\"{$no}\"}fa-flip-horizontal text-gray{/eq}"]);
+                    } elseif ($inputType == 'citypicker') {
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $attrArr['data-toggle'] = "city-picker";
+                        $formAddElement = sprintf("<div class='control-relative'>%s</div>", Form::input('text', $fieldName, $defaultValue, $attrArr));
+                        $formEditElement = sprintf("<div class='control-relative'>%s</div>", Form::input('text', $fieldName, $editValue, $attrArr));
+                    } elseif ($inputType == 'tagsinput') {
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $attrArr['data-role'] = "tagsinput";
+                        $formAddElement = Form::input('text', $fieldName, $defaultValue, $attrArr);
+                        $formEditElement = Form::input('text', $fieldName, $editValue, $attrArr);
+                    } elseif ($inputType == 'fieldlist') {
+                        $itemArr = $this->getItemArray($itemArr, $field, $v['COLUMN_COMMENT']);
+                        $templateName = !isset($itemArr['key']) && !isset($itemArr['value']) && count($itemArr) > 0 ? 'fieldlist-template' : 'fieldlist';
+                        $itemKey = isset($itemArr['key']) ? ucfirst($itemArr['key']) : 'Key';
+                        $itemValue = isset($itemArr['value']) ? ucfirst($itemArr['value']) : 'Value';
+                        $theadListArr = $tbodyListArr = [];
+                        foreach ($itemArr as $index => $item) {
+                            $theadListArr[] = "<td>{:__('" . $item . "')}</td>";
+                            $tbodyListArr[] = '<td><input type="text" name="<%=name%>[<%=index%>][' . $index . ']" class="form-control" value="<%=row.' . $index . '%>"/></td>';
+                        }
+                        $colspan = count($theadListArr) + 1;
+                        $commonFields = ['field' => $field, 'fieldName' => $fieldName, 'itemKey' => $itemKey, 'itemValue' => $itemValue, 'theadList' => implode("\n", $theadListArr), 'tbodyList' => implode("\n", $tbodyListArr), 'colspan' => $colspan];
+                        $formAddElement = $this->getReplacedStub('html/' . $templateName, array_merge($commonFields, ['fieldValue' => $defaultValue]));
+                        $formEditElement = $this->getReplacedStub('html/' . $templateName, array_merge($commonFields, ['fieldValue' => $editValue]));
+                    } else {
+                        $search = $replace = '';
+                        //特殊字段为关联搜索
+                        if ($this->isMatchSuffix($field, $this->selectpageSuffix)) {
+                            $inputType = 'text';
+                            $defaultValue = '';
+                            $attrArr['data-rule'] = 'required';
+                            $cssClassArr[] = 'selectpage';
+                            $selectpageTable = substr($field, 0, strripos($field, '_'));
+                            $selectpageField = '';
+                            $selectpageController = str_replace('_', '/', $selectpageTable);
+                            $attrArr['data-source'] = $selectpageController . "/index";
+                            //如果是类型表需要特殊处理下
+                            if ($selectpageController == 'category') {
+                                $attrArr['data-source'] = 'category/selectpage';
+                                $attrArr['data-params'] = '##replacetext##';
+                                $search = '"##replacetext##"';
+                                $replace = '\'{"custom[type]":"' . $table . '"}\'';
+                            } elseif ($selectpageController == 'admin') {
+                                $attrArr['data-source'] = 'auth/admin/selectpage';
+                            } elseif ($selectpageController == 'user') {
+                                $attrArr['data-source'] = 'user/user/index';
+                                $attrArr['data-field'] = 'nickname';
+                            }
+                            if ($this->isMatchSuffix($field, $this->selectpagesSuffix)) {
+                                $attrArr['data-multiple'] = 'true';
+                            }
+
+                            $tableInfo = null;
+                            try {
+                                $tableInfo = \think\Db::name($selectpageTable)->getTableInfo();
+                                if (isset($tableInfo['fields'])) {
+                                    foreach ($tableInfo['fields'] as $m => $n) {
+                                        if (in_array($n, ['nickname', 'title', 'name'])) {
+                                            $selectpageField = $n;
+                                            break;
+                                        }
+                                    }
+                                }
+                            } catch (\Exception $e) {
+
+                            }
+                            if (!$selectpageField) {
+                                foreach ($this->fieldSelectpageMap as $m => $n) {
+                                    if (in_array($field, $n)) {
+                                        $attrArr['data-field'] = $m;
+                                        break;
+                                    }
+                                }
+                            }
+                        }
+                        //因为有自动完成可输入其它内容
+                        $step = array_intersect($cssClassArr, ['selectpage']) ? 0 : $step;
+                        $attrArr['class'] = implode(' ', $cssClassArr);
+                        $isUpload = false;
+                        if ($this->isMatchSuffix($field, array_merge($this->imageField, $this->fileField))) {
+                            $isUpload = true;
+                        }
+                        //如果是步长则加上步长
+                        if ($step) {
+                            $attrArr['step'] = $step;
+                        }
+                        //如果是图片加上个size
+                        if ($isUpload) {
+                            $attrArr['size'] = 50;
+                        }
+
+                        $formAddElement = Form::input($inputType, $fieldName, $defaultValue, $attrArr);
+                        $formEditElement = Form::input($inputType, $fieldName, $editValue, $attrArr);
+                        if ($search && $replace) {
+                            $formAddElement = str_replace($search, $replace, $formAddElement);
+                            $formEditElement = str_replace($search, $replace, $formEditElement);
+                        }
+                        //如果是图片或文件
+                        if ($isUpload) {
+                            $formAddElement = $this->getImageUpload($field, $formAddElement);
+                            $formEditElement = $this->getImageUpload($field, $formEditElement);
+                        }
+                    }
+                    //构造添加和编辑HTML信息
+                    $addList[] = $this->getFormGroup($field, $formAddElement);
+                    $editList[] = $this->getFormGroup($field, $formEditElement);
+                }
+
+                //过滤text类型字段
+                if ($v['DATA_TYPE'] != 'text' && $inputType != 'fieldlist') {
+                    //主键
+                    if ($v['COLUMN_KEY'] == 'PRI' && !$priDefined) {
+                        $priDefined = true;
+                        $javascriptList[] = "{checkbox: true}";
+                    }
+                    if ($this->deleteTimeField == $field) {
+                        $recyclebinHtml = $this->getReplacedStub('html/recyclebin-html', ['controllerUrl' => $controllerUrl]);
+                        continue;
+                    }
+                    if (!$fields || in_array($field, explode(',', $fields))) {
+                        //构造JS列信息
+                        $javascriptList[] = $this->getJsColumn($field, $v['DATA_TYPE'], $inputType && in_array($inputType, ['select', 'checkbox', 'radio']) ? '_text' : '', $itemArr);
+                    }
+                    if ($this->headingFilterField && $this->headingFilterField == $field && $itemArr) {
+                        $headingHtml = $this->getReplacedStub('html/heading-html', ['field' => $field, 'fieldName' => Loader::parseName($field, 1, false)]);
+                    }
+                    //排序方式,如果有指定排序字段,否则按主键排序
+                    $order = $field == $this->sortField ? $this->sortField : $order;
+                }
+            }
+
+            //循环关联表,追加语言包和JS列
+            foreach ($relations as $index => $relation) {
+                if ($relation['relationMode'] == 'hasmany') {
+                    $relationFieldText = ucfirst(strtolower($relation['relationName'])) . ' List';
+                    // 语言列表
+                    if ($relation['relationTableInfo']['Comment']) {
+                        $langList[] = $this->getLangItem($relationFieldText, rtrim($relation['relationTableInfo']['Comment'], "表") . "列表");
+                    }
+
+                    $relationTableName = $relation['relationTableName'];
+                    $relationTableName = stripos($relationTableName, $prefix) === 0 ? substr($relationTableName, strlen($prefix)) : $relationTableName;
+
+                    list($realtionControllerNamespace, $realtionControllerName, $realtionControllerFile, $realtionControllerArr) = $this->getControllerData($moduleName, $relation['relationController'], $relationTableName);
+                    $realtionControllerArr = array_map("strtolower", $realtionControllerArr);
+                    if (count($realtionControllerArr) > 1) {
+                        $realtionControllerArr = [implode('.', $realtionControllerArr)];
+                    }
+                    $realtionControllerArr[] = 'index';
+                    $realtionControllerArr[] = $relation['relationForeignKey'] . '/{ids}';
+                    $relationControllerUrl = implode('/', $realtionControllerArr);
+
+                    //构造JS列信息
+                    $operateButtonList[] = "{name: 'addtabs',title: __('{$relationFieldText}'),text: __('{$relationFieldText}'),classname: 'btn btn-xs btn-info btn-dialog',icon: 'fa fa-list',url: '" . $relationControllerUrl . "'}";
+                    //echo "php think crud -t {$relation['relationTableName']} -c {$relation['relationController']} -m {$relation['relationModel']} -i " . implode(',', $relation['relationFields']);
+                    //不存在关联表控制器的情况下才进行生成
+                    if (!is_file($realtionControllerFile)) {
+                        exec("php think crud -t {$relation['relationTableName']} -c {$relation['relationController']} -m {$relation['relationModel']} -i " . implode(',', $relation['relationFields']));
+                    }
+                }
+                foreach ($relation['relationColumnList'] as $k => $v) {
+                    // 不显示的字段直接过滤掉
+                    if ($relation['relationFields'] && !in_array($v['COLUMN_NAME'], $relation['relationFields'])) {
+                        continue;
+                    }
+
+                    $relationField = strtolower($relation['relationName']) . "." . $v['COLUMN_NAME'];
+                    // 语言列表
+                    if ($v['COLUMN_COMMENT'] != '') {
+                        $langList[] = $this->getLangItem($relationField, $v['COLUMN_COMMENT']);
+                    }
+
+                    //过滤text类型字段
+                    if ($v['DATA_TYPE'] != 'text') {
+                        //构造JS列信息
+                        $javascriptList[] = $this->getJsColumn($relationField, $v['DATA_TYPE']);
+                    }
+                }
+            }
+
+            //JS最后一列加上操作列
+            $javascriptList[] = str_repeat(" ", 24) . "{field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, " . ($operateButtonList ? "buttons: [" . implode(',', $operateButtonList) . "], " : "") . "formatter: Table.api.formatter.operate}";
+            $addList = implode("\n", array_filter($addList));
+            $editList = implode("\n", array_filter($editList));
+            $javascriptList = implode(",\n", array_filter($javascriptList));
+            $langList = implode(",\n", array_filter($langList));
+            //数组等号对齐
+            $langList = array_filter(explode(",\n", $langList . ",\n"));
+            foreach ($langList as &$line) {
+                if (preg_match("/^\s+'([^']+)'\s*=>\s*'([^']+)'\s*/is", $line, $matches)) {
+                    $line = "    '{$matches[1]}'" . str_pad('=>', ($this->fieldMaxLen - strlen($matches[1]) + 3), ' ', STR_PAD_LEFT) . " '{$matches[2]}'";
+                }
+            }
+            unset($line);
+            $langList = implode(",\n", array_filter($langList));
+            $fixedcolumns = count($columnList) >= 10 ? 1 : $fixedcolumns;
+
+            $fixedColumnsJs = '';
+            if (is_numeric($fixedcolumns) && $fixedcolumns) {
+                $fixedColumnsJs = "\n" . str_repeat(" ", 16) . "fixedColumns: true,\n" . str_repeat(" ", 16) . ($fixedcolumns < 0 ? "fixedNumber" : "fixedRightNumber") . ": " . $fixedcolumns . ",";
+            }
+
+            //表注释
+            $tableComment = $modelTableInfo['Comment'];
+            $tableComment = mb_substr($tableComment, -1) == '表' ? mb_substr($tableComment, 0, -1) . '管理' : $tableComment;
+
+            $modelInit = '';
+            if ($priKey != $order) {
+                $modelInit = $this->getReplacedStub('mixins' . DS . 'modelinit', ['order' => $order]);
+            }
+
+            $data = [
+                'modelConnection'         => $db == 'database' ? '' : "protected \$connection = '{$db}';",
+                'controllerNamespace'     => $controllerNamespace,
+                'modelNamespace'          => $modelNamespace,
+                'validateNamespace'       => $validateNamespace,
+                'controllerUrl'           => $controllerUrl,
+                'controllerName'          => $controllerName,
+                'controllerAssignList'    => implode("\n", $controllerAssignList),
+                'modelName'               => $modelName,
+                'modelTableName'          => $modelTableName,
+                'modelTableType'          => $modelTableType,
+                'modelTableTypeName'      => $modelTableTypeName,
+                'validateName'            => $validateName,
+                'tableComment'            => $tableComment,
+                'iconName'                => $iconName,
+                'pk'                      => $priKey,
+                'order'                   => $order,
+                'fixedColumnsJs'          => $fixedColumnsJs,
+                'table'                   => $table,
+                'tableName'               => $modelTableName,
+                'addList'                 => $addList,
+                'editList'                => $editList,
+                'javascriptList'          => $javascriptList,
+                'langList'                => $langList,
+                'softDeleteClassPath'     => in_array($this->deleteTimeField, $fieldArr) ? "use traits\model\SoftDelete;" : '',
+                'softDelete'              => in_array($this->deleteTimeField, $fieldArr) ? "use SoftDelete;" : '',
+                'modelAutoWriteTimestamp' => in_array($this->createTimeField, $fieldArr) || in_array($this->updateTimeField, $fieldArr) ? "'int'" : 'false',
+                'createTime'              => in_array($this->createTimeField, $fieldArr) ? "'{$this->createTimeField}'" : 'false',
+                'updateTime'              => in_array($this->updateTimeField, $fieldArr) ? "'{$this->updateTimeField}'" : 'false',
+                'deleteTime'              => in_array($this->deleteTimeField, $fieldArr) ? "'{$this->deleteTimeField}'" : 'false',
+                'relationSearch'          => $relations ? 'true' : 'false',
+                'relationWithList'        => '',
+                'relationMethodList'      => '',
+                'controllerImport'        => $controllerImport,
+                'controllerIndex'         => '',
+                'recyclebinJs'            => '',
+                'headingHtml'             => $headingHtml,
+                'importHtml'              => $importHtml,
+                'recyclebinHtml'          => $recyclebinHtml,
+                'visibleFieldList'        => $fields ? "\$row->visible(['" . implode("','", array_filter(in_array($priKey, explode(',', $fields)) ? explode(',', $fields) : explode(',', $priKey . ',' . $fields))) . "']);" : '',
+                'appendAttrList'          => implode(",\n", $appendAttrList),
+                'getEnumList'             => implode("\n\n", $getEnumArr),
+                'getAttrList'             => implode("\n\n", $getAttrArr),
+                'setAttrList'             => implode("\n\n", $setAttrArr),
+                'modelInit'               => $modelInit,
+            ];
+
+            //如果使用关联模型
+            if ($relations) {
+                $relationWithList = $relationMethodList = $relationVisibleFieldList = [];
+                $relationKeyArr = ['hasone' => 'hasOne', 'belongsto' => 'belongsTo', 'hasmany' => 'hasMany'];
+                foreach ($relations as $index => $relation) {
+                    //需要构造关联的方法
+                    $relation['relationMethod'] = strtolower($relation['relationName']);
+
+                    //关联的模式
+                    $relation['relationMode'] = strtolower($relation['relationMode']);
+                    $relation['relationMode'] = array_key_exists($relation['relationMode'], $relationKeyArr) ? $relationKeyArr[$relation['relationMode']] : '';
+
+                    //关联字段
+                    $relation['relationPrimaryKey'] = $relation['relationPrimaryKey'] ? $relation['relationPrimaryKey'] : $priKey;
+
+                    //构造关联模型的方法
+                    $relationMethodList[] = $this->getReplacedStub('mixins' . DS . 'modelrelationmethod' . ($relation['relationMode'] == 'hasMany' ? '-hasmany' : ''), $relation);
+
+                    if ($relation['relationMode'] == 'hasMany') {
+                        continue;
+                    }
+
+                    //预载入的方法
+                    $relationWithList[] = $relation['relationMethod'];
+
+                    unset($relation['relationColumnList'], $relation['relationFieldList'], $relation['relationTableInfo']);
+
+                    //如果设置了显示主表字段,则必须显式将关联表字段显示
+                    if ($fields) {
+                        $relationVisibleFieldList[] = "\$row->visible(['{$relation['relationMethod']}']);";
+                    }
+
+                    //显示的字段
+                    if ($relation['relationFields']) {
+                        $relationVisibleFieldList[] = "\$row->getRelation('" . $relation['relationMethod'] . "')->visible(['" . implode("','", $relation['relationFields']) . "']);";
+                    }
+                }
+
+                $data['relationWithList'] = "->with(['" . implode("','", $relationWithList) . "'])";
+                $data['relationMethodList'] = implode("\n\n", $relationMethodList);
+                $data['relationVisibleFieldList'] = implode("\n\t\t\t\t", $relationVisibleFieldList);
+
+                if ($relationWithList) {
+                    //需要重写index方法
+                    $data['controllerIndex'] = $this->getReplacedStub('controllerindex', $data);
+                }
+            } elseif ($fields) {
+                $data = array_merge($data, ['relationWithList' => '', 'relationMethodList' => '', 'relationVisibleFieldList' => '']);
+                //需要重写index方法
+                $data['controllerIndex'] = $this->getReplacedStub('controllerindex', $data);
+            }
+
+            // 生成控制器文件
+            $this->writeToFile('controller', $data, $controllerFile);
+            // 生成模型文件
+            $this->writeToFile('model', $data, $modelFile);
+
+            if ($relations) {
+                foreach ($relations as $i => $relation) {
+                    $relation['modelNamespace'] = $relation['relationNamespace'];
+                    if (!is_file($relation['relationFile'])) {
+                        // 生成关联模型文件
+                        $this->writeToFile('relationmodel', $relation, $relation['relationFile']);
+                    }
+                }
+            }
+            // 生成验证文件
+            $this->writeToFile('validate', $data, $validateFile);
+            // 生成视图文件
+            $this->writeToFile('add', $data, $addFile);
+            $this->writeToFile('edit', $data, $editFile);
+            $this->writeToFile('index', $data, $indexFile);
+            if ($recyclebinHtml) {
+                $this->writeToFile('recyclebin', $data, $recyclebinFile);
+                $recyclebinTitle = in_array('title', $fieldArr) ? 'title' : (in_array('name', $fieldArr) ? 'name' : '');
+                $recyclebinTitleJs = $recyclebinTitle ? "\n                        {field: '{$recyclebinTitle}', title: __('" . (ucfirst($recyclebinTitle)) . "'), align: 'left'}," : '';
+                $data['recyclebinJs'] = $this->getReplacedStub('mixins/recyclebinjs', ['deleteTimeField' => $this->deleteTimeField, 'recyclebinTitleJs' => $recyclebinTitleJs, 'controllerUrl' => $controllerUrl]);
+            }
+            // 生成JS文件
+            $this->writeToFile('javascript', $data, $javascriptFile);
+            // 生成语言文件
+            $this->writeToFile('lang', $data, $langFile);
+        } catch (ErrorException $e) {
+            throw new Exception("Code: " . $e->getCode() . "\nLine: " . $e->getLine() . "\nMessage: " . $e->getMessage() . "\nFile: " . $e->getFile());
+        }
+
+        //继续生成菜单
+        if ($menu) {
+            exec("php think menu -c {$controllerUrl}");
+        }
+
+        $output->info("Build Successed");
+    }
+
+    protected function getEnum(&$getEnum, &$controllerAssignList, $field, $itemArr = '', $inputType = '')
+    {
+        if (!in_array($inputType, ['datetime', 'select', 'multiple', 'checkbox', 'radio'])) {
+            return;
+        }
+        $fieldList = $this->getFieldListName($field);
+        $methodName = 'get' . ucfirst($fieldList);
+        foreach ($itemArr as $k => &$v) {
+            $v = "__('" . mb_ucfirst($v) . "')";
+        }
+        unset($v);
+        $itemString = $this->getArrayString($itemArr);
+        $getEnum[] = <<<EOD
+    public function {$methodName}()
+    {
+        return [{$itemString}];
+    }
+EOD;
+        $controllerAssignList[] = <<<EOD
+        \$this->view->assign("{$fieldList}", \$this->model->{$methodName}());
+EOD;
+    }
+
+    protected function getAttr(&$getAttr, $field, $inputType = '')
+    {
+        if (!in_array($inputType, ['datetime', 'select', 'multiple', 'checkbox', 'radio'])) {
+            return;
+        }
+        $attrField = ucfirst($this->getCamelizeName($field));
+        $getAttr[] = $this->getReplacedStub("mixins" . DS . $inputType, ['field' => $field, 'methodName' => "get{$attrField}TextAttr", 'listMethodName' => "get{$attrField}List"]);
+    }
+
+    protected function setAttr(&$setAttr, $field, $inputType = '')
+    {
+        if (!in_array($inputType, ['datetime', 'checkbox', 'select'])) {
+            return;
+        }
+        $attrField = ucfirst($this->getCamelizeName($field));
+        if ($inputType == 'datetime') {
+            $return = <<<EOD
+return \$value === '' ? null : (\$value && !is_numeric(\$value) ? strtotime(\$value) : \$value);
+EOD;
+        } elseif (in_array($inputType, ['checkbox', 'select'])) {
+            $return = <<<EOD
+return is_array(\$value) ? implode(',', \$value) : \$value;
+EOD;
+        }
+        $setAttr[] = <<<EOD
+    protected function set{$attrField}Attr(\$value)
+    {
+        $return
+    }
+EOD;
+    }
+
+    protected function appendAttr(&$appendAttrList, $field)
+    {
+        $appendAttrList[] = <<<EOD
+        '{$field}_text'
+EOD;
+    }
+
+    /**
+     * 移除相对的空目录
+     * @param $parseFile
+     * @param $parseArr
+     * @return bool
+     */
+    protected function removeEmptyBaseDir($parseFile, $parseArr)
+    {
+        if (count($parseArr) > 1) {
+            $parentDir = dirname($parseFile);
+            for ($i = 0; $i < count($parseArr); $i++) {
+                try {
+                    $iterator = new \FilesystemIterator($parentDir);
+                    $isDirEmpty = !$iterator->valid();
+                    if ($isDirEmpty) {
+                        rmdir($parentDir);
+                        $parentDir = dirname($parentDir);
+                    } else {
+                        return true;
+                    }
+                } catch (\UnexpectedValueException $e) {
+                    return false;
+                }
+            }
+        }
+        return true;
+    }
+
+    /**
+     * 获取控制器URL
+     * @param string $moduleName
+     * @param array  $baseNameArr
+     * @return string
+     */
+    protected function getControllerUrl($moduleName, $baseNameArr)
+    {
+        for ($i = 0; $i < count($baseNameArr) - 1; $i++) {
+            $temp = array_slice($baseNameArr, 0, $i + 1);
+            $temp[$i] = ucfirst($temp[$i]);
+            $controllerFile = APP_PATH . $moduleName . DS . 'controller' . DS . implode(DS, $temp) . '.php';
+            //检测父级目录同名控制器是否存在,存在则变更URL格式
+            if (is_file($controllerFile)) {
+                $baseNameArr = [implode('.', $baseNameArr)];
+                break;
+            }
+        }
+        $controllerUrl = strtolower(implode('/', $baseNameArr));
+        return $controllerUrl;
+    }
+
+    /**
+     * 获取控制器相关信息
+     * @param $module
+     * @param $controller
+     * @param $table
+     * @return array
+     */
+    protected function getControllerData($module, $controller, $table)
+    {
+        return $this->getParseNameData($module, $controller, $table, 'controller');
+    }
+
+    /**
+     * 获取模型相关信息
+     * @param $module
+     * @param $model
+     * @param $table
+     * @return array
+     */
+    protected function getModelData($module, $model, $table)
+    {
+        return $this->getParseNameData($module, $model, $table, 'model');
+    }
+
+    /**
+     * 获取验证器相关信息
+     * @param $module
+     * @param $validate
+     * @param $table
+     * @return array
+     */
+    protected function getValidateData($module, $validate, $table)
+    {
+        return $this->getParseNameData($module, $validate, $table, 'validate');
+    }
+
+    /**
+     * 获取已解析相关信息
+     * @param string $module 模块名称
+     * @param string $name   自定义名称
+     * @param string $table  数据表名
+     * @param string $type   解析类型,本例中为controller、model、validate
+     * @return array
+     */
+    protected function getParseNameData($module, $name, $table, $type)
+    {
+        $arr = [];
+        if (!$name) {
+            $parseName = Loader::parseName($table, 1);
+            $name = str_replace('_', '/', $table);
+        }
+
+        $name = str_replace(['.', '/', '\\'], '/', $name);
+        $arr = explode('/', $name);
+        $parseName = ucfirst(array_pop($arr));
+        $parseArr = $arr;
+        array_push($parseArr, $parseName);
+        //类名不能为内部关键字
+        if (in_array(strtolower($parseName), $this->internalKeywords)) {
+            throw new Exception('Unable to use internal variable:' . $parseName);
+        }
+        $appNamespace = Config::get('app_namespace');
+        $parseNamespace = "{$appNamespace}\\{$module}\\{$type}" . ($arr ? "\\" . implode("\\", $arr) : "");
+        $moduleDir = APP_PATH . $module . DS;
+        $parseFile = $moduleDir . $type . DS . ($arr ? implode(DS, $arr) . DS : '') . $parseName . '.php';
+        return [$parseNamespace, $parseName, $parseFile, $parseArr];
+    }
+
+    /**
+     * 写入到文件
+     * @param string $name
+     * @param array  $data
+     * @param string $pathname
+     * @return mixed
+     */
+    protected function writeToFile($name, $data, $pathname)
+    {
+        foreach ($data as $index => &$datum) {
+            $datum = is_array($datum) ? '' : $datum;
+        }
+        unset($datum);
+        $content = $this->getReplacedStub($name, $data);
+
+        if (!is_dir(dirname($pathname))) {
+            mkdir(dirname($pathname), 0755, true);
+        }
+        return file_put_contents($pathname, $content);
+    }
+
+    /**
+     * 获取替换后的数据
+     * @param string $name
+     * @param array  $data
+     * @return string
+     */
+    protected function getReplacedStub($name, $data)
+    {
+        foreach ($data as $index => &$datum) {
+            $datum = is_array($datum) ? '' : $datum;
+        }
+        unset($datum);
+        $search = $replace = [];
+        foreach ($data as $k => $v) {
+            $search[] = "{%{$k}%}";
+            $replace[] = $v;
+        }
+        $stubname = $this->getStub($name);
+        if (isset($this->stubList[$stubname])) {
+            $stub = $this->stubList[$stubname];
+        } else {
+            $this->stubList[$stubname] = $stub = file_get_contents($stubname);
+        }
+        $content = str_replace($search, $replace, $stub);
+        return $content;
+    }
+
+    /**
+     * 获取基础模板
+     * @param string $name
+     * @return string
+     */
+    protected function getStub($name)
+    {
+        return __DIR__ . DS . 'Crud' . DS . 'stubs' . DS . $name . '.stub';
+    }
+
+    protected function getLangItem($field, $content)
+    {
+        if ($content || !Lang::has($field)) {
+            $this->fieldMaxLen = strlen($field) > $this->fieldMaxLen ? strlen($field) : $this->fieldMaxLen;
+            $content = str_replace(',', ',', $content);
+            if (stripos($content, ':') !== false && stripos($content, ',') && stripos($content, '=') !== false) {
+                list($fieldLang, $item) = explode(':', $content);
+                $itemArr = [$field => $fieldLang];
+                foreach (explode(',', $item) as $k => $v) {
+                    $valArr = explode('=', $v);
+                    if (count($valArr) == 2) {
+                        list($key, $value) = $valArr;
+                        $itemArr[$field . ' ' . $key] = $value;
+                        $this->fieldMaxLen = strlen($field . ' ' . $key) > $this->fieldMaxLen ? strlen($field . ' ' . $key) : $this->fieldMaxLen;
+                    }
+                }
+            } else {
+                $itemArr = [$field => $content];
+            }
+            $resultArr = [];
+            foreach ($itemArr as $k => $v) {
+                $resultArr[] = "    '" . mb_ucfirst($k) . "' => '{$v}'";
+            }
+            return implode(",\n", $resultArr);
+        } else {
+            return '';
+        }
+    }
+
+    /**
+     * 读取数据和语言数组列表
+     * @param array   $arr
+     * @param boolean $withTpl
+     * @return array
+     */
+    protected function getLangArray($arr, $withTpl = true)
+    {
+        $langArr = [];
+        foreach ($arr as $k => $v) {
+            $langArr[$k] = is_numeric($k) ? ($withTpl ? "{:" : "") . "__('" . mb_ucfirst($v) . "')" . ($withTpl ? "}" : "") : $v;
+        }
+        return $langArr;
+    }
+
+    /**
+     * 将数据转换成带字符串
+     * @param array $arr
+     * @return string
+     */
+    protected function getArrayString($arr)
+    {
+        if (!is_array($arr)) {
+            return $arr;
+        }
+        $stringArr = [];
+        foreach ($arr as $k => $v) {
+            $is_var = in_array(substr($v, 0, 1), ['$', '_']);
+            if (!$is_var) {
+                $v = str_replace("'", "\'", $v);
+                $k = str_replace("'", "\'", $k);
+            }
+            $stringArr[] = "'" . $k . "' => " . ($is_var ? $v : "'{$v}'");
+        }
+        return implode(", ", $stringArr);
+    }
+
+    protected function getItemArray($item, $field, $comment)
+    {
+        $itemArr = [];
+        $comment = str_replace(',', ',', $comment);
+        if (stripos($comment, ':') !== false && stripos($comment, ',') && stripos($comment, '=') !== false) {
+            list($fieldLang, $item) = explode(':', $comment);
+            $itemArr = [];
+            foreach (explode(',', $item) as $k => $v) {
+                $valArr = explode('=', $v);
+                if (count($valArr) == 2) {
+                    list($key, $value) = $valArr;
+                    $itemArr[$key] = $field . ' ' . $key;
+                }
+            }
+        } else {
+            foreach ($item as $k => $v) {
+                $itemArr[$v] = is_numeric($v) ? $field . ' ' . $v : $v;
+            }
+        }
+        return $itemArr;
+    }
+
+    protected function getFieldType(& $v)
+    {
+        $inputType = 'text';
+        switch ($v['DATA_TYPE']) {
+            case 'bigint':
+            case 'int':
+            case 'mediumint':
+            case 'smallint':
+            case 'tinyint':
+                $inputType = 'number';
+                break;
+            case 'enum':
+            case 'set':
+                $inputType = 'select';
+                break;
+            case 'decimal':
+            case 'double':
+            case 'float':
+                $inputType = 'number';
+                break;
+            case 'longtext':
+            case 'text':
+            case 'mediumtext':
+            case 'smalltext':
+            case 'tinytext':
+                $inputType = 'textarea';
+                break;
+            case 'year':
+            case 'date':
+            case 'time':
+            case 'datetime':
+            case 'timestamp':
+                $inputType = 'datetime';
+                break;
+            default:
+                break;
+        }
+        $fieldsName = $v['COLUMN_NAME'];
+        // 指定后缀说明也是个时间字段
+        if ($this->isMatchSuffix($fieldsName, $this->intDateSuffix)) {
+            $inputType = 'datetime';
+        }
+        // 指定后缀结尾且类型为enum,说明是个单选框
+        if ($this->isMatchSuffix($fieldsName, $this->enumRadioSuffix) && $v['DATA_TYPE'] == 'enum') {
+            $inputType = "radio";
+        }
+        // 指定后缀结尾且类型为set,说明是个复选框
+        if ($this->isMatchSuffix($fieldsName, $this->setCheckboxSuffix) && $v['DATA_TYPE'] == 'set') {
+            $inputType = "checkbox";
+        }
+        // 指定后缀结尾且类型为char或tinyint且长度为1,说明是个Switch复选框
+        if ($this->isMatchSuffix($fieldsName, $this->switchSuffix) && ($v['COLUMN_TYPE'] == 'tinyint(1)' || $v['COLUMN_TYPE'] == 'char(1)') && $v['COLUMN_DEFAULT'] !== '' && $v['COLUMN_DEFAULT'] !== null) {
+            $inputType = "switch";
+        }
+        // 指定后缀结尾城市选择框
+        if ($this->isMatchSuffix($fieldsName, $this->citySuffix) && ($v['DATA_TYPE'] == 'varchar' || $v['DATA_TYPE'] == 'char')) {
+            $inputType = "citypicker";
+        }
+        // 指定后缀结尾城市选择框
+        if ($this->isMatchSuffix($fieldsName, $this->rangeSuffix) && ($v['DATA_TYPE'] == 'varchar' || $v['DATA_TYPE'] == 'char')) {
+            $inputType = "datetimerange";
+        }
+        // 指定后缀结尾JSON配置
+        if ($this->isMatchSuffix($fieldsName, $this->jsonSuffix) && ($v['DATA_TYPE'] == 'varchar' || $v['DATA_TYPE'] == 'text')) {
+            $inputType = "fieldlist";
+        }
+        // 指定后缀结尾标签配置
+        if ($this->isMatchSuffix($fieldsName, $this->tagSuffix) && ($v['DATA_TYPE'] == 'varchar' || $v['DATA_TYPE'] == 'text')) {
+            $inputType = "tagsinput";
+        }
+        return $inputType;
+    }
+
+    /**
+     * 判断是否符合指定后缀
+     * @param string $field     字段名称
+     * @param mixed  $suffixArr 后缀
+     * @return boolean
+     */
+    protected function isMatchSuffix($field, $suffixArr)
+    {
+        $suffixArr = is_array($suffixArr) ? $suffixArr : explode(',', $suffixArr);
+        foreach ($suffixArr as $k => $v) {
+            if (preg_match("/{$v}$/i", $field)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * 获取表单分组数据
+     * @param string $field
+     * @param string $content
+     * @return string
+     */
+    protected function getFormGroup($field, $content)
+    {
+        $langField = mb_ucfirst($field);
+        return <<<EOD
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('{$langField}')}:</label>
+        <div class="col-xs-12 col-sm-8">
+            {$content}
+        </div>
+    </div>
+EOD;
+    }
+
+    /**
+     * 获取图片模板数据
+     * @param string $field
+     * @param string $content
+     * @return string
+     */
+    protected function getImageUpload($field, $content)
+    {
+        $uploadfilter = $selectfilter = '';
+        if ($this->isMatchSuffix($field, $this->imageField)) {
+            $uploadfilter = ' data-mimetype="image/gif,image/jpeg,image/png,image/jpg,image/bmp,image/webp"';
+            $selectfilter = ' data-mimetype="image/*"';
+        }
+        $multiple = substr($field, -1) == 's' ? ' data-multiple="true"' : ' data-multiple="false"';
+        $preview = ' data-preview-id="p-' . $field . '"';
+        $previewcontainer = $preview ? '<ul class="row list-inline faupload-preview" id="p-' . $field . '"></ul>' : '';
+        return <<<EOD
+<div class="input-group">
+                {$content}
+                <div class="input-group-addon no-border no-padding">
+                    <span><button type="button" id="faupload-{$field}" class="btn btn-danger faupload" data-input-id="c-{$field}"{$uploadfilter}{$multiple}{$preview}><i class="fa fa-upload"></i> {:__('Upload')}</button></span>
+                    <span><button type="button" id="fachoose-{$field}" class="btn btn-primary fachoose" data-input-id="c-{$field}"{$selectfilter}{$multiple}><i class="fa fa-list"></i> {:__('Choose')}</button></span>
+                </div>
+                <span class="msg-box n-right" for="c-{$field}"></span>
+            </div>
+            {$previewcontainer}
+EOD;
+    }
+
+    /**
+     * 获取JS列数据
+     * @param string $field
+     * @param string $datatype
+     * @param string $extend
+     * @param array  $itemArr
+     * @return string
+     */
+    protected function getJsColumn($field, $datatype = '', $extend = '', $itemArr = [])
+    {
+        $lang = mb_ucfirst($field);
+        $formatter = '';
+        foreach ($this->fieldFormatterSuffix as $k => $v) {
+            if (preg_match("/{$k}$/i", $field)) {
+                if (is_array($v)) {
+                    if (in_array($datatype, $v['type'])) {
+                        $formatter = $v['name'];
+                        break;
+                    }
+                } else {
+                    $formatter = $v;
+                    break;
+                }
+            }
+        }
+        $html = str_repeat(" ", 24) . "{field: '{$field}', title: __('{$lang}')";
+
+        if ($datatype == 'set') {
+            $formatter = 'label';
+        }
+        foreach ($itemArr as $k => &$v) {
+            if (substr($v, 0, 3) !== '__(') {
+                $v = "__('" . mb_ucfirst($v) . "')";
+            }
+        }
+        unset($v);
+        $searchList = json_encode($itemArr, JSON_FORCE_OBJECT | JSON_UNESCAPED_UNICODE);
+        $searchList = str_replace(['":"', '"}', ')","'], ['":', '}', '),"'], $searchList);
+        if ($itemArr) {
+            $html .= ", searchList: " . $searchList;
+        }
+
+        // 文件、图片、权重等字段默认不加入搜索栏,字符串类型默认LIKE
+        $noSearchFiles = ['file$', 'files$', 'image$', 'images$', '^weigh$'];
+        if (preg_match("/" . implode('|', $noSearchFiles) . "/i", $field)) {
+            $html .= ", operate: false";
+        } else if (in_array($datatype, ['varchar'])) {
+            $html .= ", operate: 'LIKE'";
+        }
+
+        if (in_array($datatype, ['date', 'datetime']) || $formatter === 'datetime') {
+            $html .= ", operate:'RANGE', addclass:'datetimerange', autocomplete:false";
+        } elseif (in_array($datatype, ['float', 'double', 'decimal'])) {
+            $html .= ", operate:'BETWEEN'";
+        }
+        if (in_array($datatype, ['set'])) {
+            $html .= ", operate:'FIND_IN_SET'";
+        }
+        if (in_array($formatter, ['image', 'images'])) {
+            $html .= ", events: Table.api.events.image";
+        }
+        if (in_array($formatter, ['toggle'])) {
+            $html .= ", table: table";
+        }
+        if ($itemArr && !$formatter) {
+            $formatter = 'normal';
+        }
+        if ($formatter) {
+            $html .= ", formatter: Table.api.formatter." . $formatter . "}";
+        } else {
+            $html .= "}";
+        }
+        return $html;
+    }
+
+    protected function getCamelizeName($uncamelized_words, $separator = '_')
+    {
+        $uncamelized_words = $separator . str_replace($separator, " ", strtolower($uncamelized_words));
+        return ltrim(str_replace(" ", "", ucwords($uncamelized_words)), $separator);
+    }
+
+    protected function getFieldListName($field)
+    {
+        return $this->getCamelizeName($field) . 'List';
+    }
+}

+ 11 - 0
application/admin/command/Crud/stubs/add.stub

@@ -0,0 +1,11 @@
+<form id="add-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action="">
+
+{%addList%}
+    <div class="form-group layer-footer">
+        <label class="control-label col-xs-12 col-sm-2"></label>
+        <div class="col-xs-12 col-sm-8">
+            <button type="submit" class="btn btn-primary btn-embossed disabled">{:__('OK')}</button>
+            <button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button>
+        </div>
+    </div>
+</form>

+ 37 - 0
application/admin/command/Crud/stubs/controller.stub

@@ -0,0 +1,37 @@
+<?php
+
+namespace {%controllerNamespace%};
+
+use app\common\controller\Backend;
+
+/**
+ * {%tableComment%}
+ *
+ * @icon {%iconName%}
+ */
+class {%controllerName%} extends Backend
+{
+
+    /**
+     * {%modelName%}模型对象
+     * @var \{%modelNamespace%}\{%modelName%}
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \{%modelNamespace%}\{%modelName%};
+{%controllerAssignList%}
+    }
+
+{%controllerImport%}
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+{%controllerIndex%}
+}

+ 34 - 0
application/admin/command/Crud/stubs/controllerindex.stub

@@ -0,0 +1,34 @@
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //当前是否为关联查询
+        $this->relationSearch = {%relationSearch%};
+        //设置过滤方法
+        $this->request->filter(['strip_tags', 'trim']);
+        if ($this->request->isAjax()) {
+            //如果发送的来源是Selectpage,则转发到Selectpage
+            if ($this->request->request('keyField')) {
+                return $this->selectpage();
+            }
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+
+            $list = $this->model
+                    {%relationWithList%}
+                    ->where($where)
+                    ->order($sort, $order)
+                    ->paginate($limit);
+
+            foreach ($list as $row) {
+                {%visibleFieldList%}
+                {%relationVisibleFieldList%}
+            }
+
+            $result = array("total" => $list->total(), "rows" => $list->items());
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }

+ 11 - 0
application/admin/command/Crud/stubs/edit.stub

@@ -0,0 +1,11 @@
+<form id="edit-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action="">
+
+{%editList%}
+    <div class="form-group layer-footer">
+        <label class="control-label col-xs-12 col-sm-2"></label>
+        <div class="col-xs-12 col-sm-8">
+            <button type="submit" class="btn btn-primary btn-embossed disabled">{:__('OK')}</button>
+            <button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button>
+        </div>
+    </div>
+</form>

+ 6 - 0
application/admin/command/Crud/stubs/html/checkbox.stub

@@ -0,0 +1,6 @@
+
+            <div class="checkbox">
+            {foreach name="{%fieldList%}" item="vo"}
+            <label for="{%fieldName%}-{$key}"><input id="{%fieldName%}-{$key}" name="{%fieldName%}" type="checkbox" value="{$key}" {in name="key" value="{%selectedValue%}"}checked{/in} /> {$vo}</label> 
+            {/foreach}
+            </div>

+ 20 - 0
application/admin/command/Crud/stubs/html/fieldlist-template.stub

@@ -0,0 +1,20 @@
+
+            <table class="table fieldlist" data-name="{%fieldName%}" data-template="{%fieldName%}tpl">
+                <tr>
+                    {%theadList%}
+                    <td width="90">{:__('Operate')}</td>
+                </tr>
+                <tr><td colspan="{%colspan%}">
+                <a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a>
+                <textarea name="{%fieldName%}" class="form-control hide" cols="30" rows="5">{%fieldValue%}</textarea>
+                </td></tr>
+            </table>
+            <script type="text/html" id="{%fieldName%}tpl">
+                <tr>
+                    {%tbodyList%}
+                    <td width="90">
+                        <span class="btn btn-sm btn-danger btn-remove"><i class="fa fa-times"></i></span>
+                        <span class="btn btn-sm btn-primary btn-dragsort"><i class="fa fa-arrows"></i></span>
+                    </td>
+                </tr>
+            </script>

+ 10 - 0
application/admin/command/Crud/stubs/html/fieldlist.stub

@@ -0,0 +1,10 @@
+
+            <dl class="fieldlist" data-name="{%fieldName%}">
+                <dd>
+                    <ins>{:__('{%itemKey%}')}</ins>
+                    <ins>{:__('{%itemValue%}')}</ins>
+                </dd>
+                <dd><a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a></dd>
+                <textarea name="{%fieldName%}" class="form-control hide" cols="30" rows="5">{%fieldValue%}</textarea>
+            </dl>
+

+ 10 - 0
application/admin/command/Crud/stubs/html/heading-html.stub

@@ -0,0 +1,10 @@
+
+    <div class="panel-heading">
+        {:build_heading(null,FALSE)}
+        <ul class="nav nav-tabs" data-field="{%field%}">
+            <li class="{:$Think.get.{%field%} === null ? 'active' : ''}"><a href="#t-all" data-value="" data-toggle="tab">{:__('All')}</a></li>
+            {foreach name="{%fieldName%}List" item="vo"}
+            <li class="{:$Think.get.{%field%} === (string)$key ? 'active' : ''}"><a href="#t-{$key}" data-value="{$key}" data-toggle="tab">{$vo}</a></li>
+            {/foreach}
+        </ul>
+    </div>

+ 6 - 0
application/admin/command/Crud/stubs/html/radio.stub

@@ -0,0 +1,6 @@
+
+            <div class="radio">
+            {foreach name="{%fieldList%}" item="vo"}
+            <label for="{%fieldName%}-{$key}"><input id="{%fieldName%}-{$key}" name="{%fieldName%}" type="radio" value="{$key}" {in name="key" value="{%selectedValue%}"}checked{/in} /> {$vo}</label> 
+            {/foreach}
+            </div>

+ 1 - 0
application/admin/command/Crud/stubs/html/recyclebin-html.stub

@@ -0,0 +1 @@
+<a class="btn btn-success btn-recyclebin btn-dialog {:$auth->check('{%controllerUrl%}/recyclebin')?'':'hide'}" href="{%controllerUrl%}/recyclebin" title="{:__('Recycle bin')}"><i class="fa fa-recycle"></i> {:__('Recycle bin')}</a>

+ 6 - 0
application/admin/command/Crud/stubs/html/select.stub

@@ -0,0 +1,6 @@
+            
+            <select {%attrStr%}>
+                {foreach name="{%fieldList%}" item="vo"}
+                    <option value="{$key}" {in name="key" value="{%selectedValue%}"}selected{/in}>{$vo}</option>
+                {/foreach}
+            </select>

+ 5 - 0
application/admin/command/Crud/stubs/html/switch.stub

@@ -0,0 +1,5 @@
+
+            <input {%attrStr%} name="{%fieldName%}" type="hidden" value="{%fieldValue%}">
+            <a href="javascript:;" data-toggle="switcher" class="btn-switcher" data-input-id="c-{%field%}" data-yes="{%fieldYes%}" data-no="{%fieldNo%}" >
+                <i class="fa fa-toggle-on text-success {%fieldSwitchClass%} fa-2x"></i>
+            </a>

+ 35 - 0
application/admin/command/Crud/stubs/index.stub

@@ -0,0 +1,35 @@
+<div class="panel panel-default panel-intro">
+    {%headingHtml%}
+
+    <div class="panel-body">
+        <div id="myTabContent" class="tab-content">
+            <div class="tab-pane fade active in" id="one">
+                <div class="widget-body no-padding">
+                    <div id="toolbar" class="toolbar">
+                        <a href="javascript:;" class="btn btn-primary btn-refresh" title="{:__('Refresh')}" ><i class="fa fa-refresh"></i> </a>
+                        <a href="javascript:;" class="btn btn-success btn-add {:$auth->check('{%controllerUrl%}/add')?'':'hide'}" title="{:__('Add')}" ><i class="fa fa-plus"></i> {:__('Add')}</a>
+                        <a href="javascript:;" class="btn btn-success btn-edit btn-disabled disabled {:$auth->check('{%controllerUrl%}/edit')?'':'hide'}" title="{:__('Edit')}" ><i class="fa fa-pencil"></i> {:__('Edit')}</a>
+                        <a href="javascript:;" class="btn btn-danger btn-del btn-disabled disabled {:$auth->check('{%controllerUrl%}/del')?'':'hide'}" title="{:__('Delete')}" ><i class="fa fa-trash"></i> {:__('Delete')}</a>
+                        {%importHtml%}
+
+                        <div class="dropdown btn-group {:$auth->check('{%controllerUrl%}/multi')?'':'hide'}">
+                            <a class="btn btn-primary btn-more dropdown-toggle btn-disabled disabled" data-toggle="dropdown"><i class="fa fa-cog"></i> {:__('More')}</a>
+                            <ul class="dropdown-menu text-left" role="menu">
+                                <li><a class="btn btn-link btn-multi btn-disabled disabled" href="javascript:;" data-params="status=normal"><i class="fa fa-eye"></i> {:__('Set to normal')}</a></li>
+                                <li><a class="btn btn-link btn-multi btn-disabled disabled" href="javascript:;" data-params="status=hidden"><i class="fa fa-eye-slash"></i> {:__('Set to hidden')}</a></li>
+                            </ul>
+                        </div>
+
+                        {%recyclebinHtml%}
+                    </div>
+                    <table id="table" class="table table-striped table-bordered table-hover table-nowrap"
+                           data-operate-edit="{:$auth->check('{%controllerUrl%}/edit')}"
+                           data-operate-del="{:$auth->check('{%controllerUrl%}/del')}"
+                           width="100%">
+                    </table>
+                </div>
+            </div>
+
+        </div>
+    </div>
+</div>

+ 48 - 0
application/admin/command/Crud/stubs/javascript.stub

@@ -0,0 +1,48 @@
+define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
+
+    var Controller = {
+        index: function () {
+            // 初始化表格参数配置
+            Table.api.init({
+                extend: {
+                    index_url: '{%controllerUrl%}/index' + location.search,
+                    add_url: '{%controllerUrl%}/add',
+                    edit_url: '{%controllerUrl%}/edit',
+                    del_url: '{%controllerUrl%}/del',
+                    multi_url: '{%controllerUrl%}/multi',
+                    import_url: '{%controllerUrl%}/import',
+                    table: '{%table%}',
+                }
+            });
+
+            var table = $("#table");
+
+            // 初始化表格
+            table.bootstrapTable({
+                url: $.fn.bootstrapTable.defaults.extend.index_url,
+                pk: '{%pk%}',
+                sortName: '{%order%}',{%fixedColumnsJs%}
+                columns: [
+                    [
+                        {%javascriptList%}
+                    ]
+                ]
+            });
+
+            // 为表格绑定事件
+            Table.api.bindevent(table);
+        },{%recyclebinJs%}
+        add: function () {
+            Controller.api.bindevent();
+        },
+        edit: function () {
+            Controller.api.bindevent();
+        },
+        api: {
+            bindevent: function () {
+                Form.api.bindevent($("form[role=form]"));
+            }
+        }
+    };
+    return Controller;
+});

+ 5 - 0
application/admin/command/Crud/stubs/lang.stub

@@ -0,0 +1,5 @@
+<?php
+
+return [
+{%langList%}
+];

+ 8 - 0
application/admin/command/Crud/stubs/mixins/checkbox.stub

@@ -0,0 +1,8 @@
+
+    public function {%methodName%}($value, $data)
+    {
+        $value = $value ? $value : (isset($data['{%field%}']) ? $data['{%field%}'] : '');
+        $valueArr = explode(',', $value);
+        $list = $this->{%listMethodName%}();
+        return implode(',', array_intersect_key($list, array_flip($valueArr)));
+    }

+ 6 - 0
application/admin/command/Crud/stubs/mixins/datetime.stub

@@ -0,0 +1,6 @@
+
+    public function {%methodName%}($value, $data)
+    {
+        $value = $value ? $value : (isset($data['{%field%}']) ? $data['{%field%}'] : '');
+        return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
+    }

+ 1 - 0
application/admin/command/Crud/stubs/mixins/enum.stub

@@ -0,0 +1 @@
+

+ 4 - 0
application/admin/command/Crud/stubs/mixins/import.stub

@@ -0,0 +1,4 @@
+    public function import()
+    {
+        parent::import();
+    }

+ 8 - 0
application/admin/command/Crud/stubs/mixins/modelinit.stub

@@ -0,0 +1,8 @@
+
+    protected static function init()
+    {
+        self::afterInsert(function ($row) {
+            $pk = $row->getPk();
+            $row->getQuery()->where($pk, $row[$pk])->update(['{%order%}' => $row[$pk]]);
+        });
+    }

+ 5 - 0
application/admin/command/Crud/stubs/mixins/modelrelationmethod-hasmany.stub

@@ -0,0 +1,5 @@
+
+    public function {%relationMethod%}s()
+    {
+        return $this->{%relationMode%}('{%relationClassName%}', '{%relationForeignKey%}', '{%relationPrimaryKey%}');
+    }

+ 5 - 0
application/admin/command/Crud/stubs/mixins/modelrelationmethod.stub

@@ -0,0 +1,5 @@
+
+    public function {%relationMethod%}()
+    {
+        return $this->{%relationMode%}('{%relationClassName%}', '{%relationForeignKey%}', '{%relationPrimaryKey%}', [], 'LEFT')->setEagerlyType(0);
+    }

+ 8 - 0
application/admin/command/Crud/stubs/mixins/multiple.stub

@@ -0,0 +1,8 @@
+
+    public function {%methodName%}($value, $data)
+    {
+        $value = $value ? $value : (isset($data['{%field%}']) ? $data['{%field%}'] : '');
+        $valueArr = explode(',', $value);
+        $list = $this->{%listMethodName%}();
+        return implode(',', array_intersect_key($list, array_flip($valueArr)));
+    }

+ 7 - 0
application/admin/command/Crud/stubs/mixins/radio.stub

@@ -0,0 +1,7 @@
+
+    public function {%methodName%}($value, $data)
+    {
+        $value = $value ? $value : (isset($data['{%field%}']) ? $data['{%field%}'] : '');
+        $list = $this->{%listMethodName%}();
+        return isset($list[$value]) ? $list[$value] : '';
+    }

+ 60 - 0
application/admin/command/Crud/stubs/mixins/recyclebinjs.stub

@@ -0,0 +1,60 @@
+
+        recyclebin: function () {
+            // 初始化表格参数配置
+            Table.api.init({
+                extend: {
+                    'dragsort_url': ''
+                }
+            });
+
+            var table = $("#table");
+
+            // 初始化表格
+            table.bootstrapTable({
+                url: '{%controllerUrl%}/recyclebin' + location.search,
+                pk: 'id',
+                sortName: 'id',
+                columns: [
+                    [
+                        {checkbox: true},
+                        {field: 'id', title: __('Id')},{%recyclebinTitleJs%}
+                        {
+                            field: '{%deleteTimeField%}',
+                            title: __('Deletetime'),
+                            operate: 'RANGE',
+                            addclass: 'datetimerange',
+                            formatter: Table.api.formatter.datetime
+                        },
+                        {
+                            field: 'operate',
+                            width: '130px',
+                            title: __('Operate'),
+                            table: table,
+                            events: Table.api.events.operate,
+                            buttons: [
+                                {
+                                    name: 'Restore',
+                                    text: __('Restore'),
+                                    classname: 'btn btn-xs btn-info btn-ajax btn-restoreit',
+                                    icon: 'fa fa-rotate-left',
+                                    url: '{%controllerUrl%}/restore',
+                                    refresh: true
+                                },
+                                {
+                                    name: 'Destroy',
+                                    text: __('Destroy'),
+                                    classname: 'btn btn-xs btn-danger btn-ajax btn-destroyit',
+                                    icon: 'fa fa-times',
+                                    url: '{%controllerUrl%}/destroy',
+                                    refresh: true
+                                }
+                            ],
+                            formatter: Table.api.formatter.operate
+                        }
+                    ]
+                ]
+            });
+
+            // 为表格绑定事件
+            Table.api.bindevent(table);
+        },

+ 7 - 0
application/admin/command/Crud/stubs/mixins/select.stub

@@ -0,0 +1,7 @@
+
+    public function {%methodName%}($value, $data)
+    {
+        $value = $value ? $value : (isset($data['{%field%}']) ? $data['{%field%}'] : '');
+        $list = $this->{%listMethodName%}();
+        return isset($list[$value]) ? $list[$value] : '';
+    }

+ 40 - 0
application/admin/command/Crud/stubs/model.stub

@@ -0,0 +1,40 @@
+<?php
+
+namespace {%modelNamespace%};
+
+use think\Model;
+{%softDeleteClassPath%}
+
+class {%modelName%} extends Model
+{
+
+    {%softDelete%}
+
+    {%modelConnection%}
+
+    // 表名
+    protected ${%modelTableType%} = '{%modelTableTypeName%}';
+    
+    // 自动写入时间戳字段
+    protected $autoWriteTimestamp = {%modelAutoWriteTimestamp%};
+
+    // 定义时间戳字段名
+    protected $createTime = {%createTime%};
+    protected $updateTime = {%updateTime%};
+    protected $deleteTime = {%deleteTime%};
+
+    // 追加属性
+    protected $append = [
+{%appendAttrList%}
+    ];
+    
+{%modelInit%}
+    
+{%getEnumList%}
+
+{%getAttrList%}
+
+{%setAttrList%}
+
+{%relationMethodList%}
+}

+ 25 - 0
application/admin/command/Crud/stubs/recyclebin.stub

@@ -0,0 +1,25 @@
+<div class="panel panel-default panel-intro">
+    {:build_heading()}
+
+    <div class="panel-body">
+        <div id="myTabContent" class="tab-content">
+            <div class="tab-pane fade active in" id="one">
+                <div class="widget-body no-padding">
+                    <div id="toolbar" class="toolbar">
+                        {:build_toolbar('refresh')}
+                        <a class="btn btn-info btn-multi btn-disabled disabled {:$auth->check('{%controllerUrl%}/restore')?'':'hide'}" href="javascript:;" data-url="{%controllerUrl%}/restore" data-action="restore"><i class="fa fa-rotate-left"></i> {:__('Restore')}</a>
+                        <a class="btn btn-danger btn-multi btn-disabled disabled {:$auth->check('{%controllerUrl%}/destroy')?'':'hide'}" href="javascript:;" data-url="{%controllerUrl%}/destroy" data-action="destroy"><i class="fa fa-times"></i> {:__('Destroy')}</a>
+                        <a class="btn btn-success btn-restoreall {:$auth->check('{%controllerUrl%}/restore')?'':'hide'}" href="javascript:;" data-url="{%controllerUrl%}/restore" title="{:__('Restore all')}"><i class="fa fa-rotate-left"></i> {:__('Restore all')}</a>
+                        <a class="btn btn-danger btn-destroyall {:$auth->check('{%controllerUrl%}/destroy')?'':'hide'}" href="javascript:;" data-url="{%controllerUrl%}/destroy" title="{:__('Destroy all')}"><i class="fa fa-times"></i> {:__('Destroy all')}</a>
+                    </div>
+                    <table id="table" class="table table-striped table-bordered table-hover"
+                           data-operate-restore="{:$auth->check('{%controllerUrl%}/restore')}"
+                           data-operate-destroy="{:$auth->check('{%controllerUrl%}/destroy')}"
+                           width="100%">
+                    </table>
+                </div>
+            </div>
+
+        </div>
+    </div>
+</div>

+ 12 - 0
application/admin/command/Crud/stubs/relationmodel.stub

@@ -0,0 +1,12 @@
+<?php
+
+namespace {%modelNamespace%};
+
+use think\Model;
+
+class {%relationName%} extends Model
+{
+    // 表名
+    protected ${%relationTableType%} = '{%relationTableTypeName%}';
+    
+}

+ 27 - 0
application/admin/command/Crud/stubs/validate.stub

@@ -0,0 +1,27 @@
+<?php
+
+namespace {%validateNamespace%};
+
+use think\Validate;
+
+class {%validateName%} extends Validate
+{
+    /**
+     * 验证规则
+     */
+    protected $rule = [
+    ];
+    /**
+     * 提示消息
+     */
+    protected $message = [
+    ];
+    /**
+     * 验证场景
+     */
+    protected $scene = [
+        'add'  => [],
+        'edit' => [],
+    ];
+    
+}

+ 319 - 0
application/admin/command/Install.php

@@ -0,0 +1,319 @@
+<?php
+
+namespace app\admin\command;
+
+use fast\Random;
+use PDO;
+use think\Config;
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Db;
+use think\Exception;
+use think\Lang;
+use think\Request;
+use think\View;
+
+class Install extends Command
+{
+    protected $model = null;
+    /**
+     * @var \think\View 视图类实例
+     */
+    protected $view;
+
+    /**
+     * @var \think\Request Request 实例
+     */
+    protected $request;
+
+    protected function configure()
+    {
+        $config = Config::get('database');
+        $this
+            ->setName('install')
+            ->addOption('hostname', 'a', Option::VALUE_OPTIONAL, 'mysql hostname', $config['hostname'])
+            ->addOption('hostport', 'o', Option::VALUE_OPTIONAL, 'mysql hostport', $config['hostport'])
+            ->addOption('database', 'd', Option::VALUE_OPTIONAL, 'mysql database', $config['database'])
+            ->addOption('prefix', 'r', Option::VALUE_OPTIONAL, 'table prefix', $config['prefix'])
+            ->addOption('username', 'u', Option::VALUE_OPTIONAL, 'mysql username', $config['username'])
+            ->addOption('password', 'p', Option::VALUE_OPTIONAL, 'mysql password', $config['password'])
+            ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force override', false)
+            ->setDescription('New installation of FastAdmin');
+    }
+
+    /**
+     * 命令行安装
+     */
+    protected function execute(Input $input, Output $output)
+    {
+        define('INSTALL_PATH', APP_PATH . 'admin' . DS . 'command' . DS . 'Install' . DS);
+        // 覆盖安装
+        $force = $input->getOption('force');
+        $hostname = $input->getOption('hostname');
+        $hostport = $input->getOption('hostport');
+        $database = $input->getOption('database');
+        $prefix = $input->getOption('prefix');
+        $username = $input->getOption('username');
+        $password = $input->getOption('password');
+
+        $installLockFile = INSTALL_PATH . "install.lock";
+        if (is_file($installLockFile) && !$force) {
+            throw new Exception("\nFastAdmin already installed!\nIf you need to reinstall again, use the parameter --force=true ");
+        }
+
+        $adminUsername = 'admin';
+        $adminPassword = Random::alnum(10);
+        $adminEmail = 'admin@admin.com';
+        $siteName = __('My Website');
+
+        $adminName = $this->installation($hostname, $hostport, $database, $username, $password, $prefix, $adminUsername, $adminPassword, $adminEmail, $siteName);
+        if ($adminName) {
+            $output->highlight("Admin url:http://www.yoursite.com/{$adminName}");
+        }
+
+        $output->highlight("Admin username:{$adminUsername}");
+        $output->highlight("Admin password:{$adminPassword}");
+
+        \think\Cache::rm('__menu__');
+
+        $output->info("Install Successed!");
+    }
+
+    /**
+     * PC端安装
+     */
+    public function index()
+    {
+        $this->view = View::instance(Config::get('template'), Config::get('view_replace_str'));
+        $this->request = Request::instance();
+
+        define('INSTALL_PATH', APP_PATH . 'admin' . DS . 'command' . DS . 'Install' . DS);
+        $langSet = strtolower($this->request->langset());
+        if (!$langSet || in_array($langSet, ['zh-cn', 'zh-hans-cn'])) {
+            Lang::load(INSTALL_PATH . 'zh-cn.php');
+        }
+
+        $installLockFile = INSTALL_PATH . "install.lock";
+
+        if (is_file($installLockFile)) {
+            echo __('The system has been installed. If you need to reinstall, please remove %s first', 'install.lock');
+            exit;
+        }
+        $output = function ($code, $msg, $url = null, $data = null) {
+            return json(['code' => $code, 'msg' => $msg, 'url' => $url, 'data' => $data]);
+        };
+
+        if ($this->request->isPost()) {
+            $mysqlHostname = $this->request->post('mysqlHostname', '127.0.0.1');
+            $mysqlHostport = $this->request->post('mysqlHostport', '3306');
+            $hostArr = explode(':', $mysqlHostname);
+            if (count($hostArr) > 1) {
+                $mysqlHostname = $hostArr[0];
+                $mysqlHostport = $hostArr[1];
+            }
+            $mysqlUsername = $this->request->post('mysqlUsername', 'root');
+            $mysqlPassword = $this->request->post('mysqlPassword', '');
+            $mysqlDatabase = $this->request->post('mysqlDatabase', '');
+            $mysqlPrefix = $this->request->post('mysqlPrefix', 'fa_');
+            $adminUsername = $this->request->post('adminUsername', 'admin');
+            $adminPassword = $this->request->post('adminPassword', '');
+            $adminPasswordConfirmation = $this->request->post('adminPasswordConfirmation', '');
+            $adminEmail = $this->request->post('adminEmail', 'admin@admin.com');
+            $siteName = $this->request->post('siteName', __('My Website'));
+
+            if ($adminPassword !== $adminPasswordConfirmation) {
+                return $output(0, __('The two passwords you entered did not match'));
+            }
+
+            $adminName = '';
+            try {
+                $adminName = $this->installation($mysqlHostname, $mysqlHostport, $mysqlDatabase, $mysqlUsername, $mysqlPassword, $mysqlPrefix, $adminUsername, $adminPassword, $adminEmail, $siteName);
+            } catch (\PDOException $e) {
+                throw new Exception($e->getMessage());
+            } catch (\Exception $e) {
+                return $output(0, $e->getMessage());
+            }
+            return $output(1, __('Install Successed'), null, ['adminName' => $adminName]);
+        }
+        $errInfo = '';
+        try {
+            $this->checkenv();
+        } catch (\Exception $e) {
+            $errInfo = $e->getMessage();
+        }
+        return $this->view->fetch(INSTALL_PATH . "install.html", ['errInfo' => $errInfo]);
+    }
+
+    /**
+     * 执行安装
+     */
+    protected function installation($mysqlHostname, $mysqlHostport, $mysqlDatabase, $mysqlUsername, $mysqlPassword, $mysqlPrefix, $adminUsername, $adminPassword, $adminEmail = null, $siteName = null)
+    {
+        $this->checkenv();
+
+        if ($mysqlDatabase == '') {
+            throw new Exception(__('Please input correct database'));
+        }
+        if (!preg_match("/^\w{3,12}$/", $adminUsername)) {
+            throw new Exception(__('Please input correct username'));
+        }
+        if (!preg_match("/^[\S]{6,16}$/", $adminPassword)) {
+            throw new Exception(__('Please input correct password'));
+        }
+        $weakPasswordArr = ['123456', '12345678', '123456789', '654321', '111111', '000000', 'password', 'qwerty', 'abc123', '1qaz2wsx'];
+        if (in_array($adminPassword, $weakPasswordArr)) {
+            throw new Exception(__('Password is too weak'));
+        }
+        if ($siteName == '' || preg_match("/fast" . "admin/i", $siteName)) {
+            throw new Exception(__('Please input correct website'));
+        }
+
+        $sql = file_get_contents(INSTALL_PATH . 'fastadmin.sql');
+
+        $sql = str_replace("`fa_", "`{$mysqlPrefix}", $sql);
+
+        // 先尝试能否自动创建数据库
+        $config = Config::get('database');
+        try {
+            $pdo = new PDO("{$config['type']}:host={$mysqlHostname}" . ($mysqlHostport ? ";port={$mysqlHostport}" : ''), $mysqlUsername, $mysqlPassword);
+            $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
+            $pdo->query("CREATE DATABASE IF NOT EXISTS `{$mysqlDatabase}` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;");
+
+            // 连接install命令中指定的数据库
+            $instance = Db::connect([
+                'type'     => "{$config['type']}",
+                'hostname' => "{$mysqlHostname}",
+                'hostport' => "{$mysqlHostport}",
+                'database' => "{$mysqlDatabase}",
+                'username' => "{$mysqlUsername}",
+                'password' => "{$mysqlPassword}",
+                'prefix'   => "{$mysqlPrefix}",
+            ]);
+
+            // 查询一次SQL,判断连接是否正常
+            $instance->execute("SELECT 1");
+
+            // 调用原生PDO对象进行批量查询
+            $instance->getPdo()->exec($sql);
+        } catch (\PDOException $e) {
+            throw new Exception($e->getMessage());
+        }
+        // 后台入口文件
+        $adminFile = ROOT_PATH . 'public' . DS . 'admin.php';
+
+        // 数据库配置文件
+        $dbConfigFile = APP_PATH . 'database.php';
+        $dbConfigText = @file_get_contents($dbConfigFile);
+        $callback = function ($matches) use ($mysqlHostname, $mysqlHostport, $mysqlUsername, $mysqlPassword, $mysqlDatabase, $mysqlPrefix) {
+            $field = "mysql" . ucfirst($matches[1]);
+            $replace = $$field;
+            if ($matches[1] == 'hostport' && $mysqlHostport == 3306) {
+                $replace = '';
+            }
+            return "'{$matches[1]}'{$matches[2]}=>{$matches[3]}Env::get('database.{$matches[1]}', '{$replace}'),";
+        };
+        $dbConfigText = preg_replace_callback("/'(hostname|database|username|password|hostport|prefix)'(\s+)=>(\s+)Env::get\((.*)\)\,/", $callback, $dbConfigText);
+
+        // 检测能否成功写入数据库配置
+        $result = @file_put_contents($dbConfigFile, $dbConfigText);
+        if (!$result) {
+            throw new Exception(__('The current permissions are insufficient to write the file %s', 'application/database.php'));
+        }
+
+        // 设置新的Token随机密钥key
+        $oldTokenKey = config('token.key');
+        $newTokenKey = \fast\Random::alnum(32);
+        $coreConfigFile = CONF_PATH . 'config.php';
+        $coreConfigText = @file_get_contents($coreConfigFile);
+        $coreConfigText = preg_replace("/'key'(\s+)=>(\s+)'{$oldTokenKey}'/", "'key'\$1=>\$2'{$newTokenKey}'", $coreConfigText);
+
+        $result = @file_put_contents($coreConfigFile, $coreConfigText);
+        if (!$result) {
+            throw new Exception(__('The current permissions are insufficient to write the file %s', 'application/config.php'));
+        }
+
+        $avatar = request()->domain() . '/assets/img/avatar.png';
+        // 变更默认管理员密码
+        $adminPassword = $adminPassword ? $adminPassword : Random::alnum(8);
+        $adminEmail = $adminEmail ? $adminEmail : "admin@admin.com";
+        $newSalt = substr(md5(uniqid(true)), 0, 6);
+        $newPassword = md5(md5($adminPassword) . $newSalt);
+        $data = ['username' => $adminUsername, 'email' => $adminEmail, 'avatar' => $avatar, 'password' => $newPassword, 'salt' => $newSalt];
+        $instance->name('admin')->where('username', 'admin')->update($data);
+
+        // 变更前台默认用户的密码,随机生成
+        $newSalt = substr(md5(uniqid(true)), 0, 6);
+        $newPassword = md5(md5(Random::alnum(8)) . $newSalt);
+        $instance->name('user')->where('username', 'admin')->update(['avatar' => $avatar, 'password' => $newPassword, 'salt' => $newSalt]);
+
+        // 修改后台入口
+        $adminName = '';
+        if (is_file($adminFile)) {
+            $adminName = Random::alpha(10) . '.php';
+            rename($adminFile, ROOT_PATH . 'public' . DS . $adminName);
+        }
+
+        //修改站点名称
+        if ($siteName != config('site.name')) {
+            $instance->name('config')->where('name', 'name')->update(['value' => $siteName]);
+            $siteConfigFile = CONF_PATH . 'extra' . DS . 'site.php';
+            $siteConfig = include $siteConfigFile;
+            $configList = $instance->name("config")->select();
+            foreach ($configList as $k => $value) {
+                if (in_array($value['type'], ['selects', 'checkbox', 'images', 'files'])) {
+                    $value['value'] = is_array($value['value']) ? $value['value'] : explode(',', $value['value']);
+                }
+                if ($value['type'] == 'array') {
+                    $value['value'] = (array)json_decode($value['value'], true);
+                }
+                $siteConfig[$value['name']] = $value['value'];
+            }
+            $siteConfig['name'] = $siteName;
+            file_put_contents($siteConfigFile, '<?php' . "\n\nreturn " . var_export_short($siteConfig) . ";\n");
+        }
+
+        $installLockFile = INSTALL_PATH . "install.lock";
+        //检测能否成功写入lock文件
+        $result = @file_put_contents($installLockFile, 1);
+        if (!$result) {
+            throw new Exception(__('The current permissions are insufficient to write the file %s', 'application/admin/command/Install/install.lock'));
+        }
+
+        return $adminName;
+    }
+
+    /**
+     * 检测环境
+     */
+    protected function checkenv()
+    {
+        // 检测目录是否存在
+        $checkDirs = [
+            'thinkphp',
+            'vendor',
+            'public' . DS . 'assets' . DS . 'libs'
+        ];
+
+        //数据库配置文件
+        $dbConfigFile = APP_PATH . 'database.php';
+
+        if (version_compare(PHP_VERSION, '7.1.0', '<')) {
+            throw new Exception(__("The current version %s is too low, please use PHP 7.1 or higher", PHP_VERSION));
+        }
+        if (!extension_loaded("PDO")) {
+            throw new Exception(__("PDO is not currently installed and cannot be installed"));
+        }
+        if (!is_really_writable($dbConfigFile)) {
+            throw new Exception(__('The current permissions are insufficient to write the configuration file application/database.php'));
+        }
+        foreach ($checkDirs as $k => $v) {
+            if (!is_dir(ROOT_PATH . $v)) {
+                throw new Exception(__('Please go to the official website to download the full package or resource package and try to install'));
+                break;
+            }
+        }
+        return true;
+    }
+}

+ 604 - 0
application/admin/command/Install/fastadmin.sql

@@ -0,0 +1,604 @@
+/*
+ FastAdmin Install SQL
+ Date: 2020-06-11 22:11:09
+*/
+
+SET FOREIGN_KEY_CHECKS = 0;
+
+-- ----------------------------
+-- Table structure for fa_admin
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_admin`;
+CREATE TABLE `fa_admin` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `username` varchar(20) DEFAULT '' COMMENT '用户名',
+  `nickname` varchar(50) DEFAULT '' COMMENT '昵称',
+  `password` varchar(32) DEFAULT '' COMMENT '密码',
+  `salt` varchar(30) DEFAULT '' COMMENT '密码盐',
+  `avatar` varchar(255) DEFAULT '' COMMENT '头像',
+  `email` varchar(100) DEFAULT '' COMMENT '电子邮箱',
+  `loginfailure` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '失败次数',
+  `logintime` int(10) DEFAULT NULL COMMENT '登录时间',
+  `loginip` varchar(50) DEFAULT NULL COMMENT '登录IP',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `token` varchar(59) DEFAULT '' COMMENT 'Session标识',
+  `status` varchar(30) NOT NULL DEFAULT 'normal' COMMENT '状态',
+  PRIMARY KEY (`id`),
+  UNIQUE KEY `username` (`username`) USING BTREE
+) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='管理员表';
+
+-- ----------------------------
+-- Records of fa_admin
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_admin` VALUES (1, 'admin', 'Admin', '', '', '/assets/img/avatar.png', 'admin@admin.com', 0, 1491635035, '127.0.0.1',1491635035, 1491635035, '', 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_admin_log
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_admin_log`;
+CREATE TABLE `fa_admin_log` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `admin_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '管理员ID',
+  `username` varchar(30) DEFAULT '' COMMENT '管理员名字',
+  `url` varchar(1500) DEFAULT '' COMMENT '操作页面',
+  `title` varchar(100) DEFAULT '' COMMENT '日志标题',
+  `content` longtext NOT NULL COMMENT '内容',
+  `ip` varchar(50) DEFAULT '' COMMENT 'IP',
+  `useragent` varchar(255) DEFAULT '' COMMENT 'User-Agent',
+  `createtime` int(10) DEFAULT NULL COMMENT '操作时间',
+  PRIMARY KEY (`id`),
+  KEY `name` (`username`)
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='管理员日志表';
+
+-- ----------------------------
+-- Table structure for fa_area
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_area`;
+CREATE TABLE `fa_area` (
+  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `pid` int(10) DEFAULT NULL COMMENT '父id',
+  `shortname` varchar(100) DEFAULT NULL COMMENT '简称',
+  `name` varchar(100) DEFAULT NULL COMMENT '名称',
+  `mergename` varchar(255) DEFAULT NULL COMMENT '全称',
+  `level` tinyint(4) DEFAULT NULL COMMENT '层级:1=省,2=市,3=区/县',
+  `pinyin` varchar(100) DEFAULT NULL COMMENT '拼音',
+  `code` varchar(100) DEFAULT NULL COMMENT '长途区号',
+  `zip` varchar(100) DEFAULT NULL COMMENT '邮编',
+  `first` varchar(50) DEFAULT NULL COMMENT '首字母',
+  `lng` varchar(100) DEFAULT NULL COMMENT '经度',
+  `lat` varchar(100) DEFAULT NULL COMMENT '纬度',
+  PRIMARY KEY (`id`),
+  KEY `pid` (`pid`)
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='地区表';
+
+-- ----------------------------
+-- Table structure for fa_attachment
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_attachment`;
+CREATE TABLE `fa_attachment` (
+  `id` int(20) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `category` varchar(50) DEFAULT '' COMMENT '类别',
+  `admin_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '管理员ID',
+  `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '会员ID',
+  `url` varchar(255) DEFAULT '' COMMENT '物理路径',
+  `imagewidth` varchar(30) DEFAULT '' COMMENT '宽度',
+  `imageheight` varchar(30) DEFAULT '' COMMENT '高度',
+  `imagetype` varchar(30) DEFAULT '' COMMENT '图片类型',
+  `imageframes` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '图片帧数',
+  `filename` varchar(100) DEFAULT '' COMMENT '文件名称',
+  `filesize` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '文件大小',
+  `mimetype` varchar(100) DEFAULT '' COMMENT 'mime类型',
+  `extparam` varchar(255) DEFAULT '' COMMENT '透传数据',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建日期',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `uploadtime` int(10) DEFAULT NULL COMMENT '上传时间',
+  `storage` varchar(100) NOT NULL DEFAULT 'local' COMMENT '存储位置',
+  `sha1` varchar(40) DEFAULT '' COMMENT '文件 sha1编码',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='附件表';
+
+-- ----------------------------
+-- Records of fa_attachment
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_attachment` VALUES (1, '', 1, 0, '/assets/img/qrcode.png', '150', '150', 'png', 0, 'qrcode.png', 21859, 'image/png', '', 1491635035, 1491635035, 1491635035, 'local', '17163603d0263e4838b9387ff2cd4877e8b018f6');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_auth_group
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_auth_group`;
+CREATE TABLE `fa_auth_group` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `pid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父组别',
+  `name` varchar(100) DEFAULT '' COMMENT '组名',
+  `rules` text NOT NULL COMMENT '规则ID',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `status` varchar(30) DEFAULT '' COMMENT '状态',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='分组表';
+
+-- ----------------------------
+-- Records of fa_auth_group
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_auth_group` VALUES (1, 0, 'Admin group', '*', 1491635035, 1491635035, 'normal');
+INSERT INTO `fa_auth_group` VALUES (2, 1, 'Second group', '13,14,16,15,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,40,41,42,43,44,45,46,47,48,49,50,55,56,57,58,59,60,61,62,63,64,65,1,9,10,11,7,6,8,2,4,5', 1491635035, 1491635035, 'normal');
+INSERT INTO `fa_auth_group` VALUES (3, 2, 'Third group', '1,4,9,10,11,13,14,15,16,17,40,41,42,43,44,45,46,47,48,49,50,55,56,57,58,59,60,61,62,63,64,65,5', 1491635035, 1491635035, 'normal');
+INSERT INTO `fa_auth_group` VALUES (4, 1, 'Second group 2', '1,4,13,14,15,16,17,55,56,57,58,59,60,61,62,63,64,65', 1491635035, 1491635035, 'normal');
+INSERT INTO `fa_auth_group` VALUES (5, 2, 'Third group 2', '1,2,6,7,8,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34', 1491635035, 1491635035, 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_auth_group_access
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_auth_group_access`;
+CREATE TABLE `fa_auth_group_access` (
+  `uid` int(10) unsigned NOT NULL COMMENT '会员ID',
+  `group_id` int(10) unsigned NOT NULL COMMENT '级别ID',
+  UNIQUE KEY `uid_group_id` (`uid`,`group_id`),
+  KEY `uid` (`uid`),
+  KEY `group_id` (`group_id`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='权限分组表';
+
+-- ----------------------------
+-- Records of fa_auth_group_access
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_auth_group_access` VALUES (1, 1);
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_auth_rule
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_auth_rule`;
+CREATE TABLE `fa_auth_rule` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `type` enum('menu','file') NOT NULL DEFAULT 'file' COMMENT 'menu为菜单,file为权限节点',
+  `pid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父ID',
+  `name` varchar(100) DEFAULT '' COMMENT '规则名称',
+  `title` varchar(50) DEFAULT '' COMMENT '规则名称',
+  `icon` varchar(50) DEFAULT '' COMMENT '图标',
+  `url` varchar(255) DEFAULT '' COMMENT '规则URL',
+  `condition` varchar(255) DEFAULT '' COMMENT '条件',
+  `remark` varchar(255) DEFAULT '' COMMENT '备注',
+  `ismenu` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否为菜单',
+  `menutype` enum('addtabs','blank','dialog','ajax') DEFAULT NULL COMMENT '菜单类型',
+  `extend` varchar(255) DEFAULT '' COMMENT '扩展属性',
+  `py` varchar(30) DEFAULT '' COMMENT '拼音首字母',
+  `pinyin` varchar(100) DEFAULT '' COMMENT '拼音',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `weigh` int(10) NOT NULL DEFAULT '0' COMMENT '权重',
+  `status` varchar(30) DEFAULT '' COMMENT '状态',
+  PRIMARY KEY (`id`),
+  UNIQUE KEY `name` (`name`) USING BTREE,
+  KEY `pid` (`pid`),
+  KEY `weigh` (`weigh`)
+) ENGINE=InnoDB AUTO_INCREMENT=66 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='节点表';
+
+-- ----------------------------
+-- Records of fa_auth_rule
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_auth_rule` VALUES (1, 'file', 0, 'dashboard', 'Dashboard', 'fa fa-dashboard', '', '', 'Dashboard tips', 1, NULL, '', 'kzt', 'kongzhitai', 1491635035, 1491635035, 143, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (2, 'file', 0, 'general', 'General', 'fa fa-cogs', '', '', '', 1, NULL, '', 'cggl', 'changguiguanli', 1491635035, 1491635035, 137, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (3, 'file', 0, 'category', 'Category', 'fa fa-leaf', '', '', 'Category tips', 0, NULL, '', 'flgl', 'fenleiguanli', 1491635035, 1491635035, 119, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (4, 'file', 0, 'addon', 'Addon', 'fa fa-rocket', '', '', 'Addon tips', 1, NULL, '', 'cjgl', 'chajianguanli', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (5, 'file', 0, 'auth', 'Auth', 'fa fa-group', '', '', '', 1, NULL, '', 'qxgl', 'quanxianguanli', 1491635035, 1491635035, 99, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (6, 'file', 2, 'general/config', 'Config', 'fa fa-cog', '', '', 'Config tips', 1, NULL, '', 'xtpz', 'xitongpeizhi', 1491635035, 1491635035, 60, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (7, 'file', 2, 'general/attachment', 'Attachment', 'fa fa-file-image-o', '', '', 'Attachment tips', 1, NULL, '', 'fjgl', 'fujianguanli', 1491635035, 1491635035, 53, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (8, 'file', 2, 'general/profile', 'Profile', 'fa fa-user', '', '', '', 1, NULL, '', 'grzl', 'gerenziliao', 1491635035, 1491635035, 34, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (9, 'file', 5, 'auth/admin', 'Admin', 'fa fa-user', '', '', 'Admin tips', 1, NULL, '', 'glygl', 'guanliyuanguanli', 1491635035, 1491635035, 118, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (10, 'file', 5, 'auth/adminlog', 'Admin log', 'fa fa-list-alt', '', '', 'Admin log tips', 1, NULL, '', 'glyrz', 'guanliyuanrizhi', 1491635035, 1491635035, 113, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (11, 'file', 5, 'auth/group', 'Group', 'fa fa-group', '', '', 'Group tips', 1, NULL, '', 'jsz', 'juesezu', 1491635035, 1491635035, 109, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (12, 'file', 5, 'auth/rule', 'Rule', 'fa fa-bars', '', '', 'Rule tips', 1, NULL, '', 'cdgz', 'caidanguize', 1491635035, 1491635035, 104, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (13, 'file', 1, 'dashboard/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 136, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (14, 'file', 1, 'dashboard/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 135, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (15, 'file', 1, 'dashboard/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 133, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (16, 'file', 1, 'dashboard/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 134, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (17, 'file', 1, 'dashboard/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 132, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (18, 'file', 6, 'general/config/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 52, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (19, 'file', 6, 'general/config/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 51, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (20, 'file', 6, 'general/config/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 50, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (21, 'file', 6, 'general/config/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 49, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (22, 'file', 6, 'general/config/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 48, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (23, 'file', 7, 'general/attachment/index', 'View', 'fa fa-circle-o', '', '', 'Attachment tips', 0, NULL, '', '', '', 1491635035, 1491635035, 59, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (24, 'file', 7, 'general/attachment/select', 'Select attachment', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 58, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (25, 'file', 7, 'general/attachment/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 57, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (26, 'file', 7, 'general/attachment/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 56, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (27, 'file', 7, 'general/attachment/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 55, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (28, 'file', 7, 'general/attachment/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 54, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (29, 'file', 8, 'general/profile/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 33, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (30, 'file', 8, 'general/profile/update', 'Update profile', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 32, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (31, 'file', 8, 'general/profile/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 31, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (32, 'file', 8, 'general/profile/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 30, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (33, 'file', 8, 'general/profile/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 29, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (34, 'file', 8, 'general/profile/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 28, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (35, 'file', 3, 'category/index', 'View', 'fa fa-circle-o', '', '', 'Category tips', 0, NULL, '', '', '', 1491635035, 1491635035, 142, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (36, 'file', 3, 'category/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 141, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (37, 'file', 3, 'category/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 140, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (38, 'file', 3, 'category/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 139, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (39, 'file', 3, 'category/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 138, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (40, 'file', 9, 'auth/admin/index', 'View', 'fa fa-circle-o', '', '', 'Admin tips', 0, NULL, '', '', '', 1491635035, 1491635035, 117, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (41, 'file', 9, 'auth/admin/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 116, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (42, 'file', 9, 'auth/admin/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 115, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (43, 'file', 9, 'auth/admin/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 114, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (44, 'file', 10, 'auth/adminlog/index', 'View', 'fa fa-circle-o', '', '', 'Admin log tips', 0, NULL, '', '', '', 1491635035, 1491635035, 112, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (45, 'file', 10, 'auth/adminlog/detail', 'Detail', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 111, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (46, 'file', 10, 'auth/adminlog/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 110, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (47, 'file', 11, 'auth/group/index', 'View', 'fa fa-circle-o', '', '', 'Group tips', 0, NULL, '', '', '', 1491635035, 1491635035, 108, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (48, 'file', 11, 'auth/group/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 107, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (49, 'file', 11, 'auth/group/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 106, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (50, 'file', 11, 'auth/group/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 105, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (51, 'file', 12, 'auth/rule/index', 'View', 'fa fa-circle-o', '', '', 'Rule tips', 0, NULL, '', '', '', 1491635035, 1491635035, 103, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (52, 'file', 12, 'auth/rule/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 102, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (53, 'file', 12, 'auth/rule/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 101, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (54, 'file', 12, 'auth/rule/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 100, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (55, 'file', 4, 'addon/index', 'View', 'fa fa-circle-o', '', '', 'Addon tips', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (56, 'file', 4, 'addon/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (57, 'file', 4, 'addon/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (58, 'file', 4, 'addon/del', 'Delete', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (59, 'file', 4, 'addon/downloaded', 'Local addon', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (60, 'file', 4, 'addon/state', 'Update state', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (63, 'file', 4, 'addon/config', 'Setting', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (64, 'file', 4, 'addon/refresh', 'Refresh', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (65, 'file', 4, 'addon/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (66, 'file', 0, 'user', 'User', 'fa fa-user-circle', '', '', '', 1, NULL, '', 'hygl', 'huiyuanguanli', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (67, 'file', 66, 'user/user', 'User', 'fa fa-user', '', '', '', 1, NULL, '', 'hygl', 'huiyuanguanli', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (68, 'file', 67, 'user/user/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (69, 'file', 67, 'user/user/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (70, 'file', 67, 'user/user/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (71, 'file', 67, 'user/user/del', 'Del', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (72, 'file', 67, 'user/user/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (73, 'file', 66, 'user/group', 'User group', 'fa fa-users', '', '', '', 1, NULL, '', 'hyfz', 'huiyuanfenzu', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (74, 'file', 73, 'user/group/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (75, 'file', 73, 'user/group/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (76, 'file', 73, 'user/group/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (77, 'file', 73, 'user/group/del', 'Del', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (78, 'file', 73, 'user/group/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (79, 'file', 66, 'user/rule', 'User rule', 'fa fa-circle-o', '', '', '', 1, NULL, '', 'hygz', 'huiyuanguize', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (80, 'file', 79, 'user/rule/index', 'View', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (81, 'file', 79, 'user/rule/del', 'Del', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (82, 'file', 79, 'user/rule/add', 'Add', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (83, 'file', 79, 'user/rule/edit', 'Edit', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+INSERT INTO `fa_auth_rule` VALUES (84, 'file', 79, 'user/rule/multi', 'Multi', 'fa fa-circle-o', '', '', '', 0, NULL, '', '', '', 1491635035, 1491635035, 0, 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_category
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_category`;
+CREATE TABLE `fa_category` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `pid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父ID',
+  `type` varchar(30) DEFAULT '' COMMENT '栏目类型',
+  `name` varchar(30) DEFAULT '',
+  `nickname` varchar(50) DEFAULT '',
+  `flag` set('hot','index','recommend') DEFAULT '',
+  `image` varchar(100) DEFAULT '' COMMENT '图片',
+  `keywords` varchar(255) DEFAULT '' COMMENT '关键字',
+  `description` varchar(255) DEFAULT '' COMMENT '描述',
+  `diyname` varchar(30) DEFAULT '' COMMENT '自定义名称',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `weigh` int(10) NOT NULL DEFAULT '0' COMMENT '权重',
+  `status` varchar(30) DEFAULT '' COMMENT '状态',
+  PRIMARY KEY (`id`),
+  KEY `weigh` (`weigh`,`id`),
+  KEY `pid` (`pid`)
+) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='分类表';
+
+-- ----------------------------
+-- Records of fa_category
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_category` VALUES (1, 0, 'page', '官方新闻', 'news', 'recommend', '/assets/img/qrcode.png', '', '', 'news', 1491635035, 1491635035, 1, 'normal');
+INSERT INTO `fa_category` VALUES (2, 0, 'page', '移动应用', 'mobileapp', 'hot', '/assets/img/qrcode.png', '', '', 'mobileapp', 1491635035, 1491635035, 2, 'normal');
+INSERT INTO `fa_category` VALUES (3, 2, 'page', '微信公众号', 'wechatpublic', 'index', '/assets/img/qrcode.png', '', '', 'wechatpublic', 1491635035, 1491635035, 3, 'normal');
+INSERT INTO `fa_category` VALUES (4, 2, 'page', 'Android开发', 'android', 'recommend', '/assets/img/qrcode.png', '', '', 'android', 1491635035, 1491635035, 4, 'normal');
+INSERT INTO `fa_category` VALUES (5, 0, 'page', '软件产品', 'software', 'recommend', '/assets/img/qrcode.png', '', '', 'software', 1491635035, 1491635035, 5, 'normal');
+INSERT INTO `fa_category` VALUES (6, 5, 'page', '网站建站', 'website', 'recommend', '/assets/img/qrcode.png', '', '', 'website', 1491635035, 1491635035, 6, 'normal');
+INSERT INTO `fa_category` VALUES (7, 5, 'page', '企业管理软件', 'company', 'index', '/assets/img/qrcode.png', '', '', 'company', 1491635035, 1491635035, 7, 'normal');
+INSERT INTO `fa_category` VALUES (8, 6, 'page', 'PC端', 'website-pc', 'recommend', '/assets/img/qrcode.png', '', '', 'website-pc', 1491635035, 1491635035, 8, 'normal');
+INSERT INTO `fa_category` VALUES (9, 6, 'page', '移动端', 'website-mobile', 'recommend', '/assets/img/qrcode.png', '', '', 'website-mobile', 1491635035, 1491635035, 9, 'normal');
+INSERT INTO `fa_category` VALUES (10, 7, 'page', 'CRM系统 ', 'company-crm', 'recommend', '/assets/img/qrcode.png', '', '', 'company-crm', 1491635035, 1491635035, 10, 'normal');
+INSERT INTO `fa_category` VALUES (11, 7, 'page', 'SASS平台软件', 'company-sass', 'recommend', '/assets/img/qrcode.png', '', '', 'company-sass', 1491635035, 1491635035, 11, 'normal');
+INSERT INTO `fa_category` VALUES (12, 0, 'test', '测试1', 'test1', 'recommend', '/assets/img/qrcode.png', '', '', 'test1', 1491635035, 1491635035, 12, 'normal');
+INSERT INTO `fa_category` VALUES (13, 0, 'test', '测试2', 'test2', 'recommend', '/assets/img/qrcode.png', '', '', 'test2', 1491635035, 1491635035, 13, 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_config
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_config`;
+CREATE TABLE `fa_config` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `name` varchar(30) DEFAULT '' COMMENT '变量名',
+  `group` varchar(30) DEFAULT '' COMMENT '分组',
+  `title` varchar(100) DEFAULT '' COMMENT '变量标题',
+  `tip` varchar(100) DEFAULT '' COMMENT '变量描述',
+  `type` varchar(30) DEFAULT '' COMMENT '类型:string,text,int,bool,array,datetime,date,file',
+  `visible` varchar(255) DEFAULT '' COMMENT '可见条件',
+  `value` text COMMENT '变量值',
+  `content` text COMMENT '变量字典数据',
+  `rule` varchar(100) DEFAULT '' COMMENT '验证规则',
+  `extend` varchar(255) DEFAULT '' COMMENT '扩展属性',
+  `setting` varchar(255) DEFAULT '' COMMENT '配置',
+  PRIMARY KEY (`id`),
+  UNIQUE KEY `name` (`name`)
+) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='系统配置';
+
+-- ----------------------------
+-- Records of fa_config
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_config` VALUES (1, 'name', 'basic', 'Site name', '请填写站点名称', 'string', '', '我的网站', '', 'required', '', '');
+INSERT INTO `fa_config` VALUES (2, 'beian', 'basic', 'Beian', '粤ICP备15000000号-1', 'string', '', '', '', '', '', '');
+INSERT INTO `fa_config` VALUES (3, 'cdnurl', 'basic', 'Cdn url', '如果全站静态资源使用第三方云储存请配置该值', 'string', '', '', '', '', '', '');
+INSERT INTO `fa_config` VALUES (4, 'version', 'basic', 'Version', '如果静态资源有变动请重新配置该值', 'string', '', '1.0.1', '', 'required', '', '');
+INSERT INTO `fa_config` VALUES (5, 'timezone', 'basic', 'Timezone', '', 'string', '', 'Asia/Shanghai', '', 'required', '', '');
+INSERT INTO `fa_config` VALUES (6, 'forbiddenip', 'basic', 'Forbidden ip', '一行一条记录', 'text', '', '', '', '', '', '');
+INSERT INTO `fa_config` VALUES (7, 'languages', 'basic', 'Languages', '', 'array', '', '{\"backend\":\"zh-cn\",\"frontend\":\"zh-cn\"}', '', 'required', '', '');
+INSERT INTO `fa_config` VALUES (8, 'fixedpage', 'basic', 'Fixed page', '请尽量输入左侧菜单栏存在的链接', 'string', '', 'dashboard', '', 'required', '', '');
+INSERT INTO `fa_config` VALUES (9, 'categorytype', 'dictionary', 'Category type', '', 'array', '', '{\"default\":\"Default\",\"page\":\"Page\",\"article\":\"Article\",\"test\":\"Test\"}', '', '', '', '');
+INSERT INTO `fa_config` VALUES (10, 'configgroup', 'dictionary', 'Config group', '', 'array', '', '{\"basic\":\"Basic\",\"email\":\"Email\",\"dictionary\":\"Dictionary\",\"user\":\"User\",\"example\":\"Example\"}', '', '', '', '');
+INSERT INTO `fa_config` VALUES (11, 'mail_type', 'email', 'Mail type', '选择邮件发送方式', 'select', '', '1', '[\"请选择\",\"SMTP\"]', '', '', '');
+INSERT INTO `fa_config` VALUES (12, 'mail_smtp_host', 'email', 'Mail smtp host', '错误的配置发送邮件会导致服务器超时', 'string', '', 'smtp.qq.com', '', '', '', '');
+INSERT INTO `fa_config` VALUES (13, 'mail_smtp_port', 'email', 'Mail smtp port', '(不加密默认25,SSL默认465,TLS默认587)', 'string', '', '465', '', '', '', '');
+INSERT INTO `fa_config` VALUES (14, 'mail_smtp_user', 'email', 'Mail smtp user', '(填写完整用户名)', 'string', '', '10000', '', '', '', '');
+INSERT INTO `fa_config` VALUES (15, 'mail_smtp_pass', 'email', 'Mail smtp password', '(填写您的密码或授权码)', 'string', '', 'password', '', '', '', '');
+INSERT INTO `fa_config` VALUES (16, 'mail_verify_type', 'email', 'Mail vertify type', '(SMTP验证方式[推荐SSL])', 'select', '', '2', '[\"无\",\"TLS\",\"SSL\"]', '', '', '');
+INSERT INTO `fa_config` VALUES (17, 'mail_from', 'email', 'Mail from', '', 'string', '', '10000@qq.com', '', '', '', '');
+INSERT INTO `fa_config` VALUES (18, 'attachmentcategory', 'dictionary', 'Attachment category', '', 'array', '', '{\"category1\":\"Category1\",\"category2\":\"Category2\",\"custom\":\"Custom\"}', '', '', '', '');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_ems
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_ems`;
+CREATE TABLE `fa_ems`  (
+  `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `event` varchar(30) DEFAULT '' COMMENT '事件',
+  `email` varchar(100) DEFAULT '' COMMENT '邮箱',
+  `code` varchar(10) DEFAULT '' COMMENT '验证码',
+  `times` int(10) UNSIGNED NOT NULL DEFAULT 0 COMMENT '验证次数',
+  `ip` varchar(30) DEFAULT '' COMMENT 'IP',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  PRIMARY KEY (`id`) USING BTREE
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='邮箱验证码表';
+
+-- ----------------------------
+-- Table structure for fa_sms
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_sms`;
+CREATE TABLE `fa_sms` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `event` varchar(30) DEFAULT '' COMMENT '事件',
+  `mobile` varchar(20) DEFAULT '' COMMENT '手机号',
+  `code` varchar(10) DEFAULT '' COMMENT '验证码',
+  `times` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '验证次数',
+  `ip` varchar(30) DEFAULT '' COMMENT 'IP',
+  `createtime` int(10) unsigned DEFAULT '0' COMMENT '创建时间',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='短信验证码表';
+
+-- ----------------------------
+-- Table structure for fa_test
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_test`;
+CREATE TABLE `fa_test` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `user_id` int(10) DEFAULT '0' COMMENT '会员ID',
+  `admin_id` int(10) DEFAULT '0' COMMENT '管理员ID',
+  `category_id` int(10) unsigned DEFAULT '0' COMMENT '分类ID(单选)',
+  `category_ids` varchar(100) COMMENT '分类ID(多选)',
+  `tags` varchar(255) DEFAULT '' COMMENT '标签',
+  `week` enum('monday','tuesday','wednesday') COMMENT '星期(单选):monday=星期一,tuesday=星期二,wednesday=星期三',
+  `flag` set('hot','index','recommend') DEFAULT '' COMMENT '标志(多选):hot=热门,index=首页,recommend=推荐',
+  `genderdata` enum('male','female') DEFAULT 'male' COMMENT '性别(单选):male=男,female=女',
+  `hobbydata` set('music','reading','swimming') COMMENT '爱好(多选):music=音乐,reading=读书,swimming=游泳',
+  `title` varchar(100) DEFAULT '' COMMENT '标题',
+  `content` text COMMENT '内容',
+  `image` varchar(100) DEFAULT '' COMMENT '图片',
+  `images` varchar(1500) DEFAULT '' COMMENT '图片组',
+  `attachfile` varchar(100) DEFAULT '' COMMENT '附件',
+  `keywords` varchar(255) DEFAULT '' COMMENT '关键字',
+  `description` varchar(255) DEFAULT '' COMMENT '描述',
+  `city` varchar(100) DEFAULT '' COMMENT '省市',
+  `json` varchar(255) DEFAULT NULL COMMENT '配置:key=名称,value=值',
+  `multiplejson` varchar(1500) DEFAULT '' COMMENT '二维数组:title=标题,intro=介绍,author=作者,age=年龄',
+  `price` decimal(10,2) unsigned DEFAULT '0.00' COMMENT '价格',
+  `views` int(10) unsigned DEFAULT '0' COMMENT '点击',
+  `workrange` varchar(100) DEFAULT '' COMMENT '时间区间',
+  `startdate` date DEFAULT NULL COMMENT '开始日期',
+  `activitytime` datetime DEFAULT NULL COMMENT '活动时间(datetime)',
+  `year` year(4) DEFAULT NULL COMMENT '年',
+  `times` time DEFAULT NULL COMMENT '时间',
+  `refreshtime` int(10) DEFAULT NULL COMMENT '刷新时间(int)',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `deletetime` int(10) DEFAULT NULL COMMENT '删除时间',
+  `weigh` int(10) DEFAULT '0' COMMENT '权重',
+  `switch` tinyint(1) DEFAULT '0' COMMENT '开关',
+  `status` enum('normal','hidden') DEFAULT 'normal' COMMENT '状态',
+  `state` enum('0','1','2') DEFAULT '1' COMMENT '状态值:0=禁用,1=正常,2=推荐',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='测试表';
+
+-- ----------------------------
+-- Records of fa_test
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_test` VALUES (1, 1, 1, 12, '12,13', '互联网,计算机', 'monday', 'hot,index', 'male', 'music,reading', '我是一篇测试文章', '<p>我是测试内容</p>', '/assets/img/avatar.png', '/assets/img/avatar.png,/assets/img/qrcode.png', '/assets/img/avatar.png', '关键字', '描述', '广西壮族自治区/百色市/平果县', '{\"a\":\"1\",\"b\":\"2\"}', '[{\"title\":\"标题一\",\"intro\":\"介绍一\",\"author\":\"小明\",\"age\":\"21\"}]', 0.00, 0, '2020-10-01 00:00:00 - 2021-10-31 23:59:59', '2017-07-10', '2017-07-10 18:24:45', 2017, '18:24:45', 1491635035, 1491635035, 1491635035, NULL, 0, 1, 'normal', '1');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_user
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user`;
+CREATE TABLE `fa_user` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `group_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '组别ID',
+  `username` varchar(32) DEFAULT '' COMMENT '用户名',
+  `nickname` varchar(50) DEFAULT '' COMMENT '昵称',
+  `password` varchar(32) DEFAULT '' COMMENT '密码',
+  `salt` varchar(30) DEFAULT '' COMMENT '密码盐',
+  `email` varchar(100) DEFAULT '' COMMENT '电子邮箱',
+  `mobile` varchar(11) DEFAULT '' COMMENT '手机号',
+  `avatar` varchar(255) DEFAULT '' COMMENT '头像',
+  `level` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '等级',
+  `gender` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '性别',
+  `birthday` date DEFAULT NULL COMMENT '生日',
+  `bio` varchar(100) DEFAULT '' COMMENT '格言',
+  `money` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '余额',
+  `score` int(10) NOT NULL DEFAULT '0' COMMENT '积分',
+  `successions` int(10) unsigned NOT NULL DEFAULT '1' COMMENT '连续登录天数',
+  `maxsuccessions` int(10) unsigned NOT NULL DEFAULT '1' COMMENT '最大连续登录天数',
+  `prevtime` int(10) DEFAULT NULL COMMENT '上次登录时间',
+  `logintime` int(10) DEFAULT NULL COMMENT '登录时间',
+  `loginip` varchar(50) DEFAULT '' COMMENT '登录IP',
+  `loginfailure` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '失败次数',
+  `joinip` varchar(50) DEFAULT '' COMMENT '加入IP',
+  `jointime` int(10) DEFAULT NULL COMMENT '加入时间',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `token` varchar(50) DEFAULT '' COMMENT 'Token',
+  `status` varchar(30) DEFAULT '' COMMENT '状态',
+  `verification` varchar(255) DEFAULT '' COMMENT '验证',
+  PRIMARY KEY (`id`),
+  KEY `username` (`username`),
+  KEY `email` (`email`),
+  KEY `mobile` (`mobile`)
+) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员表';
+
+-- ----------------------------
+-- Records of fa_user
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_user` VALUES (1, 1, 'admin', 'admin', '', '', 'admin@163.com', '13888888888', '', 0, 0, '2017-04-08', '', 0, 0, 1, 1, 1491635035, 1491635035, '127.0.0.1', 0, '127.0.0.1', 1491635035, 0, 1491635035, '', 'normal','');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_user_group
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user_group`;
+CREATE TABLE `fa_user_group` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `name` varchar(50) DEFAULT '' COMMENT '组名',
+  `rules` text COMMENT '权限节点',
+  `createtime` int(10) DEFAULT NULL COMMENT '添加时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `status` enum('normal','hidden') DEFAULT NULL COMMENT '状态',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员组表';
+
+-- ----------------------------
+-- Records of fa_user_group
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_user_group` VALUES (1, '默认组', '1,2,3,4,5,6,7,8,9,10,11,12', 1491635035, 1491635035, 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_user_money_log
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user_money_log`;
+CREATE TABLE `fa_user_money_log` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '会员ID',
+  `money` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '变更余额',
+  `before` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '变更前余额',
+  `after` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '变更后余额',
+  `memo` varchar(255) DEFAULT '' COMMENT '备注',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员余额变动表';
+
+-- ----------------------------
+-- Table structure for fa_user_rule
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user_rule`;
+CREATE TABLE `fa_user_rule` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `pid` int(10) DEFAULT NULL COMMENT '父ID',
+  `name` varchar(50) DEFAULT NULL COMMENT '名称',
+  `title` varchar(50) DEFAULT '' COMMENT '标题',
+  `remark` varchar(100) DEFAULT NULL COMMENT '备注',
+  `ismenu` tinyint(1) DEFAULT NULL COMMENT '是否菜单',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `weigh` int(10) DEFAULT '0' COMMENT '权重',
+  `status` enum('normal','hidden') DEFAULT NULL COMMENT '状态',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员规则表';
+
+-- ----------------------------
+-- Records of fa_user_rule
+-- ----------------------------
+BEGIN;
+INSERT INTO `fa_user_rule` VALUES (1, 0, 'index', 'Frontend', '', 1, 1491635035, 1491635035, 1, 'normal');
+INSERT INTO `fa_user_rule` VALUES (2, 0, 'api', 'API Interface', '', 1, 1491635035, 1491635035, 2, 'normal');
+INSERT INTO `fa_user_rule` VALUES (3, 1, 'user', 'User Module', '', 1, 1491635035, 1491635035, 12, 'normal');
+INSERT INTO `fa_user_rule` VALUES (4, 2, 'user', 'User Module', '', 1, 1491635035, 1491635035, 11, 'normal');
+INSERT INTO `fa_user_rule` VALUES (5, 3, 'index/user/login', 'Login', '', 0, 1491635035, 1491635035, 5, 'normal');
+INSERT INTO `fa_user_rule` VALUES (6, 3, 'index/user/register', 'Register', '', 0, 1491635035, 1491635035, 7, 'normal');
+INSERT INTO `fa_user_rule` VALUES (7, 3, 'index/user/index', 'User Center', '', 0, 1491635035, 1491635035, 9, 'normal');
+INSERT INTO `fa_user_rule` VALUES (8, 3, 'index/user/profile', 'Profile', '', 0, 1491635035, 1491635035, 4, 'normal');
+INSERT INTO `fa_user_rule` VALUES (9, 4, 'api/user/login', 'Login', '', 0, 1491635035, 1491635035, 6, 'normal');
+INSERT INTO `fa_user_rule` VALUES (10, 4, 'api/user/register', 'Register', '', 0, 1491635035, 1491635035, 8, 'normal');
+INSERT INTO `fa_user_rule` VALUES (11, 4, 'api/user/index', 'User Center', '', 0, 1491635035, 1491635035, 10, 'normal');
+INSERT INTO `fa_user_rule` VALUES (12, 4, 'api/user/profile', 'Profile', '', 0, 1491635035, 1491635035, 3, 'normal');
+COMMIT;
+
+-- ----------------------------
+-- Table structure for fa_user_score_log
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user_score_log`;
+CREATE TABLE `fa_user_score_log` (
+  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+  `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '会员ID',
+  `score` int(10) NOT NULL DEFAULT '0' COMMENT '变更积分',
+  `before` int(10) NOT NULL DEFAULT '0' COMMENT '变更前积分',
+  `after` int(10) NOT NULL DEFAULT '0' COMMENT '变更后积分',
+  `memo` varchar(255) DEFAULT '' COMMENT '备注',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  PRIMARY KEY (`id`)
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员积分变动表';
+
+-- ----------------------------
+-- Table structure for fa_user_token
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_user_token`;
+CREATE TABLE `fa_user_token` (
+  `token` varchar(50) NOT NULL COMMENT 'Token',
+  `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '会员ID',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `expiretime` int(10) DEFAULT NULL COMMENT '过期时间',
+  PRIMARY KEY (`token`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='会员Token表';
+
+-- ----------------------------
+-- Table structure for fa_version
+-- ----------------------------
+DROP TABLE IF EXISTS `fa_version`;
+CREATE TABLE `fa_version`  (
+  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID',
+  `oldversion` varchar(30) DEFAULT '' COMMENT '旧版本号',
+  `newversion` varchar(30) DEFAULT '' COMMENT '新版本号',
+  `packagesize` varchar(30) DEFAULT '' COMMENT '包大小',
+  `content` varchar(500) DEFAULT '' COMMENT '升级内容',
+  `downloadurl` varchar(255) DEFAULT '' COMMENT '下载地址',
+  `enforce` tinyint(1) UNSIGNED NOT NULL DEFAULT 0 COMMENT '强制更新',
+  `createtime` int(10) DEFAULT NULL COMMENT '创建时间',
+  `updatetime` int(10) DEFAULT NULL COMMENT '更新时间',
+  `weigh` int(10) NOT NULL DEFAULT 0 COMMENT '权重',
+  `status` varchar(30) DEFAULT '' COMMENT '状态',
+  PRIMARY KEY (`id`) USING BTREE
+) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT='版本表';
+
+SET FOREIGN_KEY_CHECKS = 1;

+ 316 - 0
application/admin/command/Install/install.html

@@ -0,0 +1,316 @@
+<!doctype html>
+<html>
+<head>
+    <meta charset="utf-8">
+    <meta http-equiv="X-UA-Compatible" content="IE=edge">
+    <title>{:__('Installing FastAdmin')}</title>
+    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1">
+    <meta name="renderer" content="webkit">
+
+    <style>
+        body {
+            background: #f1f6fd;
+            margin: 0;
+            padding: 0;
+            line-height: 1.5;
+            -webkit-font-smoothing: antialiased;
+            -moz-osx-font-smoothing: grayscale;
+        }
+
+        body, input, button {
+            font-family: 'Source Sans Pro', 'Helvetica Neue', Helvetica, 'Microsoft Yahei', Arial, sans-serif;
+            font-size: 14px;
+            color: #7E96B3;
+        }
+
+        .container {
+            max-width: 480px;
+            margin: 0 auto;
+            padding: 20px;
+            text-align: center;
+        }
+
+        a {
+            color: #4e73df;
+            text-decoration: none;
+        }
+
+        a:hover {
+            text-decoration: underline;
+        }
+
+        h1 {
+            margin-top: 0;
+            margin-bottom: 10px;
+        }
+
+        h2 {
+            font-size: 28px;
+            font-weight: normal;
+            color: #3C5675;
+            margin-bottom: 0;
+            margin-top: 0;
+        }
+
+        form {
+            margin-top: 40px;
+        }
+
+        .form-group {
+            margin-bottom: 20px;
+        }
+
+        .form-group .form-field:first-child input {
+            border-top-left-radius: 4px;
+            border-top-right-radius: 4px;
+        }
+
+        .form-group .form-field:last-child input {
+            border-bottom-left-radius: 4px;
+            border-bottom-right-radius: 4px;
+        }
+
+        .form-field input {
+            background: #fff;
+            margin: 0 0 2px;
+            border: 2px solid transparent;
+            transition: background 0.2s, border-color 0.2s, color 0.2s;
+            width: 100%;
+            padding: 15px 15px 15px 180px;
+            box-sizing: border-box;
+        }
+
+        .form-field input:focus {
+            border-color: #4e73df;
+            background: #fff;
+            color: #444;
+            outline: none;
+        }
+
+        .form-field label {
+            float: left;
+            width: 160px;
+            text-align: right;
+            margin-right: -160px;
+            position: relative;
+            margin-top: 15px;
+            font-size: 14px;
+            pointer-events: none;
+            opacity: 0.7;
+        }
+
+        button, .btn {
+            background: #3C5675;
+            color: #fff;
+            border: 0;
+            font-weight: bold;
+            border-radius: 4px;
+            cursor: pointer;
+            padding: 15px 30px;
+            -webkit-appearance: none;
+        }
+
+        button[disabled] {
+            opacity: 0.5;
+        }
+
+        .form-buttons {
+            height: 52px;
+            line-height: 52px;
+        }
+
+        .form-buttons .btn {
+            margin-right: 5px;
+        }
+
+        #error, .error, #success, .success, #warmtips, .warmtips {
+            background: #D83E3E;
+            color: #fff;
+            padding: 15px 20px;
+            border-radius: 4px;
+            margin-bottom: 20px;
+        }
+
+        #success {
+            background: #3C5675;
+        }
+
+        #error a, .error a {
+            color: white;
+            text-decoration: underline;
+        }
+
+        #warmtips {
+            background: #ffcdcd;
+            font-size: 14px;
+            color: #e74c3c;
+        }
+
+        #warmtips a {
+            background: #ffffff7a;
+            display: block;
+            height: 30px;
+            line-height: 30px;
+            margin-top: 10px;
+            color: #e21a1a;
+            border-radius: 3px;
+        }
+    </style>
+</head>
+
+<body>
+<div class="container">
+    <h1>
+        <svg width="80px" height="96px" viewBox="0 0 768 830" version="1.1" xmlns="http://www.w3.org/2000/svg"
+             xmlns:xlink="http://www.w3.org/1999/xlink">
+            <g id="logo" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
+                <path d="M64.433651,605.899968 C20.067302,536.265612 0,469.698785 0,389.731348 C0,174.488668 171.922656,0 384,0 C596.077344,0 768,174.488668 768,389.731348 C768,469.698785 747.932698,536.265612 703.566349,605.899968 C614.4,753.480595 441.6,870.4 384,870.4 C326.4,870.4 153.6,753.480595 64.433651,605.899968 L64.433651,605.899968 Z"
+                      id="body" fill="#4e73df"></path>
+                <path d="M429.648991,190.816 L430.160991,190.816 L429.648991,190.816 L429.648991,190.816 Z M429.648991,156 L427.088991,156 C419.408991,157.024 411.728991,160.608 404.560991,168.8 L403.024991,170.848 L206.928991,429.92 C198.736991,441.184 197.712991,453.984 204.368991,466.784 C210.512991,478.048 222.288991,485.728 235.600991,485.728 L336.464991,486.24 L304.208991,673.632 C301.648991,689.504 310.352991,705.376 325.200991,712.032 C329.808991,714.08 334.416991,714.592 339.536991,714.592 C349.776991,714.592 358.992991,709.472 366.160991,700.256 L561.744991,419.168 C569.936991,407.904 570.960991,395.104 564.304991,382.304 C557.648991,369.504 547.408991,363.36 533.072991,363.36 L432.208991,363.36 L463.952991,199.008 C464.464991,196.448 464.976991,193.376 464.976991,190.816 C464.976991,171.872 449.104991,156 431.184991,156 L429.648991,156 L429.648991,156 Z"
+                      id="flash" fill="#FFFFFF"></path>
+            </g>
+        </svg>
+    </h1>
+    <h2>{:__('Installing FastAdmin')}</h2>
+    <div>
+
+        <form method="post">
+            {if $errInfo}
+            <div class="error">
+                {$errInfo}
+            </div>
+            {/if}
+            <div id="error" style="display:none"></div>
+            <div id="success" style="display:none"></div>
+            <div id="warmtips" style="display:none"></div>
+
+            <div class="form-group">
+                <div class="form-field">
+                    <label>{:__('Mysql Hostname')}</label>
+                    <input type="text" name="mysqlHostname" value="127.0.0.1" required="">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Mysql Database')}</label>
+                    <input type="text" name="mysqlDatabase" value="" required="">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Mysql Username')}</label>
+                    <input type="text" name="mysqlUsername" value="root" required="">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Mysql Password')}</label>
+                    <input type="password" name="mysqlPassword">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Mysql Prefix')}</label>
+                    <input type="text" name="mysqlPrefix" value="fa_">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Mysql Hostport')}</label>
+                    <input type="number" name="mysqlHostport" value="3306">
+                </div>
+            </div>
+
+            <div class="form-group">
+                <div class="form-field">
+                    <label>{:__('Admin Username')}</label>
+                    <input name="adminUsername" value="admin" required=""/>
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Admin Email')}</label>
+                    <input name="adminEmail" value="admin@admin.com" required="">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Admin Password')}</label>
+                    <input type="password" name="adminPassword" required="">
+                </div>
+
+                <div class="form-field">
+                    <label>{:__('Repeat Password')}</label>
+                    <input type="password" name="adminPasswordConfirmation" required="">
+                </div>
+            </div>
+
+            <div class="form-group">
+                <div class="form-field">
+                    <label>{:__('Website')}</label>
+                    <input type="text" name="siteName" value="{:__('My Website')}" required=""/>
+                </div>
+
+            </div>
+
+            <div class="form-buttons">
+                <!--@formatter:off-->
+                <button type="submit" {:$errInfo?'disabled':''}>{:__('Install now')}</button>
+                <!--@formatter:on-->
+            </div>
+        </form>
+
+        <!-- jQuery -->
+        <script src="https://cdn.staticfile.org/jquery/2.1.4/jquery.min.js"></script>
+
+        <script>
+            $(function () {
+                $('form :input:first').select();
+
+                $('form').on('submit', function (e) {
+                    e.preventDefault();
+                    var form = this;
+                    var $error = $("#error");
+                    var $success = $("#success");
+                    var $button = $(this).find('button')
+                        .text("{:__('Installing')}")
+                        .prop('disabled', true);
+                    $.ajax({
+                        url: "",
+                        type: "POST",
+                        dataType: "json",
+                        data: $(this).serialize(),
+                        success: function (ret) {
+                            if (ret.code == 1) {
+                                var data = ret.data;
+                                $error.hide();
+                                $(".form-group", form).remove();
+                                $button.remove();
+                                $("#success").text(ret.msg).show();
+
+                                $buttons = $(".form-buttons", form);
+                                $("<a class='btn' href='./'>{:__('Home')}</a>").appendTo($buttons);
+
+                                if (typeof data.adminName !== 'undefined') {
+                                    var url = location.href.replace(/install\.php/, data.adminName);
+                                    $("#warmtips").html("{:__('Security tips')}" + '<a href="' + url + '">' + url + '</a>').show();
+                                    $('<a class="btn" href="' + url + '" id="btn-admin" style="background:#4e73df">' + "{:__('Dashboard')}" + '</a>').appendTo($buttons);
+                                }
+                                localStorage.setItem("fastep", "installed");
+                            } else {
+                                $error.show().text(ret.msg);
+                                $button.prop('disabled', false).text("{:__('Install now')}");
+                                $("html,body").animate({
+                                    scrollTop: 0
+                                }, 500);
+                            }
+                        },
+                        error: function (xhr) {
+                            $error.show().text(xhr.responseText);
+                            $button.prop('disabled', false).text("{:__('Install now')}");
+                            $("html,body").animate({
+                                scrollTop: 0
+                            }, 500);
+                        }
+                    });
+                    return false;
+                });
+            });
+        </script>
+    </div>
+</div>
+</body>
+</html>

+ 35 - 0
application/admin/command/Install/zh-cn.php

@@ -0,0 +1,35 @@
+<?php
+return [
+    'Warning'                                                                                               => '温馨提示',
+    'Installing FastAdmin'                                                                                  => '安装FastAdmin',
+    'Mysql Hostname'                                                                                        => 'MySQL 数据库地址',
+    'Mysql Database'                                                                                        => 'MySQL 数据库名',
+    'Mysql Username'                                                                                        => 'MySQL 用户名',
+    'Mysql Password'                                                                                        => 'MySQL 密码',
+    'Mysql Prefix'                                                                                          => 'MySQL 数据表前缀',
+    'Mysql Hostport'                                                                                        => 'MySQL 端口号',
+    'Admin Username'                                                                                        => '管理员用户名',
+    'Admin Email'                                                                                           => '管理员Email',
+    'Admin Password'                                                                                        => '管理员密码',
+    'Repeat Password'                                                                                       => '重复管理员密码',
+    'Website'                                                                                               => '网站名称',
+    'My Website'                                                                                            => '我的网站',
+    'Install now'                                                                                           => '点击安装',
+    'Installing'                                                                                            => '安装中...',
+    'Home'                                                                                                  => '访问首页',
+    'Dashboard'                                                                                             => '进入后台',
+    'Go back'                                                                                               => '返回上一页',
+    'Install Successed'                                                                                     => '安装成功!',
+    'Security tips'                                                                                         => '温馨提示:请将以下后台登录入口添加到你的收藏夹,为了你的安全,不要泄漏或发送给他人!如有泄漏请及时修改!',
+    'Please input correct database'                                                                         => '请输入正确的数据库名',
+    'Please input correct username'                                                                         => '用户名只能由3-30位数字、字母、下划线组合',
+    'Please input correct password'                                                                         => '密码长度必须在6-30位之间,不能包含空格',
+    'Password is too weak'                                                                                  => '密码太简单,请重新输入',
+    'The two passwords you entered did not match'                                                           => '两次输入的密码不一致',
+    'Please input correct website'                                                                          => '网站名称输入不正确',
+    'The current version %s is too low, please use PHP 7.1 or higher'                                       => '当前版本%s过低,请使用PHP7.1以上版本',
+    'PDO is not currently installed and cannot be installed'                                                => '当前未开启PDO,无法进行安装',
+    'The current permissions are insufficient to write the file %s'                                         => '当前权限不足,无法写入文件%s',
+    'Please go to the official website to download the full package or resource package and try to install' => '当前代码仅包含核心代码,请前往官网下载完整包或资源包覆盖后再尝试安装',
+    'The system has been installed. If you need to reinstall, please remove %s first'                       => '当前已经安装成功,如果需要重新安装,请手动移除%s文件',
+];

+ 327 - 0
application/admin/command/Menu.php

@@ -0,0 +1,327 @@
+<?php
+
+namespace app\admin\command;
+
+use app\admin\model\AuthRule;
+use ReflectionClass;
+use ReflectionMethod;
+use think\Cache;
+use think\Config;
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Exception;
+use think\Loader;
+
+class Menu extends Command
+{
+    protected $model = null;
+
+    protected function configure()
+    {
+        $this
+            ->setName('menu')
+            ->addOption('controller', 'c', Option::VALUE_REQUIRED | Option::VALUE_IS_ARRAY, 'controller name,use \'all-controller\' when build all menu', null)
+            ->addOption('delete', 'd', Option::VALUE_OPTIONAL, 'delete the specified menu', '')
+            ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force delete menu,without tips', null)
+            ->addOption('equal', 'e', Option::VALUE_OPTIONAL, 'the controller must be equal', null)
+            ->setDescription('Build auth menu from controller');
+        //要执行的controller必须一样,不适用模糊查询
+    }
+
+    protected function execute(Input $input, Output $output)
+    {
+        $this->model = new AuthRule();
+        $adminPath = dirname(__DIR__) . DS;
+        //控制器名
+        $controller = $input->getOption('controller') ?: '';
+        if (!$controller) {
+            throw new Exception("please input controller name");
+        }
+        $force = $input->getOption('force');
+        //是否为删除模式
+        $delete = $input->getOption('delete');
+        //是否控制器完全匹配
+        $equal = $input->getOption('equal');
+
+
+        if ($delete) {
+            if (in_array('all-controller', $controller)) {
+                throw new Exception("could not delete all menu");
+            }
+            $ids = [];
+            $list = $this->model->where(function ($query) use ($controller, $equal) {
+                foreach ($controller as $index => $item) {
+                    if (stripos($item, '_') !== false) {
+                        $item = Loader::parseName($item, 1);
+                    }
+                    if (stripos($item, '/') !== false) {
+                        $controllerArr = explode('/', $item);
+                        end($controllerArr);
+                        $key = key($controllerArr);
+                        $controllerArr[$key] = Loader::parseName($controllerArr[$key]);
+                    } else {
+                        $controllerArr = [Loader::parseName($item)];
+                    }
+                    $item = str_replace('_', '\_', implode('/', $controllerArr));
+                    if ($equal) {
+                        $query->whereOr('name', 'eq', $item);
+                    } else {
+                        $query->whereOr('name', 'like', strtolower($item) . "%");
+                    }
+                }
+            })->select();
+            foreach ($list as $k => $v) {
+                $output->warning($v->name);
+                $ids[] = $v->id;
+            }
+            if (!$ids) {
+                throw new Exception("There is no menu to delete");
+            }
+            if (!$force) {
+                $output->info("Are you sure you want to delete all those menu?  Type 'yes' to continue: ");
+                $line = fgets(defined('STDIN') ? STDIN : fopen('php://stdin', 'r'));
+                if (trim($line) != 'yes') {
+                    throw new Exception("Operation is aborted!");
+                }
+            }
+            AuthRule::destroy($ids);
+
+            Cache::rm("__menu__");
+            $output->info("Delete Successed");
+            return;
+        }
+
+        if (!in_array('all-controller', $controller)) {
+            foreach ($controller as $index => $item) {
+                if (stripos($item, '_') !== false) {
+                    $item = Loader::parseName($item, 1);
+                }
+                if (stripos($item, '/') !== false) {
+                    $controllerArr = explode('/', $item);
+                    end($controllerArr);
+                    $key = key($controllerArr);
+                    $controllerArr[$key] = ucfirst($controllerArr[$key]);
+                } else {
+                    $controllerArr = [ucfirst($item)];
+                }
+                $adminPath = dirname(__DIR__) . DS . 'controller' . DS . implode(DS, $controllerArr) . '.php';
+                if (!is_file($adminPath)) {
+                    $output->error("controller not found");
+                    return;
+                }
+                $this->importRule($item);
+            }
+        } else {
+            $authRuleList = AuthRule::select();
+            //生成权限规则备份文件
+            file_put_contents(RUNTIME_PATH . 'authrule.json', json_encode(collection($authRuleList)->toArray()));
+
+            $this->model->where('id', '>', 0)->delete();
+            $controllerDir = $adminPath . 'controller' . DS;
+            // 扫描新的节点信息并导入
+            $treelist = $this->import($this->scandir($controllerDir));
+        }
+        Cache::rm("__menu__");
+        $output->info("Build Successed!");
+    }
+
+    /**
+     * 递归扫描文件夹
+     * @param string $dir
+     * @return array
+     */
+    public function scandir($dir)
+    {
+        $result = [];
+        $cdir = scandir($dir);
+        foreach ($cdir as $value) {
+            if (!in_array($value, array(".", ".."))) {
+                if (is_dir($dir . DS . $value)) {
+                    $result[$value] = $this->scandir($dir . DS . $value);
+                } else {
+                    $result[] = $value;
+                }
+            }
+        }
+        return $result;
+    }
+
+    /**
+     * 导入规则节点
+     * @param array $dirarr
+     * @param array $parentdir
+     * @return array
+     */
+    public function import($dirarr, $parentdir = [])
+    {
+        $menuarr = [];
+        foreach ($dirarr as $k => $v) {
+            if (is_array($v)) {
+                //当前是文件夹
+                $nowparentdir = array_merge($parentdir, [$k]);
+                $this->import($v, $nowparentdir);
+            } else {
+                //只匹配PHP文件
+                if (!preg_match('/^(\w+)\.php$/', $v, $matchone)) {
+                    continue;
+                }
+                //导入文件
+                $controller = ($parentdir ? implode('/', $parentdir) . '/' : '') . $matchone[1];
+                $this->importRule($controller);
+            }
+        }
+
+        return $menuarr;
+    }
+
+    protected function importRule($controller)
+    {
+        $controller = str_replace('\\', '/', $controller);
+        if (stripos($controller, '/') !== false) {
+            $controllerArr = explode('/', $controller);
+            end($controllerArr);
+            $key = key($controllerArr);
+            $controllerArr[$key] = ucfirst($controllerArr[$key]);
+        } else {
+            $key = 0;
+            $controllerArr = [ucfirst($controller)];
+        }
+        $classSuffix = Config::get('controller_suffix') ? ucfirst(Config::get('url_controller_layer')) : '';
+        $className = "\\app\\admin\\controller\\" . implode("\\", $controllerArr) . $classSuffix;
+
+        $pathArr = $controllerArr;
+        array_unshift($pathArr, '', 'application', 'admin', 'controller');
+        $classFile = ROOT_PATH . implode(DS, $pathArr) . $classSuffix . ".php";
+        $classContent = file_get_contents($classFile);
+        $uniqueName = uniqid("FastAdmin") . $classSuffix;
+        $classContent = str_replace("class " . $controllerArr[$key] . $classSuffix . " ", 'class ' . $uniqueName . ' ', $classContent);
+        $classContent = preg_replace("/namespace\s(.*);/", 'namespace ' . __NAMESPACE__ . ";", $classContent);
+
+        //临时的类文件
+        $tempClassFile = __DIR__ . DS . $uniqueName . ".php";
+        file_put_contents($tempClassFile, $classContent);
+        $className = "\\app\\admin\\command\\" . $uniqueName;
+
+        //删除临时文件
+        register_shutdown_function(function () use ($tempClassFile) {
+            if ($tempClassFile) {
+                //删除临时文件
+                @unlink($tempClassFile);
+            }
+        });
+
+        //反射机制调用类的注释和方法名
+        $reflector = new ReflectionClass($className);
+
+        //只匹配公共的方法
+        $methods = $reflector->getMethods(ReflectionMethod::IS_PUBLIC);
+        $classComment = $reflector->getDocComment();
+        //判断是否有启用软删除
+        $softDeleteMethods = ['destroy', 'restore', 'recyclebin'];
+        $withSofeDelete = false;
+        $modelRegexArr = ["/\\\$this\->model\s*=\s*model\(['|\"](\w+)['|\"]\);/", "/\\\$this\->model\s*=\s*new\s+([a-zA-Z\\\]+);/"];
+        $modelRegex = preg_match($modelRegexArr[0], $classContent) ? $modelRegexArr[0] : $modelRegexArr[1];
+        preg_match_all($modelRegex, $classContent, $matches);
+        if (isset($matches[1]) && isset($matches[1][0]) && $matches[1][0]) {
+            \think\Request::instance()->module('admin');
+            $model = model($matches[1][0]);
+            if (in_array('trashed', get_class_methods($model))) {
+                $withSofeDelete = true;
+            }
+        }
+        //忽略的类
+        if (stripos($classComment, "@internal") !== false) {
+            return;
+        }
+        preg_match_all('#(@.*?)\n#s', $classComment, $annotations);
+        $controllerIcon = 'fa fa-circle-o';
+        $controllerRemark = '';
+        //判断注释中是否设置了icon值
+        if (isset($annotations[1])) {
+            foreach ($annotations[1] as $tag) {
+                if (stripos($tag, '@icon') !== false) {
+                    $controllerIcon = substr($tag, stripos($tag, ' ') + 1);
+                }
+                if (stripos($tag, '@remark') !== false) {
+                    $controllerRemark = substr($tag, stripos($tag, ' ') + 1);
+                }
+            }
+        }
+        //过滤掉其它字符
+        $controllerTitle = trim(preg_replace(array('/^\/\*\*(.*)[\n\r\t]/u', '/[\s]+\*\//u', '/\*\s@(.*)/u', '/[\s|\*]+/u'), '', $classComment));
+
+        //导入中文语言包
+        \think\Lang::load(dirname(__DIR__) . DS . 'lang/zh-cn.php');
+
+        //先导入菜单的数据
+        $pid = 0;
+        foreach ($controllerArr as $k => $v) {
+            $key = $k + 1;
+            //驼峰转下划线
+            $controllerNameArr = array_slice($controllerArr, 0, $key);
+            foreach ($controllerNameArr as &$val) {
+                $val = strtolower(trim(preg_replace("/[A-Z]/", "_\\0", $val), "_"));
+            }
+            unset($val);
+            $name = implode('/', $controllerNameArr);
+            $title = (!isset($controllerArr[$key]) ? $controllerTitle : '');
+            $icon = (!isset($controllerArr[$key]) ? $controllerIcon : 'fa fa-list');
+            $remark = (!isset($controllerArr[$key]) ? $controllerRemark : '');
+            $title = $title ? $title : $v;
+            $rulemodel = $this->model->get(['name' => $name]);
+            if (!$rulemodel) {
+                $this->model
+                    ->data(['pid' => $pid, 'name' => $name, 'title' => $title, 'icon' => $icon, 'remark' => $remark, 'ismenu' => 1, 'status' => 'normal'])
+                    ->isUpdate(false)
+                    ->save();
+                $pid = $this->model->id;
+            } else {
+                $pid = $rulemodel->id;
+            }
+        }
+        $ruleArr = [];
+        foreach ($methods as $m => $n) {
+            //过滤特殊的类
+            if (substr($n->name, 0, 2) == '__' || $n->name == '_initialize') {
+                continue;
+            }
+            //未启用软删除时过滤相关方法
+            if (!$withSofeDelete && in_array($n->name, $softDeleteMethods)) {
+                continue;
+            }
+            //只匹配符合的方法
+            if (!preg_match('/^(\w+)' . Config::get('action_suffix') . '/', $n->name, $matchtwo)) {
+                unset($methods[$m]);
+                continue;
+            }
+            $comment = $reflector->getMethod($n->name)->getDocComment();
+            //忽略的方法
+            if (stripos($comment, "@internal") !== false) {
+                continue;
+            }
+            //过滤掉其它字符
+            $comment = preg_replace(array('/^\/\*\*(.*)[\n\r\t]/u', '/[\s]+\*\//u', '/\*\s@(.*)/u', '/[\s|\*]+/u'), '', $comment);
+
+            $title = $comment ? $comment : ucfirst($n->name);
+
+            //获取主键,作为AuthRule更新依据
+            $id = $this->getAuthRulePK($name . "/" . strtolower($n->name));
+
+            $ruleArr[] = array('id' => $id, 'pid' => $pid, 'name' => $name . "/" . strtolower($n->name), 'icon' => 'fa fa-circle-o', 'title' => $title, 'ismenu' => 0, 'status' => 'normal');
+        }
+        $this->model->isUpdate(false)->saveAll($ruleArr);
+    }
+
+    //获取主键
+    protected function getAuthRulePK($name)
+    {
+        if (!empty($name)) {
+            $id = $this->model
+                ->where('name', $name)
+                ->value('id');
+            return $id ? $id : null;
+        }
+    }
+}

+ 162 - 0
application/admin/command/Min.php

@@ -0,0 +1,162 @@
+<?php
+
+namespace app\admin\command;
+
+use think\console\Command;
+use think\console\Input;
+use think\console\input\Option;
+use think\console\Output;
+use think\Exception;
+
+class Min extends Command
+{
+
+    /**
+     * 路径和文件名配置
+     */
+    protected $options = [
+        'cssBaseUrl'  => 'public/assets/css/',
+        'cssBaseName' => '{module}',
+        'jsBaseUrl'   => 'public/assets/js/',
+        'jsBaseName'  => 'require-{module}',
+    ];
+
+    protected function configure()
+    {
+        $this
+                ->setName('min')
+                ->addOption('module', 'm', Option::VALUE_REQUIRED, 'module name(frontend or backend),use \'all\' when build all modules', null)
+                ->addOption('resource', 'r', Option::VALUE_REQUIRED, 'resource name(js or css),use \'all\' when build all resources', null)
+                ->addOption('optimize', 'o', Option::VALUE_OPTIONAL, 'optimize type(uglify|closure|none)', 'none')
+                ->setDescription('Compress js and css file');
+    }
+
+    protected function execute(Input $input, Output $output)
+    {
+        $module = $input->getOption('module') ?: '';
+        $resource = $input->getOption('resource') ?: '';
+        $optimize = $input->getOption('optimize') ?: 'none';
+
+        if (!$module || !in_array($module, ['frontend', 'backend', 'all'])) {
+            throw new Exception('Please input correct module name');
+        }
+        if (!$resource || !in_array($resource, ['js', 'css', 'all'])) {
+            throw new Exception('Please input correct resource name');
+        }
+
+        $moduleArr = $module == 'all' ? ['frontend', 'backend'] : [$module];
+        $resourceArr = $resource == 'all' ? ['js', 'css'] : [$resource];
+
+        $minPath = __DIR__ . DS . 'Min' . DS;
+        $publicPath = ROOT_PATH . 'public' . DS;
+        $tempFile = $minPath . 'temp.js';
+
+        $nodeExec = '';
+
+        if (!$nodeExec) {
+            if (IS_WIN) {
+                // Winsows下请手动配置配置该值,一般将该值配置为 '"C:\Program Files\nodejs\node.exe"',除非你的Node安装路径有变更
+                $nodeExec = 'C:\Program Files\nodejs\node.exe';
+                if (file_exists($nodeExec)) {
+                    $nodeExec = '"' . $nodeExec . '"';
+                } else {
+                    // 如果 '"C:\Program Files\nodejs\node.exe"' 不存在,可能是node安装路径有变更
+                    // 但安装node会自动配置环境变量,直接执行 '"node.exe"' 提高第一次使用压缩打包的成功率
+                    $nodeExec = '"node.exe"';
+                }
+            } else {
+                try {
+                    $nodeExec = exec("which node");
+                    if (!$nodeExec) {
+                        throw new Exception("node environment not found!please install node first!");
+                    }
+                } catch (Exception $e) {
+                    throw new Exception($e->getMessage());
+                }
+            }
+        }
+
+        foreach ($moduleArr as $mod) {
+            foreach ($resourceArr as $res) {
+                $data = [
+                    'publicPath'  => $publicPath,
+                    'jsBaseName'  => str_replace('{module}', $mod, $this->options['jsBaseName']),
+                    'jsBaseUrl'   => $this->options['jsBaseUrl'],
+                    'cssBaseName' => str_replace('{module}', $mod, $this->options['cssBaseName']),
+                    'cssBaseUrl'  => $this->options['cssBaseUrl'],
+                    'jsBasePath'  => str_replace(DS, '/', ROOT_PATH . $this->options['jsBaseUrl']),
+                    'cssBasePath' => str_replace(DS, '/', ROOT_PATH . $this->options['cssBaseUrl']),
+                    'optimize'    => $optimize,
+                    'ds'          => DS,
+                ];
+
+                //源文件
+                $from = $data["{$res}BasePath"] . $data["{$res}BaseName"] . '.' . $res;
+                if (!is_file($from)) {
+                    $output->error("{$res} source file not found!file:{$from}");
+                    continue;
+                }
+                if ($res == "js") {
+                    $content = file_get_contents($from);
+                    preg_match("/require\.config\(\{[\r\n]?[\n]?+(.*?)[\r\n]?[\n]?}\);/is", $content, $matches);
+                    if (!isset($matches[1])) {
+                        $output->error("js config not found!");
+                        continue;
+                    }
+                    $config = preg_replace("/(urlArgs|baseUrl):(.*)\n/", '', $matches[1]);
+                    $data['config'] = $config;
+                }
+                // 生成压缩文件
+                $this->writeToFile($res, $data, $tempFile);
+
+                $output->info("Compress " . $data["{$res}BaseName"] . ".{$res}");
+
+                // 执行压缩
+                $command = "{$nodeExec} \"{$minPath}r.js\" -o \"{$tempFile}\" >> \"{$minPath}node.log\"";
+                if ($output->isDebug()) {
+                    $output->warning($command);
+                }
+                echo exec($command);
+            }
+        }
+
+        if (!$output->isDebug()) {
+            @unlink($tempFile);
+        }
+
+        $output->info("Build Successed!");
+    }
+
+    /**
+     * 写入到文件
+     * @param string $name
+     * @param array $data
+     * @param string $pathname
+     * @return mixed
+     */
+    protected function writeToFile($name, $data, $pathname)
+    {
+        $search = $replace = [];
+        foreach ($data as $k => $v) {
+            $search[] = "{%{$k}%}";
+            $replace[] = $v;
+        }
+        $stub = file_get_contents($this->getStub($name));
+        $content = str_replace($search, $replace, $stub);
+
+        if (!is_dir(dirname($pathname))) {
+            mkdir(strtolower(dirname($pathname)), 0755, true);
+        }
+        return file_put_contents($pathname, $content);
+    }
+
+    /**
+     * 获取基础模板
+     * @param string $name
+     * @return string
+     */
+    protected function getStub($name)
+    {
+        return __DIR__ . DS . 'Min' . DS . 'stubs' . DS . $name . '.stub';
+    }
+}

File diff suppressed because it is too large
+ 4699 - 0
application/admin/command/Min/r.js


+ 6 - 0
application/admin/command/Min/stubs/css.stub

@@ -0,0 +1,6 @@
+({
+  cssIn: "{%cssBasePath%}{%cssBaseName%}.css",
+  out: "{%cssBasePath%}{%cssBaseName%}.min.css",
+  optimizeCss: "default",
+  optimize: "{%optimize%}"
+})

+ 11 - 0
application/admin/command/Min/stubs/js.stub

@@ -0,0 +1,11 @@
+({
+    {%config%}
+    ,
+    optimizeCss: "standard",
+    optimize: "{%optimize%}",   //可使用uglify|closure|none
+    preserveLicenseComments: false,
+    removeCombined: false,
+    baseUrl: "{%jsBasePath%}",    //JS文件所在的基础目录
+    name: "{%jsBaseName%}", //来源文件,不包含后缀
+    out: "{%jsBasePath%}{%jsBaseName%}.min.js"  //目标文件
+});

+ 196 - 0
application/admin/common.php

@@ -0,0 +1,196 @@
+<?php
+
+use app\common\model\Category;
+use fast\Form;
+use fast\Tree;
+use think\Db;
+
+if (!function_exists('build_select')) {
+
+    /**
+     * 生成下拉列表
+     * @param string $name
+     * @param mixed  $options
+     * @param mixed  $selected
+     * @param mixed  $attr
+     * @return string
+     */
+    function build_select($name, $options, $selected = [], $attr = [])
+    {
+        $options = is_array($options) ? $options : explode(',', $options);
+        $selected = is_array($selected) ? $selected : explode(',', $selected);
+        return Form::select($name, $options, $selected, $attr);
+    }
+}
+
+if (!function_exists('build_radios')) {
+
+    /**
+     * 生成单选按钮组
+     * @param string $name
+     * @param array  $list
+     * @param mixed  $selected
+     * @return string
+     */
+    function build_radios($name, $list = [], $selected = null)
+    {
+        $html = [];
+        $selected = is_null($selected) ? key($list) : $selected;
+        $selected = is_array($selected) ? $selected : explode(',', $selected);
+        foreach ($list as $k => $v) {
+            $html[] = sprintf(Form::label("{$name}-{$k}", "%s {$v}"), Form::radio($name, $k, in_array($k, $selected), ['id' => "{$name}-{$k}"]));
+        }
+        return '<div class="radio">' . implode(' ', $html) . '</div>';
+    }
+}
+
+if (!function_exists('build_checkboxs')) {
+
+    /**
+     * 生成复选按钮组
+     * @param string $name
+     * @param array  $list
+     * @param mixed  $selected
+     * @return string
+     */
+    function build_checkboxs($name, $list = [], $selected = null)
+    {
+        $html = [];
+        $selected = is_null($selected) ? [] : $selected;
+        $selected = is_array($selected) ? $selected : explode(',', $selected);
+        foreach ($list as $k => $v) {
+            $html[] = sprintf(Form::label("{$name}-{$k}", "%s {$v}"), Form::checkbox($name, $k, in_array($k, $selected), ['id' => "{$name}-{$k}"]));
+        }
+        return '<div class="checkbox">' . implode(' ', $html) . '</div>';
+    }
+}
+
+
+if (!function_exists('build_category_select')) {
+
+    /**
+     * 生成分类下拉列表框
+     * @param string $name
+     * @param string $type
+     * @param mixed  $selected
+     * @param array  $attr
+     * @param array  $header
+     * @return string
+     */
+    function build_category_select($name, $type, $selected = null, $attr = [], $header = [])
+    {
+        $tree = Tree::instance();
+        $tree->init(Category::getCategoryArray($type), 'pid');
+        $categorylist = $tree->getTreeList($tree->getTreeArray(0), 'name');
+        $categorydata = $header ? $header : [];
+        foreach ($categorylist as $k => $v) {
+            $categorydata[$v['id']] = $v['name'];
+        }
+        $attr = array_merge(['id' => "c-{$name}", 'class' => 'form-control selectpicker'], $attr);
+        return build_select($name, $categorydata, $selected, $attr);
+    }
+}
+
+if (!function_exists('build_toolbar')) {
+
+    /**
+     * 生成表格操作按钮栏
+     * @param array $btns 按钮组
+     * @param array $attr 按钮属性值
+     * @return string
+     */
+    function build_toolbar($btns = null, $attr = [])
+    {
+        $auth = \app\admin\library\Auth::instance();
+        $controller = str_replace('.', '/', strtolower(think\Request::instance()->controller()));
+        $btns = $btns ? $btns : ['refresh', 'add', 'edit', 'del', 'import'];
+        $btns = is_array($btns) ? $btns : explode(',', $btns);
+        $index = array_search('delete', $btns);
+        if ($index !== false) {
+            $btns[$index] = 'del';
+        }
+        $btnAttr = [
+            'refresh' => ['javascript:;', 'btn btn-primary btn-refresh', 'fa fa-refresh', '', __('Refresh')],
+            'add'     => ['javascript:;', 'btn btn-success btn-add', 'fa fa-plus', __('Add'), __('Add')],
+            'edit'    => ['javascript:;', 'btn btn-success btn-edit btn-disabled disabled', 'fa fa-pencil', __('Edit'), __('Edit')],
+            'del'     => ['javascript:;', 'btn btn-danger btn-del btn-disabled disabled', 'fa fa-trash', __('Delete'), __('Delete')],
+            'import'  => ['javascript:;', 'btn btn-info btn-import', 'fa fa-upload', __('Import'), __('Import')],
+        ];
+        $btnAttr = array_merge($btnAttr, $attr);
+        $html = [];
+        foreach ($btns as $k => $v) {
+            //如果未定义或没有权限
+            if (!isset($btnAttr[$v]) || ($v !== 'refresh' && !$auth->check("{$controller}/{$v}"))) {
+                continue;
+            }
+            list($href, $class, $icon, $text, $title) = $btnAttr[$v];
+            //$extend = $v == 'import' ? 'id="btn-import-file" data-url="ajax/upload" data-mimetype="csv,xls,xlsx" data-multiple="false"' : '';
+            //$html[] = '<a href="' . $href . '" class="' . $class . '" title="' . $title . '" ' . $extend . '><i class="' . $icon . '"></i> ' . $text . '</a>';
+            if ($v == 'import') {
+                $template = str_replace('/', '_', $controller);
+                $download = '';
+                if (file_exists("./template/{$template}.xlsx")) {
+                    $download .= "<li><a href=\"/template/{$template}.xlsx\" target=\"_blank\">XLSX模版</a></li>";
+                }
+                if (file_exists("./template/{$template}.xls")) {
+                    $download .= "<li><a href=\"/template/{$template}.xls\" target=\"_blank\">XLS模版</a></li>";
+                }
+                if (file_exists("./template/{$template}.csv")) {
+                    $download .= empty($download) ? '' : "<li class=\"divider\"></li>";
+                    $download .= "<li><a href=\"/template/{$template}.csv\" target=\"_blank\">CSV模版</a></li>";
+                }
+                $download .= empty($download) ? '' : "\n                            ";
+                if (!empty($download)) {
+                    $html[] = <<<EOT
+                        <div class="btn-group">
+                            <button type="button" href="{$href}" class="btn btn-info btn-import" title="{$title}" id="btn-import-file" data-url="ajax/upload" data-mimetype="csv,xls,xlsx" data-multiple="false"><i class="{$icon}"></i> {$text}</button>
+                            <button type="button" class="btn btn-info dropdown-toggle" data-toggle="dropdown" title="下载批量导入模版">
+                                <span class="caret"></span>
+                                <span class="sr-only">Toggle Dropdown</span>
+                            </button>
+                            <ul class="dropdown-menu" role="menu">{$download}</ul>
+                        </div>
+EOT;
+                } else {
+                    $html[] = '<a href="' . $href . '" class="' . $class . '" title="' . $title . '" id="btn-import-file" data-url="ajax/upload" data-mimetype="csv,xls,xlsx" data-multiple="false"><i class="' . $icon . '"></i> ' . $text . '</a>';
+                }
+            } else {
+                $html[] = '<a href="' . $href . '" class="' . $class . '" title="' . $title . '"><i class="' . $icon . '"></i> ' . $text . '</a>';
+            }
+        }
+        return implode(' ', $html);
+    }
+}
+
+if (!function_exists('build_heading')) {
+
+    /**
+     * 生成页面Heading
+     *
+     * @param string $path 指定的path
+     * @return string
+     */
+    function build_heading($path = null, $container = true)
+    {
+        $title = $content = '';
+        if (is_null($path)) {
+            $action = request()->action();
+            $controller = str_replace('.', '/', request()->controller());
+            $path = strtolower($controller . ($action && $action != 'index' ? '/' . $action : ''));
+        }
+        // 根据当前的URI自动匹配父节点的标题和备注
+        $data = Db::name('auth_rule')->where('name', $path)->field('title,remark')->find();
+        if ($data) {
+            $title = __($data['title']);
+            $content = __($data['remark']);
+        }
+        if (!$content) {
+            return '';
+        }
+        $result = '<div class="panel-lead"><em>' . $title . '</em>' . $content . '</div>';
+        if ($container) {
+            $result = '<div class="panel-heading">' . $result . '</div>';
+        }
+        return $result;
+    }
+}

+ 8 - 0
application/admin/config.php

@@ -0,0 +1,8 @@
+<?php
+
+//配置文件
+return [
+    'url_common_param'       => true,
+    'url_html_suffix'        => '',
+    'controller_auto_search' => true,
+];

+ 453 - 0
application/admin/controller/Addon.php

@@ -0,0 +1,453 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+use fast\Http;
+use think\addons\AddonException;
+use think\addons\Service;
+use think\Cache;
+use think\Config;
+use think\Db;
+use think\Exception;
+
+/**
+ * 插件管理
+ *
+ * @icon   fa fa-cube
+ * @remark 可在线安装、卸载、禁用、启用、配置、升级插件,插件升级前请做好备份。
+ */
+class Addon extends Backend
+{
+    protected $model = null;
+    protected $noNeedRight = ['get_table_list'];
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        if (!$this->auth->isSuperAdmin() && in_array($this->request->action(), ['install', 'uninstall', 'local', 'upgrade', 'authorization', 'testdata'])) {
+            $this->error(__('Access is allowed only to the super management group'));
+        }
+    }
+
+    /**
+     * 插件列表
+     */
+    public function index()
+    {
+        $addons = get_addon_list();
+        foreach ($addons as $k => &$v) {
+            $config = get_addon_config($v['name']);
+            $v['config'] = $config ? 1 : 0;
+            $v['url'] = str_replace($this->request->server('SCRIPT_NAME'), '', $v['url']);
+        }
+        $this->assignconfig(['addons' => $addons, 'api_url' => config('fastadmin.api_url'), 'faversion' => config('fastadmin.version'), 'domain' => request()->host(true)]);
+        return $this->view->fetch();
+    }
+
+    /**
+     * 配置
+     */
+    public function config($name = null)
+    {
+        $name = $name ? $name : $this->request->get("name");
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+        $info = get_addon_info($name);
+        $config = get_addon_fullconfig($name);
+        if (!$info) {
+            $this->error(__('Addon not exists'));
+        }
+        if ($this->request->isPost()) {
+            $params = $this->request->post("row/a", [], 'trim');
+            if ($params) {
+                foreach ($config as $k => &$v) {
+                    if (isset($params[$v['name']])) {
+                        if ($v['type'] == 'array') {
+                            $params[$v['name']] = is_array($params[$v['name']]) ? $params[$v['name']] : (array)json_decode($params[$v['name']], true);
+                            $value = $params[$v['name']];
+                        } else {
+                            $value = is_array($params[$v['name']]) ? implode(',', $params[$v['name']]) : $params[$v['name']];
+                        }
+                        $v['value'] = $value;
+                    }
+                }
+                try {
+                    $addon = get_addon_instance($name);
+                    //插件自定义配置实现逻辑
+                    if (method_exists($addon, 'config')) {
+                        $addon->config($name, $config);
+                    } else {
+                        //更新配置文件
+                        set_addon_fullconfig($name, $config);
+                        Service::refresh();
+                    }
+                } catch (Exception $e) {
+                    $this->error(__($e->getMessage()));
+                }
+                $this->success();
+            }
+            $this->error(__('Parameter %s can not be empty', ''));
+        }
+        $tips = [];
+        $groupList = [];
+        foreach ($config as $index => &$item) {
+            //如果有设置分组
+            if (isset($item['group']) && $item['group']) {
+                if (!in_array($item['group'], $groupList)) {
+                    $groupList["custom" . (count($groupList) + 1)] = $item['group'];
+                }
+            }
+            if ($item['name'] == '__tips__') {
+                $tips = $item;
+                unset($config[$index]);
+            }
+        }
+        $groupList['other'] = '其它';
+        $this->view->assign("groupList", $groupList);
+        $this->view->assign("addon", ['info' => $info, 'config' => $config, 'tips' => $tips]);
+        $configFile = ADDON_PATH . $name . DS . 'config.html';
+        $viewFile = is_file($configFile) ? $configFile : '';
+        return $this->view->fetch($viewFile);
+    }
+
+    /**
+     * 安装
+     */
+    public function install()
+    {
+        $name = $this->request->post("name");
+        $force = (int)$this->request->post("force");
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+
+        $info = [];
+        try {
+            $uid = $this->request->post("uid");
+            $token = $this->request->post("token");
+            $version = $this->request->post("version");
+            $faversion = $this->request->post("faversion");
+            $extend = [
+                'uid'       => $uid,
+                'token'     => $token,
+                'version'   => $version,
+                'faversion' => $faversion
+            ];
+            $info = Service::install($name, $force, $extend);
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()), $e->getCode());
+        }
+        $this->success(__('Install successful'), '', ['addon' => $info]);
+    }
+
+    /**
+     * 卸载
+     */
+    public function uninstall()
+    {
+        $name = $this->request->post("name");
+        $force = (int)$this->request->post("force");
+        $droptables = (int)$this->request->post("droptables");
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+        //只有开启调试且为超级管理员才允许删除相关数据库
+        $tables = [];
+        if ($droptables && Config::get("app_debug") && $this->auth->isSuperAdmin()) {
+            $tables = get_addon_tables($name);
+        }
+        try {
+            Service::uninstall($name, $force);
+            if ($tables) {
+                $prefix = Config::get('database.prefix');
+                //删除插件关联表
+                foreach ($tables as $index => $table) {
+                    //忽略非插件标识的表名
+                    if (!preg_match("/^{$prefix}{$name}/", $table)) {
+                        continue;
+                    }
+                    Db::execute("DROP TABLE IF EXISTS `{$table}`");
+                }
+            }
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        $this->success(__('Uninstall successful'));
+    }
+
+    /**
+     * 禁用启用
+     */
+    public function state()
+    {
+        $name = $this->request->post("name");
+        $action = $this->request->post("action");
+        $force = (int)$this->request->post("force");
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+        try {
+            $action = $action == 'enable' ? $action : 'disable';
+            //调用启用、禁用的方法
+            Service::$action($name, $force);
+            Cache::rm('__menu__');
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        $this->success(__('Operate successful'));
+    }
+
+    /**
+     * 本地上传
+     */
+    public function local()
+    {
+        Config::set('default_return_type', 'json');
+
+        $info = [];
+        $file = $this->request->file('file');
+        try {
+            $uid = $this->request->post("uid");
+            $token = $this->request->post("token");
+            $faversion = $this->request->post("faversion");
+            if (!$uid || !$token) {
+                throw new Exception(__('Please login and try to install'));
+            }
+            $extend = [
+                'uid'       => $uid,
+                'token'     => $token,
+                'faversion' => $faversion
+            ];
+            $info = Service::local($file, $extend);
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        $this->success(__('Offline installed tips'), '', ['addon' => $info]);
+    }
+
+    /**
+     * 更新插件
+     */
+    public function upgrade()
+    {
+        $name = $this->request->post("name");
+        $addonTmpDir = RUNTIME_PATH . 'addons' . DS;
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+        if (!is_dir($addonTmpDir)) {
+            @mkdir($addonTmpDir, 0755, true);
+        }
+
+        $info = [];
+        try {
+            $uid = $this->request->post("uid");
+            $token = $this->request->post("token");
+            $version = $this->request->post("version");
+            $faversion = $this->request->post("faversion");
+            $extend = [
+                'uid'       => $uid,
+                'token'     => $token,
+                'version'   => $version,
+                'faversion' => $faversion
+            ];
+            //调用更新的方法
+            $info = Service::upgrade($name, $extend);
+            Cache::rm('__menu__');
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        $this->success(__('Operate successful'), '', ['addon' => $info]);
+    }
+
+    /**
+     * 测试数据
+     */
+    public function testdata()
+    {
+        $name = $this->request->post("name");
+        if (!$name) {
+            $this->error(__('Parameter %s can not be empty', 'name'));
+        }
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+
+        try {
+            Service::importsql($name, 'testdata.sql');
+        } catch (AddonException $e) {
+            $this->result($e->getData(), $e->getCode(), __($e->getMessage()));
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()), $e->getCode());
+        }
+        $this->success(__('Import successful'), '');
+    }
+
+    /**
+     * 已装插件
+     */
+    public function downloaded()
+    {
+        $offset = (int)$this->request->get("offset");
+        $limit = (int)$this->request->get("limit");
+        $filter = $this->request->get("filter");
+        $search = $this->request->get("search");
+        $search = htmlspecialchars(strip_tags($search));
+        $onlineaddons = $this->getAddonList();
+        $filter = (array)json_decode($filter, true);
+        $addons = get_addon_list();
+        $list = [];
+        foreach ($addons as $k => $v) {
+            if ($search && stripos($v['name'], $search) === false && stripos($v['title'], $search) === false && stripos($v['intro'], $search) === false) {
+                continue;
+            }
+
+            if (isset($onlineaddons[$v['name']])) {
+                $v = array_merge($v, $onlineaddons[$v['name']]);
+                $v['price'] = '-';
+            } else {
+                $v['category_id'] = 0;
+                $v['flag'] = '';
+                $v['banner'] = '';
+                $v['image'] = '';
+                $v['donateimage'] = '';
+                $v['demourl'] = '';
+                $v['price'] = __('None');
+                $v['screenshots'] = [];
+                $v['releaselist'] = [];
+                $v['url'] = addon_url($v['name']);
+                $v['url'] = str_replace($this->request->server('SCRIPT_NAME'), '', $v['url']);
+            }
+            $v['createtime'] = filemtime(ADDON_PATH . $v['name']);
+            if ($filter && isset($filter['category_id']) && is_numeric($filter['category_id']) && $filter['category_id'] != $v['category_id']) {
+                continue;
+            }
+            $list[] = $v;
+        }
+        $total = count($list);
+        if ($limit) {
+            $list = array_slice($list, $offset, $limit);
+        }
+        $result = array("total" => $total, "rows" => $list);
+
+        $callback = $this->request->get('callback') ? "jsonp" : "json";
+        return $callback($result);
+    }
+
+    /**
+     * 检测
+     */
+    public function isbuy()
+    {
+        $name = $this->request->post("name");
+        $uid = $this->request->post("uid");
+        $token = $this->request->post("token");
+        $version = $this->request->post("version");
+        $faversion = $this->request->post("faversion");
+        $extend = [
+            'uid'       => $uid,
+            'token'     => $token,
+            'version'   => $version,
+            'faversion' => $faversion
+        ];
+        try {
+            $result = Service::isBuy($name, $extend);
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        return json($result);
+    }
+
+    /**
+     * 刷新授权
+     */
+    public function authorization()
+    {
+        $params = [
+            'uid'       => $this->request->post('uid'),
+            'token'     => $this->request->post('token'),
+            'faversion' => $this->request->post('faversion'),
+        ];
+        try {
+            Service::authorization($params);
+        } catch (Exception $e) {
+            $this->error(__($e->getMessage()));
+        }
+        $this->success(__('Operate successful'));
+    }
+
+    /**
+     * 获取插件相关表
+     */
+    public function get_table_list()
+    {
+        $name = $this->request->post("name");
+        if (!preg_match("/^[a-zA-Z0-9]+$/", $name)) {
+            $this->error(__('Addon name incorrect'));
+        }
+        $tables = get_addon_tables($name);
+        $prefix = Config::get('database.prefix');
+        foreach ($tables as $index => $table) {
+            //忽略非插件标识的表名
+            if (!preg_match("/^{$prefix}{$name}/", $table)) {
+                unset($tables[$index]);
+            }
+        }
+        $tables = array_values($tables);
+        $this->success('', null, ['tables' => $tables]);
+    }
+
+    protected function getAddonList()
+    {
+        $onlineaddons = Cache::get("onlineaddons");
+        if (!is_array($onlineaddons) && config('fastadmin.api_url')) {
+            $onlineaddons = [];
+            $params = [
+                'uid'       => $this->request->post('uid'),
+                'token'     => $this->request->post('token'),
+                'version'   => config('fastadmin.version'),
+                'faversion' => config('fastadmin.version'),
+            ];
+            $json = [];
+            try {
+                $json = Service::addons($params);
+            } catch (\Exception $e) {
+
+            }
+            $rows = isset($json['rows']) ? $json['rows'] : [];
+            foreach ($rows as $index => $row) {
+                $onlineaddons[$row['name']] = $row;
+            }
+            Cache::set("onlineaddons", $onlineaddons, 600);
+        }
+        return $onlineaddons;
+    }
+
+}

+ 313 - 0
application/admin/controller/Ajax.php

@@ -0,0 +1,313 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+use app\common\exception\UploadException;
+use app\common\library\Upload;
+use fast\Random;
+use think\addons\Service;
+use think\Cache;
+use think\Config;
+use think\Db;
+use think\Lang;
+use think\Response;
+use think\Validate;
+
+/**
+ * Ajax异步请求接口
+ * @internal
+ */
+class Ajax extends Backend
+{
+
+    protected $noNeedLogin = ['lang'];
+    protected $noNeedRight = ['*'];
+    protected $layout = '';
+
+    public function _initialize()
+    {
+        parent::_initialize();
+
+        //设置过滤方法
+        $this->request->filter(['trim', 'strip_tags', 'htmlspecialchars']);
+    }
+
+    /**
+     * 加载语言包
+     */
+    public function lang()
+    {
+
+        $header = ['Content-Type' => 'application/javascript'];
+        if (!config('app_debug')) {
+            $offset = 30 * 60 * 60 * 24; // 缓存一个月
+            $header['Cache-Control'] = 'public';
+            $header['Pragma'] = 'cache';
+            $header['Expires'] = gmdate("D, d M Y H:i:s", time() + $offset) . " GMT";
+        }
+
+        $controllername = input("controllername");
+        //默认只加载了控制器对应的语言名,你还根据控制器名来加载额外的语言包
+        $this->loadlang($controllername);
+        return jsonp(Lang::get(), 200, $header, ['json_encode_param' => JSON_FORCE_OBJECT | JSON_UNESCAPED_UNICODE]);
+    }
+
+    /**
+     * 上传文件
+     */
+    public function upload()
+    {
+        Config::set('default_return_type', 'json');
+        //必须设定cdnurl为空,否则cdnurl函数计算错误
+        Config::set('upload.cdnurl', '');
+        $chunkid = $this->request->post("chunkid");
+        if ($chunkid) {
+            if (!Config::get('upload.chunking')) {
+                $this->error(__('Chunk file disabled'));
+            }
+            $action = $this->request->post("action");
+            $chunkindex = $this->request->post("chunkindex/d");
+            $chunkcount = $this->request->post("chunkcount/d");
+            $filename = $this->request->post("filename");
+            $method = $this->request->method(true);
+            if ($action == 'merge') {
+                $attachment = null;
+                //合并分片文件
+                try {
+                    $upload = new Upload();
+                    $attachment = $upload->merge($chunkid, $chunkcount, $filename);
+                } catch (UploadException $e) {
+                    $this->error($e->getMessage());
+                }
+                $this->success(__('Uploaded successful'), '', ['url' => $attachment->url, 'fullurl' => cdnurl($attachment->url, true)]);
+            } elseif ($method == 'clean') {
+                //删除冗余的分片文件
+                try {
+                    $upload = new Upload();
+                    $upload->clean($chunkid);
+                } catch (UploadException $e) {
+                    $this->error($e->getMessage());
+                }
+                $this->success();
+            } else {
+                //上传分片文件
+                //默认普通上传文件
+                $file = $this->request->file('file');
+                try {
+                    $upload = new Upload($file);
+                    $upload->chunk($chunkid, $chunkindex, $chunkcount);
+                } catch (UploadException $e) {
+                    $this->error($e->getMessage());
+                }
+                $this->success();
+            }
+        } else {
+            $attachment = null;
+            //默认普通上传文件
+            $file = $this->request->file('file');
+            try {
+                $upload = new Upload($file);
+                $attachment = $upload->upload();
+            } catch (UploadException $e) {
+                $this->error($e->getMessage());
+            }
+
+            $this->success(__('Uploaded successful'), '', ['url' => $attachment->url, 'fullurl' => cdnurl($attachment->url, true)]);
+        }
+    }
+
+    /**
+     * 通用排序
+     */
+    public function weigh()
+    {
+        //排序的数组
+        $ids = $this->request->post("ids");
+        //拖动的记录ID
+        $changeid = $this->request->post("changeid");
+        //操作字段
+        $field = $this->request->post("field");
+        //操作的数据表
+        $table = $this->request->post("table");
+        if (!Validate::is($table, "alphaDash")) {
+            $this->error();
+        }
+        //主键
+        $pk = $this->request->post("pk");
+        //排序的方式
+        $orderway = strtolower($this->request->post("orderway", ""));
+        $orderway = $orderway == 'asc' ? 'ASC' : 'DESC';
+        $sour = $weighdata = [];
+        $ids = explode(',', $ids);
+        $prikey = $pk && preg_match("/^[a-z0-9\-_]+$/i", $pk) ? $pk : (Db::name($table)->getPk() ?: 'id');
+        $pid = $this->request->post("pid", "");
+        //限制更新的字段
+        $field = in_array($field, ['weigh']) ? $field : 'weigh';
+
+        // 如果设定了pid的值,此时只匹配满足条件的ID,其它忽略
+        if ($pid !== '') {
+            $hasids = [];
+            $list = Db::name($table)->where($prikey, 'in', $ids)->where('pid', 'in', $pid)->field("{$prikey},pid")->select();
+            foreach ($list as $k => $v) {
+                $hasids[] = $v[$prikey];
+            }
+            $ids = array_values(array_intersect($ids, $hasids));
+        }
+
+        $list = Db::name($table)->field("$prikey,$field")->where($prikey, 'in', $ids)->order($field, $orderway)->select();
+        foreach ($list as $k => $v) {
+            $sour[] = $v[$prikey];
+            $weighdata[$v[$prikey]] = $v[$field];
+        }
+        $position = array_search($changeid, $ids);
+        $desc_id = isset($sour[$position]) ? $sour[$position] : end($sour);    //移动到目标的ID值,取出所处改变前位置的值
+        $sour_id = $changeid;
+        $weighids = array();
+        $temp = array_values(array_diff_assoc($ids, $sour));
+        foreach ($temp as $m => $n) {
+            if ($n == $sour_id) {
+                $offset = $desc_id;
+            } else {
+                if ($sour_id == $temp[0]) {
+                    $offset = isset($temp[$m + 1]) ? $temp[$m + 1] : $sour_id;
+                } else {
+                    $offset = isset($temp[$m - 1]) ? $temp[$m - 1] : $sour_id;
+                }
+            }
+            if (!isset($weighdata[$offset])) {
+                continue;
+            }
+            $weighids[$n] = $weighdata[$offset];
+            Db::name($table)->where($prikey, $n)->update([$field => $weighdata[$offset]]);
+        }
+        $this->success();
+    }
+
+    /**
+     * 清空系统缓存
+     */
+    public function wipecache()
+    {
+        try {
+            $type = $this->request->request("type");
+            switch ($type) {
+                case 'all':
+                    // no break
+                case 'content':
+                    //内容缓存
+                    rmdirs(CACHE_PATH, false);
+                    Cache::clear();
+                    if ($type == 'content') {
+                        break;
+                    }
+                case 'template':
+                    // 模板缓存
+                    rmdirs(TEMP_PATH, false);
+                    if ($type == 'template') {
+                        break;
+                    }
+                case 'addons':
+                    // 插件缓存
+                    Service::refresh();
+                    if ($type == 'addons') {
+                        break;
+                    }
+                case 'browser':
+                    // 浏览器缓存
+                    // 只有生产环境下才修改
+                    if (!config('app_debug')) {
+                        $version = config('site.version');
+                        $newversion = preg_replace_callback("/(.*)\.([0-9]+)\$/", function ($match) {
+                            return $match[1] . '.' . ($match[2] + 1);
+                        }, $version);
+                        if ($newversion && $newversion != $version) {
+                            Db::startTrans();
+                            try {
+                                \app\common\model\Config::where('name', 'version')->update(['value' => $newversion]);
+                                \app\common\model\Config::refreshFile();
+                                Db::commit();
+                            } catch (\Exception $e) {
+                                Db::rollback();
+                                exception($e->getMessage());
+                            }
+                        }
+                    }
+                    if ($type == 'browser') {
+                        break;
+                    }
+            }
+        } catch (\Exception $e) {
+            $this->error($e->getMessage());
+        }
+
+        \think\Hook::listen("wipecache_after");
+        $this->success();
+    }
+
+    /**
+     * 读取分类数据,联动列表
+     */
+    public function category()
+    {
+        $type = $this->request->get('type', '');
+        $pid = $this->request->get('pid', '');
+        $where = ['status' => 'normal'];
+        $categorylist = null;
+        if ($pid || $pid === '0') {
+            $where['pid'] = $pid;
+        }
+        if ($type) {
+            $where['type'] = $type;
+        }
+
+        $categorylist = Db::name('category')->where($where)->field('id as value,name')->order('weigh desc,id desc')->select();
+
+        $this->success('', '', $categorylist);
+    }
+
+    /**
+     * 读取省市区数据,联动列表
+     */
+    public function area()
+    {
+        $params = $this->request->get("row/a");
+        if (!empty($params)) {
+            $province = isset($params['province']) ? $params['province'] : '';
+            $city = isset($params['city']) ? $params['city'] : '';
+        } else {
+            $province = $this->request->get('province', '');
+            $city = $this->request->get('city', '');
+        }
+        $where = ['pid' => 0, 'level' => 1];
+        $provincelist = null;
+        if ($province !== '') {
+            $where['pid'] = $province;
+            $where['level'] = 2;
+            if ($city !== '') {
+                $where['pid'] = $city;
+                $where['level'] = 3;
+            }
+        }
+        $provincelist = Db::name('area')->where($where)->field('id as value,name')->select();
+        $this->success('', '', $provincelist);
+    }
+
+    /**
+     * 生成后缀图标
+     */
+    public function icon()
+    {
+        $suffix = $this->request->request("suffix");
+        $suffix = $suffix ? $suffix : "FILE";
+        $data = build_suffix_image($suffix);
+        $header = ['Content-Type' => 'image/svg+xml'];
+        $offset = 30 * 60 * 60 * 24; // 缓存一个月
+        $header['Cache-Control'] = 'public';
+        $header['Pragma'] = 'cache';
+        $header['Expires'] = gmdate("D, d M Y H:i:s", time() + $offset) . " GMT";
+        $response = Response::create($data, '', 200, $header);
+        return $response;
+    }
+
+}

+ 158 - 0
application/admin/controller/Category.php

@@ -0,0 +1,158 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+use app\common\model\Category as CategoryModel;
+use fast\Tree;
+
+/**
+ * 分类管理
+ *
+ * @icon   fa fa-list
+ * @remark 用于管理网站的所有分类,分类可进行无限级分类,分类类型请在常规管理->系统配置->字典配置中添加
+ */
+class Category extends Backend
+{
+
+    /**
+     * @var \app\common\model\Category
+     */
+    protected $model = null;
+    protected $categorylist = [];
+    protected $noNeedRight = ['selectpage'];
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = model('app\common\model\Category');
+
+        $tree = Tree::instance();
+        $tree->init(collection($this->model->order('weigh desc,id desc')->select())->toArray(), 'pid');
+        $this->categorylist = $tree->getTreeList($tree->getTreeArray(0), 'name');
+        $categorydata = [0 => ['type' => 'all', 'name' => __('None')]];
+        foreach ($this->categorylist as $k => $v) {
+            $categorydata[$v['id']] = $v;
+        }
+        $typeList = CategoryModel::getTypeList();
+        $this->view->assign("flagList", $this->model->getFlagList());
+        $this->view->assign("typeList", $typeList);
+        $this->view->assign("parentList", $categorydata);
+        $this->assignconfig('typeList', $typeList);
+    }
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //设置过滤方法
+        $this->request->filter(['strip_tags']);
+        if ($this->request->isAjax()) {
+            $search = $this->request->request("search");
+            $type = $this->request->request("type");
+
+            //构造父类select列表选项数据
+            $list = [];
+
+            foreach ($this->categorylist as $k => $v) {
+                if ($search) {
+                    if ($v['type'] == $type && stripos($v['name'], $search) !== false || stripos($v['nickname'], $search) !== false) {
+                        if ($type == "all" || $type == null) {
+                            $list = $this->categorylist;
+                        } else {
+                            $list[] = $v;
+                        }
+                    }
+                } else {
+                    if ($type == "all" || $type == null) {
+                        $list = $this->categorylist;
+                    } elseif ($v['type'] == $type) {
+                        $list[] = $v;
+                    }
+                }
+            }
+
+            $total = count($list);
+            $result = array("total" => $total, "rows" => $list);
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }
+
+    /**
+     * 添加
+     */
+    public function add()
+    {
+        if ($this->request->isPost()) {
+            $this->token();
+        }
+        return parent::add();
+    }
+
+    /**
+     * 编辑
+     */
+    public function edit($ids = null)
+    {
+        $row = $this->model->get($ids);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+        $adminIds = $this->getDataLimitAdminIds();
+        if (is_array($adminIds)) {
+            if (!in_array($row[$this->dataLimitField], $adminIds)) {
+                $this->error(__('You have no permission'));
+            }
+        }
+        if ($this->request->isPost()) {
+            $this->token();
+            $params = $this->request->post("row/a");
+            if ($params) {
+                $params = $this->preExcludeFields($params);
+
+                if ($params['pid'] != $row['pid']) {
+                    $childrenIds = Tree::instance()->init(collection(\app\common\model\Category::select())->toArray())->getChildrenIds($row['id'], true);
+                    if (in_array($params['pid'], $childrenIds)) {
+                        $this->error(__('Can not change the parent to child or itself'));
+                    }
+                }
+
+                try {
+                    //是否采用模型验证
+                    if ($this->modelValidate) {
+                        $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
+                        $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate;
+                        $row->validate($validate);
+                    }
+                    $result = $row->allowField(true)->save($params);
+                    if ($result !== false) {
+                        $this->success();
+                    } else {
+                        $this->error($row->getError());
+                    }
+                } catch (\think\exception\PDOException $e) {
+                    $this->error($e->getMessage());
+                } catch (\think\Exception $e) {
+                    $this->error($e->getMessage());
+                }
+            }
+            $this->error(__('Parameter %s can not be empty', ''));
+        }
+        $this->view->assign("row", $row);
+        return $this->view->fetch();
+    }
+
+
+    /**
+     * Selectpage搜索
+     *
+     * @internal
+     */
+    public function selectpage()
+    {
+        return parent::selectpage();
+    }
+}

+ 236 - 0
application/admin/controller/Command.php

@@ -0,0 +1,236 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+use think\Config;
+use think\console\Input;
+use think\Db;
+use think\Exception;
+
+/**
+ * 在线命令管理
+ *
+ * @icon fa fa-circle-o
+ */
+class Command extends Backend
+{
+
+    /**
+     * Command模型对象
+     */
+    protected $model = null;
+    protected $noNeedRight = ['get_controller_list', 'get_field_list'];
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = model('Command');
+        $this->view->assign("statusList", $this->model->getStatusList());
+    }
+
+    /**
+     * 添加
+     */
+    public function add()
+    {
+
+        $tableList = [];
+        $list = \think\Db::query("SHOW TABLES");
+        foreach ($list as $key => $row) {
+            $tableList[reset($row)] = reset($row);
+        }
+
+        $this->view->assign("tableList", $tableList);
+        return $this->view->fetch();
+    }
+
+    /**
+     * 获取字段列表
+     * @internal
+     */
+    public function get_field_list()
+    {
+        $dbname = Config::get('database.database');
+        $prefix = Config::get('database.prefix');
+        $table = $this->request->request('table');
+        //从数据库中获取表字段信息
+        $sql = "SELECT * FROM `information_schema`.`columns` "
+            . "WHERE TABLE_SCHEMA = ? AND table_name = ? "
+            . "ORDER BY ORDINAL_POSITION";
+        //加载主表的列
+        $columnList = Db::query($sql, [$dbname, $table]);
+        $fieldlist = [];
+        foreach ($columnList as $index => $item) {
+            $fieldlist[] = $item['COLUMN_NAME'];
+        }
+        $this->success("", null, ['fieldlist' => $fieldlist]);
+    }
+
+    /**
+     * 获取控制器列表
+     * @internal
+     */
+    public function get_controller_list()
+    {
+        //搜索关键词,客户端输入以空格分开,这里接收为数组
+        $word = (array)$this->request->request("q_word/a");
+        $word = implode('', $word);
+
+        $adminPath = dirname(__DIR__) . DS;
+        $controllerDir = $adminPath . 'controller' . DS;
+        $files = new \RecursiveIteratorIterator(
+            new \RecursiveDirectoryIterator($controllerDir), \RecursiveIteratorIterator::LEAVES_ONLY
+        );
+        $list = [];
+        foreach ($files as $name => $file) {
+            if (!$file->isDir()) {
+                $filePath = $file->getRealPath();
+                $name = str_replace($controllerDir, '', $filePath);
+                $name = str_replace(DS, "/", $name);
+                if (!preg_match("/(.*)\.php\$/", $name)) {
+                    continue;
+                }
+                if (!$word || stripos($name, $word) !== false) {
+                    $list[] = ['id' => $name, 'name' => $name];
+                }
+            }
+        }
+        $pageNumber = $this->request->request("pageNumber");
+        $pageSize = $this->request->request("pageSize");
+        return json(['list' => array_slice($list, ($pageNumber - 1) * $pageSize, $pageSize), 'total' => count($list)]);
+    }
+
+    /**
+     * 详情
+     */
+    public function detail($ids)
+    {
+        $row = $this->model->get($ids);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+        $this->view->assign("row", $row);
+        return $this->view->fetch();
+    }
+
+    /**
+     * 执行
+     */
+    public function execute($ids)
+    {
+        $row = $this->model->get($ids);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+        $result = $this->doexecute($row['type'], json_decode($row['params'], true));
+        $this->success("", null, ['result' => $result]);
+    }
+
+    /**
+     * 执行命令
+     */
+    public function command($action = '')
+    {
+        $commandtype = $this->request->request("commandtype");
+        $params = $this->request->request();
+        $allowfields = [
+            'crud' => 'table,controller,model,fields,force,local,delete,menu',
+            'menu' => 'controller,delete',
+            'min'  => 'module,resource,optimize',
+            'api'  => 'url,module,output,template,force,title,author,class,language',
+        ];
+        $argv = [];
+        $allowfields = isset($allowfields[$commandtype]) ? explode(',', $allowfields[$commandtype]) : [];
+        $allowfields = array_filter(array_intersect_key($params, array_flip($allowfields)));
+        if (isset($params['local']) && !$params['local']) {
+            $allowfields['local'] = $params['local'];
+        } else {
+            unset($allowfields['local']);
+        }
+        foreach ($allowfields as $key => $param) {
+            $argv[] = "--{$key}=" . (is_array($param) ? implode(',', $param) : $param);
+        }
+        if ($commandtype == 'crud') {
+            $extend = 'setcheckboxsuffix,enumradiosuffix,imagefield,filefield,intdatesuffix,switchsuffix,citysuffix,selectpagesuffix,selectpagessuffix,ignorefields,sortfield,editorsuffix,headingfilterfield';
+            $extendArr = explode(',', $extend);
+            foreach ($params as $index => $item) {
+                if (in_array($index, $extendArr)) {
+                    foreach (explode(',', $item) as $key => $value) {
+                        if ($value) {
+                            $argv[] = "--{$index}={$value}";
+                        }
+                    }
+                }
+            }
+            $isrelation = (int)$this->request->request('isrelation');
+            if ($isrelation && isset($params['relation'])) {
+                foreach ($params['relation'] as $index => $relation) {
+                    foreach ($relation as $key => $value) {
+                        $argv[] = "--{$key}=" . (is_array($value) ? implode(',', $value) : $value);
+                    }
+                }
+            }
+        } else {
+            if ($commandtype == 'menu') {
+                if (isset($params['allcontroller']) && $params['allcontroller']) {
+                    $argv[] = "--controller=all-controller";
+                } else {
+                    foreach (explode(',', $params['controllerfile']) as $index => $param) {
+                        if ($param) {
+                            $argv[] = "--controller=" . substr($param, 0, -4);
+                        }
+                    }
+                }
+            } else {
+                if ($commandtype == 'min') {
+
+                } else {
+                    if ($commandtype == 'api') {
+
+                    } else {
+
+                    }
+                }
+            }
+        }
+        if ($action == 'execute') {
+            $result = $this->doexecute($commandtype, $argv);
+            $this->success("", null, ['result' => $result]);
+        } else {
+            $this->success("", null, ['command' => "php think {$commandtype} " . implode(' ', $argv)]);
+        }
+
+        return;
+    }
+
+    protected function doexecute($commandtype, $argv)
+    {
+        $commandName = "\\app\\admin\\command\\" . ucfirst($commandtype);
+        $input = new Input($argv);
+        $output = new \addons\command\library\Output();
+        $command = new $commandName($commandtype);
+        $data = [
+            'type'        => $commandtype,
+            'params'      => json_encode($argv),
+            'command'     => "php think {$commandtype} " . implode(' ', $argv),
+            'executetime' => time(),
+        ];
+        $this->model->save($data);
+        try {
+            $command->run($input, $output);
+            $result = implode("\n", $output->getMessage());
+            $this->model->status = 'successed';
+        } catch (Exception $e) {
+            $result = implode("\n", $output->getMessage()) . "\n";
+            $result .= $e->getMessage();
+            $this->model->status = 'failured';
+        }
+        $result = trim($result);
+        $this->model->content = $result;
+        $this->model->save();
+        return $result;
+    }
+
+
+}

+ 71 - 0
application/admin/controller/Company.php

@@ -0,0 +1,71 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 关于我们
+ *
+ * @icon fa fa-circle-o
+ */
+class Company extends Backend
+{
+
+    /**
+     * Company模型对象
+     * @var \app\admin\model\Company
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Company;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //当前是否为关联查询
+        $this->relationSearch = true;
+        //设置过滤方法
+        $this->request->filter(['strip_tags', 'trim']);
+        if ($this->request->isAjax()) {
+            //如果发送的来源是Selectpage,则转发到Selectpage
+            if ($this->request->request('keyField')) {
+                return $this->selectpage();
+            }
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+
+            $list = $this->model
+                    ->with(['type'])
+                    ->where($where)
+                    ->order($sort, $order)
+                    ->paginate($limit);
+
+            foreach ($list as $row) {
+                
+                $row->getRelation('type')->visible(['name']);
+            }
+
+            $result = array("total" => $list->total(), "rows" => $list->items());
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }
+
+}

+ 37 - 0
application/admin/controller/Companytype.php

@@ -0,0 +1,37 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 关于我们类型
+ *
+ * @icon fa fa-circle-o
+ */
+class Companytype extends Backend
+{
+
+    /**
+     * Companytype模型对象
+     * @var \app\admin\model\Companytype
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Companytype;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+}

+ 84 - 0
application/admin/controller/Dashboard.php

@@ -0,0 +1,84 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\admin\model\Admin;
+use app\admin\model\User;
+use app\common\controller\Backend;
+use app\common\model\Attachment;
+use fast\Date;
+use think\Db;
+
+/**
+ * 控制台
+ *
+ * @icon   fa fa-dashboard
+ * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
+ */
+class Dashboard extends Backend
+{
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        try {
+            \think\Db::execute("SET @@sql_mode='';");
+        } catch (\Exception $e) {
+
+        }
+        $column = [];
+        $starttime = Date::unixtime('day', -6);
+        $endtime = Date::unixtime('day', 0, 'end');
+        $joinlist = Db("user")->where('jointime', 'between time', [$starttime, $endtime])
+            ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
+            ->group('join_date')
+            ->select();
+        for ($time = $starttime; $time <= $endtime;) {
+            $column[] = date("Y-m-d", $time);
+            $time += 86400;
+        }
+        $userlist = array_fill_keys($column, 0);
+        foreach ($joinlist as $k => $v) {
+            $userlist[$v['join_date']] = $v['nums'];
+        }
+
+        $dbTableList = Db::query("SHOW TABLE STATUS");
+        $addonList = get_addon_list();
+        $totalworkingaddon = 0;
+        $totaladdon = count($addonList);
+        foreach ($addonList as $index => $item) {
+            if ($item['state']) {
+                $totalworkingaddon += 1;
+            }
+        }
+        $this->view->assign([
+            'totaluser'         => User::count(),
+            'totaladdon'        => $totaladdon,
+            'totaladmin'        => Admin::count(),
+            'totalcategory'     => \app\common\model\Category::count(),
+            'todayusersignup'   => User::whereTime('jointime', 'today')->count(),
+            'todayuserlogin'    => User::whereTime('logintime', 'today')->count(),
+            'sevendau'          => User::whereTime('jointime|logintime|prevtime', '-7 days')->count(),
+            'thirtydau'         => User::whereTime('jointime|logintime|prevtime', '-30 days')->count(),
+            'threednu'          => User::whereTime('jointime', '-3 days')->count(),
+            'sevendnu'          => User::whereTime('jointime', '-7 days')->count(),
+            'dbtablenums'       => count($dbTableList),
+            'dbsize'            => array_sum(array_map(function ($item) {
+                return $item['Data_length'] + $item['Index_length'];
+            }, $dbTableList)),
+            'totalworkingaddon' => $totalworkingaddon,
+            'attachmentnums'    => Attachment::count(),
+            'attachmentsize'    => Attachment::sum('filesize'),
+            'picturenums'       => Attachment::where('mimetype', 'like', 'image/%')->count(),
+            'picturesize'       => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
+        ]);
+
+        $this->assignconfig('column', array_keys($userlist));
+        $this->assignconfig('userdata', array_values($userlist));
+
+        return $this->view->fetch();
+    }
+
+}

+ 138 - 0
application/admin/controller/Index.php

@@ -0,0 +1,138 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\admin\model\AdminLog;
+use app\common\controller\Backend;
+use think\Config;
+use think\Hook;
+use think\Session;
+use think\Validate;
+
+/**
+ * 后台首页
+ * @internal
+ */
+class Index extends Backend
+{
+
+    protected $noNeedLogin = ['login'];
+    protected $noNeedRight = ['index', 'logout'];
+    protected $layout = '';
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        //移除HTML标签
+        $this->request->filter('trim,strip_tags,htmlspecialchars');
+    }
+
+    /**
+     * 后台首页
+     */
+    public function index()
+    {
+        $cookieArr = ['adminskin' => "/^skin\-([a-z\-]+)\$/i", 'multiplenav' => "/^(0|1)\$/", 'multipletab' => "/^(0|1)\$/", 'show_submenu' => "/^(0|1)\$/"];
+        foreach ($cookieArr as $key => $regex) {
+            $cookieValue = $this->request->cookie($key);
+            if (!is_null($cookieValue) && preg_match($regex, $cookieValue)) {
+                config('fastadmin.' . $key, $cookieValue);
+            }
+        }
+        //左侧菜单
+        list($menulist, $navlist, $fixedmenu, $referermenu) = $this->auth->getSidebar([
+            'dashboard' => 'hot',
+            'addon'     => ['new', 'red', 'badge'],
+            'auth/rule' => __('Menu'),
+            'general'   => ['new', 'purple'],
+        ], $this->view->site['fixedpage']);
+        $action = $this->request->request('action');
+        if ($this->request->isPost()) {
+            if ($action == 'refreshmenu') {
+                $this->success('', null, ['menulist' => $menulist, 'navlist' => $navlist]);
+            }
+        }
+        $this->assignconfig('cookie', ['prefix' => config('cookie.prefix')]);
+        $this->view->assign('menulist', $menulist);
+        $this->view->assign('navlist', $navlist);
+        $this->view->assign('fixedmenu', $fixedmenu);
+        $this->view->assign('referermenu', $referermenu);
+        $this->view->assign('title', __('Home'));
+        return $this->view->fetch();
+    }
+
+    /**
+     * 管理员登录
+     */
+    public function login()
+    {
+        $url = $this->request->get('url', 'index/index');
+        if ($this->auth->isLogin()) {
+            $this->success(__("You've logged in, do not login again"), $url);
+        }
+        if ($this->request->isPost()) {
+            $username = $this->request->post('username');
+            $password = $this->request->post('password');
+            $keeplogin = $this->request->post('keeplogin');
+            $token = $this->request->post('__token__');
+            $rule = [
+                'username'  => 'require|length:3,30',
+                'password'  => 'require|length:3,30',
+                '__token__' => 'require|token',
+            ];
+            $data = [
+                'username'  => $username,
+                'password'  => $password,
+                '__token__' => $token,
+            ];
+            if (Config::get('fastadmin.login_captcha')) {
+                $rule['captcha'] = 'require|captcha';
+                $data['captcha'] = $this->request->post('captcha');
+            }
+            $validate = new Validate($rule, [], ['username' => __('Username'), 'password' => __('Password'), 'captcha' => __('Captcha')]);
+            $result = $validate->check($data);
+            if (!$result) {
+                $this->error($validate->getError(), $url, ['token' => $this->request->token()]);
+            }
+            AdminLog::setTitle(__('Login'));
+            $result = $this->auth->login($username, $password, $keeplogin ? 86400 : 0);
+            if ($result === true) {
+                Hook::listen("admin_login_after", $this->request);
+                $this->success(__('Login successful'), $url, ['url' => $url, 'id' => $this->auth->id, 'username' => $username, 'avatar' => $this->auth->avatar]);
+            } else {
+                $msg = $this->auth->getError();
+                $msg = $msg ? $msg : __('Username or password is incorrect');
+                $this->error($msg, $url, ['token' => $this->request->token()]);
+            }
+        }
+
+        // 根据客户端的cookie,判断是否可以自动登录
+        if ($this->auth->autologin()) {
+            Session::delete("referer");
+            $this->redirect($url);
+        }
+        $background = Config::get('fastadmin.login_background');
+        $background = $background ? (stripos($background, 'http') === 0 ? $background : config('site.cdnurl') . $background) : '';
+        $this->view->assign('background', $background);
+        $this->view->assign('title', __('Login'));
+        Hook::listen("admin_login_init", $this->request);
+        return $this->view->fetch();
+    }
+
+    /**
+     * 退出登录
+     */
+    public function logout()
+    {
+        if ($this->request->isPost()) {
+            $this->auth->logout();
+            Hook::listen("admin_logout_after", $this->request);
+            $this->success(__('Logout successful'), 'index/login');
+        }
+        $html = "<form id='logout_submit' name='logout_submit' action='' method='post'>" . token() . "<input type='submit' value='ok' style='display:none;'></form>";
+        $html .= "<script>document.forms['logout_submit'].submit();</script>";
+
+        return $html;
+    }
+
+}

+ 71 - 0
application/admin/controller/Industry.php

@@ -0,0 +1,71 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 产业中心
+ *
+ * @icon fa fa-industry
+ */
+class Industry extends Backend
+{
+
+    /**
+     * Industry模型对象
+     * @var \app\admin\model\Industry
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Industry;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //当前是否为关联查询
+        $this->relationSearch = true;
+        //设置过滤方法
+        $this->request->filter(['strip_tags', 'trim']);
+        if ($this->request->isAjax()) {
+            //如果发送的来源是Selectpage,则转发到Selectpage
+            if ($this->request->request('keyField')) {
+                return $this->selectpage();
+            }
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+
+            $list = $this->model
+                    ->with(['type'])
+                    ->where($where)
+                    ->order($sort, $order)
+                    ->paginate($limit);
+
+            foreach ($list as $row) {
+                
+                $row->getRelation('type')->visible(['name']);
+            }
+
+            $result = array("total" => $list->total(), "rows" => $list->items());
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }
+
+}

+ 37 - 0
application/admin/controller/Industrytype.php

@@ -0,0 +1,37 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 产业类型
+ *
+ * @icon fa fa-circle-o
+ */
+class Industrytype extends Backend
+{
+
+    /**
+     * Industrytype模型对象
+     * @var \app\admin\model\Industrytype
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Industrytype;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+}

+ 71 - 0
application/admin/controller/News.php

@@ -0,0 +1,71 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 热点聚焦
+ *
+ * @icon fa fa-circle-o
+ */
+class News extends Backend
+{
+
+    /**
+     * News模型对象
+     * @var \app\admin\model\News
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\News;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //当前是否为关联查询
+        $this->relationSearch = true;
+        //设置过滤方法
+        $this->request->filter(['strip_tags', 'trim']);
+        if ($this->request->isAjax()) {
+            //如果发送的来源是Selectpage,则转发到Selectpage
+            if ($this->request->request('keyField')) {
+                return $this->selectpage();
+            }
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+
+            $list = $this->model
+                    ->with(['type'])
+                    ->where($where)
+                    ->order($sort, $order)
+                    ->paginate($limit);
+
+            foreach ($list as $row) {
+                
+                $row->getRelation('type')->visible(['name']);
+            }
+
+            $result = array("total" => $list->total(), "rows" => $list->items());
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }
+
+}

+ 37 - 0
application/admin/controller/Newstype.php

@@ -0,0 +1,37 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 热点聚焦类型
+ *
+ * @icon fa fa-circle-o
+ */
+class Newstype extends Backend
+{
+
+    /**
+     * Newstype模型对象
+     * @var \app\admin\model\Newstype
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Newstype;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+}

+ 71 - 0
application/admin/controller/Product.php

@@ -0,0 +1,71 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 产品中心
+ *
+ * @icon fa fa-circle-o
+ */
+class Product extends Backend
+{
+
+    /**
+     * Product模型对象
+     * @var \app\admin\model\Product
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Product;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+    /**
+     * 查看
+     */
+    public function index()
+    {
+        //当前是否为关联查询
+        $this->relationSearch = true;
+        //设置过滤方法
+        $this->request->filter(['strip_tags', 'trim']);
+        if ($this->request->isAjax()) {
+            //如果发送的来源是Selectpage,则转发到Selectpage
+            if ($this->request->request('keyField')) {
+                return $this->selectpage();
+            }
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+
+            $list = $this->model
+                    ->with(['type'])
+                    ->where($where)
+                    ->order($sort, $order)
+                    ->paginate($limit);
+
+            foreach ($list as $row) {
+                
+                $row->getRelation('type')->visible(['name']);
+            }
+
+            $result = array("total" => $list->total(), "rows" => $list->items());
+
+            return json($result);
+        }
+        return $this->view->fetch();
+    }
+
+}

+ 37 - 0
application/admin/controller/Productmod.php

@@ -0,0 +1,37 @@
+<?php
+
+namespace app\admin\controller;
+
+use app\common\controller\Backend;
+
+/**
+ * 首页产品信息
+ *
+ * @icon fa fa-circle-o
+ */
+class Productmod extends Backend
+{
+
+    /**
+     * Productmod模型对象
+     * @var \app\admin\model\Productmod
+     */
+    protected $model = null;
+
+    public function _initialize()
+    {
+        parent::_initialize();
+        $this->model = new \app\admin\model\Productmod;
+
+    }
+
+
+
+    /**
+     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
+     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
+     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
+     */
+
+
+}

Some files were not shown because too many files changed in this diff