背景:
● Geometry:投影坐标系,平面坐标系,笛卡尔坐标系,Srid默认2369,基于平面直角坐标系,在该坐标系内计算出的最短路径是一条直线,计算简单,执行起来更快,但是相对于地球球体表面的数据不准确。
● Geogrephy:地理坐标系,大地坐标系,经纬坐标系,球面坐标系,Srid默认4326(服务端存储一般用4326),基于球面坐标系,在该坐标系内计算出的最短路径是一段圆弧,该数据类型的计算考虑了地球是一个球型,计算复杂,执行时间相对慢,但是计算结果相对精确。
● Srid:全称Spatial Reference System Identifier,定义了地球海平面,球心位置,球心偏移,地球形状等信息,不指定SRID默认为0。
● PostGis的地理数据类型:Geometry和Geogrephy
● YashanDB的地理数据类型:Geometry,但是兼顾PostGis两种坐标系,通过指定Srid来实现两种数据类型的转换
yasd**b**兼容示例:
在**yasdb中没有函数st_geogfromtext,postGis存在st_geogfromtext函数,yasdb可通过st_geomfromtext函数指定SRID**的方式兼容
● PostGis:st_geogfromtext('POLYGON ((114.01758862581613 22.626209213735862, 114.01758862581613 22.622079565683535, 114.02268482294346 22.622079565683535, 114.02268482294346 22.626209213735862, 114.01758862581613 22.626209213735862))')
● YashanDB:st_geomfromtext('POLYGON ((114.01758862581613 22.626209213735862, 114.01758862581613 22.622079565683535, 114.02268482294346 22.622079565683535, 114.02268482294346 22.626209213735862, 114.01758862581613 22.626209213735862))',4326)
PostGi**s的ST_Distance(geometry A, geometry B)和**ST_DistanceSphere(geometry A, geometry B)
● PostGis的ST_Distance函数返回的是笛卡尔坐标系的直线距离,ST_DistanceSphere返回的是球面坐标系的圆弧距离
● YashanDB目前支持ST_Distance函数,暂不支持ST_DistanceSphere函数,但是YashanDB的ST_Distance函数可以根据SRID自动识别需要计算的是笛卡尔坐标系下的距离,还是基于地理坐标系的圆弧距离,在YashanDB下计算圆弧距离用的是椭球坐标系而不是球面坐标系,在相对带来一些性能损失的情况下,比postGis的球面坐标系的计算方式更精确。
在使**用st_distance函数计算两个地理位置距离的操作中,同一条sql语句在pgsql和yasdb上计算的结果不一致:**
YashanD**B**:
PostGi**s**:
主要原因:
pgsql不根据SRID来区分经纬度还是投影坐标,需要用对应的函数显式声明,GeomFromText生成的就是geometry,GeogFromText生成的就是geography,否则pgsql会按照投影坐标系来计算两地之间的直线距离,而不是弧度距离,而yasdb是根据SRID来区分是geometry还是geography的。
改写方式:
pgsql需要显式使用geogfromtext函数来申明是一个球面坐标参数。
select st\_distance(st\_geogfromtext('POLYGON ((113.92505953616575 22.574317714342442, 113.89123260989561 22.574317714342442, 113.89123260989561 22.55111425204862, 113.92505953616575 22.55111425204862, 113.92505953616575 22.574317714342442))'), st\_geogfromtext('POLYGON ((113.87828681559085 22.55245916933376, 113.87828681559085 22.54723397504624, 113.88905632391055 22.54723397504624, 113.88905632391055 22.55245916933376, 113.87828681559085 22.55245916933376))')) as dual;
AI 代码解读
改写后: