PostgresqlAndPostGis

Postgresql&PostGis

问题及解决方法

关于postGIS没有template_postgis模版的问题解决

// 1、建立普通数据库
  create database xx;
  
// 2、然后输入官网给的这几条添加扩展语句(官网可找到):
-- Enable PostGIS (includes raster)
CREATE EXTENSION postgis;
-- Enable Topology
CREATE EXTENSION postgis_topology;
-- Enable PostGIS Advanced 3D 
-- and other geoprocessing algorithms
-- sfcgal not available with all distributions
CREATE EXTENSION postgis_sfcgal;
-- fuzzy matching needed for Tiger
CREATE EXTENSION fuzzystrmatch;
-- rule based standardizer
CREATE EXTENSION address_standardizer;
-- example rule data set
CREATE EXTENSION address_standardizer_data_us;
-- Enable US Tiger Geocoder
CREATE EXTENSION postgis_tiger_geocoder;

关于PostGresql中没有postgis函数问题

create extension postgis	// postgis 相关函数

相关函数的使用

二进制geometry转geojson

select st_asgeojson(the_geom) from cities

geojson转二进制geometry

select st_geomfromgeojson('{"type":"Point","coordinates":[27.91162491,-33.01529]}')

将二进制的geometry格式的转换成 4326(经纬度)的格式

update test3 set geom = st_setsrid(geom,4326)

将wkt转成geometry

SELECT   ST_GeomFromText(wkt)  from cities

创建空间索引

create index idx_test_shenz on test_shenz(geom) using gist

将geometry转换成wkt格式:

select st_astext(geometry) from cities limit 3;

将数据库中的经纬度转为geometry格式

// ALTER TABLE ajxx ADD geom geometry;   
update ajxx set geom=st_geomfromtext('Point('||dqjd||' '||dqwd||')',4326) // 经度/纬度

插入数据返回Id

insert into point(pointtype,pointx,pointy,pointval)values(1,2,3,4) RETURNING id;

将查询的结果导成新表

CREATE TABLE films_recent AS
 SELECT * FROM films WHERE date_prod >= '2002-01-01';

将shp文件转成sql 直接入pg库

D:\Program Files\PostgreSQL9.6\bin>shp2pgsql -s 4326 -W "GBK" D:\FZ_PCS_PG_ALL.shp fz_pcs >  D:\fz_pcs.sql

异常

ERROR:  relation "public.kafka_swan_vehicle_id_seq" does not exist

解决

新建查询,执行 CREATE SEQUENCE IF NOT EXISTS XXXX_id_seq;

表中含有自增主键导出sql文件 再导入另外一个数据库时自增主键报错问题解决

//有自增字段的表导出成sql文件之后,执行的时候,要在建表之前加上 digitalhub_country_gid_seq  代表主键
DROP SEQUENCE if EXISTS "public"."digitalhub_country_gid_seq"; 
CREATE SEQUENCE "public"."digitalhub_country_gid_seq"  
 INCREMENT 1  
MINVALUE 1  
MAXVALUE 9223372036854775807  
START 1  
CACHE 1;  
就是把之前的删掉了再建

判断两点之间函数

select ST_Length(Geography(ST_GeomFromText('LINESTRING(116.47 39.89,116.47 39.95)')));

查看sql正在运行的进程、查看表是否被锁、解锁表

SELECT
    procpid,
    START,
    now() - START AS lap,
    current_query
FROM
    (
        SELECT
            backendid,
            pg_stat_get_backend_pid (S.backendid) AS procpid,
            pg_stat_get_backend_activity_start (S.backendid) AS START,
            pg_stat_get_backend_activity (S.backendid) AS current_query
        FROM
            (
                SELECT
                    pg_stat_get_backend_idset () AS backendid
            ) AS S
    ) AS S
WHERE
    current_query <> '<IDLE>'
ORDER BY
    lap DESC;
  • procpid:进程id
  • start:进程开始时间
  • lap:经过时间
  • current_query:执行中的sql
  • 怎样停止正在执行的sql
  • SELECT pg_cancel_backend(进程id);
  • 或者用系统函数
  • kill -9 进程id;

