PostSQL编写经验(利用坐标值,创建空间要素字段)

1、创建数据表station,包含geometry字段:

CREATE TABLE "public"."station" (
  "name" varchar(20) COLLATE "pg_catalog"."default",
  "lat" float4,
  "lon" float4,
  "geometry" "public"."geometry",
  "code" varchar(4) COLLATE "pg_catalog"."default" NOT NULL,
  CONSTRAINT "station_pkey" PRIMARY KEY ("code")
)

2、程序创建表格记录时,应用SQL语句:

sSQL = "INSERT INTO station(lat, lon, geometry) " + \ 
       "VALUES(%f,%f, ST_GeomFromText('POINT(%f %f)', 4326))" \
       % (lat, lon, lon, lat)

代码用于python,注意最后创建点数据的经纬数值输入采用的是:(lon lat) 的方式

参数:4326,表示的是地理投影坐标系统,代表地理坐标系中的GCS_WGS_1984

3、如需增补空间坐标值,采用SQL语句:update

update station as a set geometry = 
        ST_GeomFromText('POINT('||(select lon || ' ' || lat from station 
        where id =a.id)||')', 4326) 

该语句可直接在Navicat for PostgreSQL中运行。

4、考虑跨越日经线的空间要素创建

跨越日经线,空间坐标发生变化,Lon值从179跳跃至-179,采取Line绘制的图形,会出现360度的连线,形成乱线。此时需采取多线方式创建空间要素,Lon值同正负的生成一条线段,多个线段组成一个空间要素MULTILINSTING,以确保使用同一属性数据,为一个空间实体。

        #########
        #lat、lon为点集数组
            
            lat1 = lat[0]
            lon1 = lon[0]
            pt_str = '(' + str(lon[0]) + ' ' + str(lat[0])
            iLen = len(lat)
            i = 1
            while(i< iLen):
                pt_str1 = str(lon[i]) + ' ' + str(lat[i])
                if  lon1 * lon[i] > 0:               #同为正负值,说明前后两点处于日经线同侧
                    pt_str += ',' + pt_str1
                else:
                    pt_str += '),(' + pt_str1
                lon1 = lon[i]
                i += 1
                                
            pt_str += ')'
            
            linestring = 'MULTILINESTRING('
            linestring = linestring + pt_str +')'
            
            sSQL = 'INSERT INTO line_table(code, StartTime,EndTime, geometry) ' + \
                   'VALUES (\'%s\', \'%s\', \'%s\', ST_GeomFromText(\'%s\', 4326))' \
                   % (code, start_time, end_time, linestring)
                   
            pgHelp.insert(sSQL)

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值