查找postgresql的慢SQL

查找执行慢的sql,可以开启druid的监控,也可以在数据库开启性能监控。

oracle默认开启,pg需要手动配置开启。

pg的统计信息放入pg_stat_statements中,开启统计信息之后,对pg库的性能会有一定影响,应该不会太大,可以在备库上添加开启统计信息。

1 修改pg配置文件postgre.sql

shared_preload_libraries = 'pg_stat_statements'

2 创建pg_stat_statements扩展

CREATE EXTENSION pg_stat_statements;

查询sql:
 

SELECT  query, calls, total_time, (total_time/calls) as average ,rows, 
        100.0 * shared_blks_hit /nullif(shared_blks_hit + shared_blks_read, 0) AS hit_percent 
FROM    pg_stat_statements 
ORDER   BY average DESC LIMIT 10;

统计结果会一直存在,可以清空统计结果:
 

select pg_stat_statements_reset() ;

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是十条空间查询的中文语句与对应的postgreSQL数据库SQL语句: 1. 查找指定区域内所有的设施:SELECT * FROM facilities WHERE ST_Intersects(geom,ST_GeomFromText('POLYGON((lon1 lat1,lon2 lat2,lon3 lat3,lon4 lat4,lon1 lat1))',4326)); 2. 查找与指定点最近的5个商店:SELECT * FROM stores ORDER BY ST_Distance(geom,ST_GeomFromText('POINT(lon lat)',4326)) LIMIT 5; 3. 查找所有位于指定行政区域内的房屋:SELECT * FROM houses WHERE ST_Within(geom, (SELECT geom FROM areas WHERE name = '行政区域名称')); 4. 查找距离指定点不超过500米的所有社区服务设施:SELECT * FROM community_facilities WHERE ST_DWithin(geom,ST_GeomFromText('POINT(lon lat)',4326),500); 5. 查找所有距离指定路线不超过500米的公园:SELECT * FROM parks WHERE ST_DWithin(geom, (SELECT ST_Collect(geom) FROM roads WHERE road_name = '路线名称'),500); 6. 查找所有距离指定建筑物超过200米的古迹:SELECT * FROM historic_sites WHERE ST_Distance(geom,(SELECT geom FROM buildings WHERE building_name = '建筑物名称'))>200; 7. 查找所有位置在指定自然保护区内的动物:SELECT * FROM animals WHERE ST_Within(geom, (SELECT geom FROM nature_reserve WHERE name = '自然保护区名称')); 8. 查找所有距离指定城市中心不超过1000米的酒店:SELECT * FROM hotels WHERE ST_Distance(geom,(SELECT geom FROM city_centers WHERE city_name = '城市名称'))<1000; 9. 查找所有距离指定河流不超过200米的钓鱼点:SELECT * FROM fishing_spots WHERE ST_DWithin(geom, (SELECT geom FROM rivers WHERE river_name = '河流名称'),200); 10. 查找所有距离指定机场跑道不超过300米的航空公司办公室:SELECT * FROM airlines_offices WHERE ST_DWithin(geom, (SELECT ST_Collect(runway_geom) FROM airports WHERE airport_name = '机场名称'),300); 希望能够帮助到你。如果还有其他问题,可以随时问我。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值