查看表是否被锁,解锁表

select oid from pg_class where relname='m_ss_kjcx_tech_inovate_talent' 
select pid from pg_locks where relation='4384913' 
--如果查询到了结果,表示该表被锁 则需要释放锁定 
select pg_cancel_backend(140650678843136)
通过命令: 
=# select pg_cancel_backend(线程id); 
来kill掉指定的SQL语句。(这个函数只能 kill Select 查询,而updae,delete DML不生效)
使用可以kill 各种DML(SELECT,UPDATE,DELETE,DROP)操作= 
=# select pg_terminate_backend(pid int)
-- PGSQL
select oid from pg_class where relname='m_ss_kjcx_tech_inovate_talent' 
select pid from pg_locks where relation='4384913' 
--如果查询到了结果,表示该表被锁 则需要释放锁定 
select pg_cancel_backend(140650678843136)
--- 来查看有哪些SQL正在执行。 waiting='t'
select pid,backend_start,application_name,query_start,waiting,state ,query from pg_stat_activity where query <>'' order by query_start asc
通过命令: 
=# select pg_cancel_backend(线程id); 
来kill掉指定的SQL语句。(这个函数只能 kill Select 查询,而updae,delete DML不生效)
使用可以kill 各种DML(SELECT,UPDATE,DELETE,DROP)操作= 
=# select pg_terminate_backend(pid int)

常用函数

