arcpy应用之python脚本生成矢量表并注册到空间数据库和生成空间索引

      在实际工作中,经常会用到在数据库里将普通的数据表生成矢量表,然后在ARCMAP里发布服务。生成矢量表后,需要在ARCMAP里手动注册到空间数据库和生成空间索引。有时候会忘记以上两个步骤,虽然不会对发布服务造成影响,数据量小的时候还好,当数据量达到几十万甚至上百万时,不管是做数据分析,如空间连接,缓冲区等,还是前端展示,都会非常缓慢。所以当我们用SQL生成矢量表时,要注册到空间数据库和生成空间索引,这都是非常必要的。

在ARCMAP里注册到空间数据库和有无索引的区别:

       下面用一个python小脚本实现普通数据表生成矢量表并自动注册到数据库和生成空间索引:

# - * - coding: utf-8 -
import arcpy
import pyodbc

##连接数据库
#数据库类型:DRIVER, 数据库IP:SERVER, 数据库名称:DATABASE, 账号:UID, 密码:PWD
dbConn = pyodbc.connect('DRIVER={SQL Server};SERVER=100.201.126.45;DATABASE=GISDB;UID=gis;PWD=Gisadmin123')
cursor = dbConn.cursor()

#生成矢量表sql语句
sql = "select cast (ROW_NUMBER ( )  OVER ( order by LON) as int) OBJECTID, *, geometry::Point(LON,LAT,4326) shape"
sql += " into GIS_TEST_POINTS from GIS_POIS"
#执行sql并提交
cursor.execute(sql)
dbConn.commit()
#关闭数据库连接
dbConn.close()

##工作空间
sde = "C:\\Users\\dengyuchen\\AppData\Roaming\\ESRI\Desktop10.5\\ArcCatalog\\连接到 100.201.126.45.sde"
inFeature = sde + "\\" + GIS_TEST_POINTS
#注册空间数据库
arcpy.RegisterWithGeodatabase_management(inFeature)
#生成空间索引
arcpy.AddSpatialIndex_management(inFeature,0,0,0)

然后我们在ARCMAP的空间数据库里查看GIS_TEST_POINTS属性可以看到:

说明该表已经成功注册到空间数据库并生成空间索引。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值