PostGIS中的常用函数
以下内容包括比较多的尖括号,发布到blogger的时候会显示不正常,内容太多我也无暇一个个手动改代码,因此如有问题就去参考PostGIS官方文档。
首先需要说明一下,这里许多函数是以ST_[X]yyy形式命名的,事实上很多函数也可以通过xyyy的形式访问,在PostGIS的函数库中我们可以看到这两种函数定义完全一样。
1. OGC标准函数
管理函数:
添加几何字段 AddGeometryColumn(, , , , , )
删除几何字段 DropGeometryColumn(, , )
检查数据库几何字段并在geometry_columns中归档 Probe_Geometry_Columns()
给几何对象设置空间参考(在通过一个范围做空间查询时常用)ST_SetSRID(geometry, integer)
几何对象关系函数:
获取两个几何对象间的距离                                                                                        ST_Distance(geometry, geometry)
如果两个几何对象间距离在给定值范围内,则返回                                                    TRUEST_DWithin(geometry, geometry, float)
判断两个几何对象是否相等
(比如LINESTRING(0 0, 2 2)和LINESTRING(0 0, 1 1, 2 2)是相同的几何对象)      ST_Equals(geometry, geometry)
判断两个几何对象是否分离                                                                                         ST_Disjoint(geometry, geometry)
判断两个几何对象是否相交                                                                                         ST_Intersects(geometry, geometry)
判断两个几何对象的边缘是否接触                                                                              ST_Touches(geometry, geometry)
判断两个几何对象是否互相穿过                                                                                  ST_Crosses(geometry, geometry)
判断A是否被B包含                                                                                                       ST_Within(geometry A, geometry B)
判断两个几何对象是否是重叠                                                                                      ST_Overlaps(geometry, geometry)
判断A是否包含B                                                                                                          ST_Contains(geometry A, geometry B)
判断A是否覆盖 B                                                                                                         ST_Covers(geometry A, geometry B)
判断A是否被B所覆盖                                                                                                   ST_CoveredBy(geometry A, geometry B)
通过DE-9IM 矩阵判断两个几何对象的关系是否成立                                                   ST_Relate(geometry, geometry, intersectionPatternMatrix)
获得两个几何对象的关系(DE-9IM矩阵)                                                                   ST_Relate(geometry, geometry)
几何对象处理函数:
获取几何对象的中心                                                                                                      ST_Centroid(geometry)
面积量测                                                                                                                        ST_Area(geometry)
长度量测                                                                                                                        ST_Length(geometry)
返回曲面上的一个点                                                                                                      ST_PointOnSurface(geometry)
获取边界                                                                                                                        ST_Boundary(geometry)
获取缓冲后的几何对象                                                                                                   ST_Buffer(geometry, double,[integer])
获取多几何对象的外接对象                                                                                            ST_ConvexHull(geometry)
获取两个几何对象相交的部分                                                                                        ST_Intersection(geometry, geometry)
将经度小于0的值加360使所有经度值在0-360间                                                            ST_Shift_Longitude(geometry)
获取两个几何对象不相交的部分(A、B可互换)                                                          ST_SymDifference(geometry A,geometry B)
从A去除和B相交的部分后返回                                                                                      ST_Difference(geometry A, geometryB)
返回两个几何对象的合并结果                                                                                       ST_Union(geometry, geometry)
返回一系列几何对象的合并结果                                                                                    ST_Union(geometry set)
用较少的内存和较长的时间完成合并操作,结果和ST_Union相同 ST_MemUnion(geometry set)
几何对象存取函数:
获取几何对象的WKT描述 ST_AsText(geometry)
获取几何对象的WKB描述 ST_AsBinary(geometry)
获取几何对象的空间参考ID ST_SRID(geometry)
获取几何对象的维数 ST_Dimension(geometry)
获取几何对象的边界范围 ST_Envelope(geometry)
判断几何对象是否为空 ST_IsEmpty(geometry)
判断几何对象是否不包含特殊点(比如自相交)ST_IsSimple(geometry)
判断几何对象是否闭合 ST_IsClosed(geometry)
判断曲线是否闭合并且不包含特殊点 ST_IsRing(geometry)
获取多几何对象中的对象个数 ST_NumGeometries(geometry)
获取多几何对象中第N个对象 ST_GeometryN(geometry,int)
获取几何对象中的点个数 ST_NumPoints(geometry)
获取几何对象的第N个点 ST_PointN(geometry,integer)
获取多边形的外边缘 ST_ExteriorRing(geometry)
获取多边形内边界个数 ST_NumInteriorRings(geometry)
同上 ST_NumInteriorRing(geometry)
获取多边形的第N个内边界 ST_InteriorRingN(geometry,integer)
获取线的终点 ST_EndPoint(geometry)
获取线的起始点 ST_StartPoint(geometry)
获取几何对象的类型 GeometryType(geometry)
类似上,但是不检查M值,即POINTM对象会被判断为point ST_GeometryType(geometry)
获取点的X坐标 ST_X(geometry)
获取点的Y坐标 ST_Y(geometry)
获取点的Z坐标 ST_Z(geometry)
获取点的M值 ST_M(geometry)
几何对象构造函数:
参考语义:
Text:WKT
WKB:WKB
Geom:Geometry
M:Multi
Bd:BuildArea
Coll:Collection ST_GeomFromText(text,[])    将wkt转为geometry
ST_PointFromText(text,[])
ST_LineFromText(text,[])
ST_LinestringFromText(text,[])
ST_PolyFromText(text,[])
ST_PolygonFromText(text,[])
ST_MPointFromText(text,[])
ST_MLineFromText(text,[])
ST_MPolyFromText(text,[])
ST_GeomCollFromText(text,[])
ST_GeomFromWKB(bytea,[])
ST_GeometryFromWKB(bytea,[])
ST_PointFromWKB(bytea,[])
ST_LineFromWKB(bytea,[])
ST_LinestringFromWKB(bytea,[])
ST_PolyFromWKB(bytea,[])
ST_PolygonFromWKB(bytea,[])
ST_MPointFromWKB(bytea,[])
ST_MLineFromWKB(bytea,[])
ST_MPolyFromWKB(bytea,[])
ST_GeomCollFromWKB(bytea,[])
ST_BdPolyFromText(text WKT, integer SRID)
ST_BdMPolyFromText(text WKT, integer SRID)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家中的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与中国已互相成为双方最大的交易伙伴。中国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占中国外贸总值的15.4%。在过去20余年中,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、传感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值