
30个实用SQL语句,玩转PostgreSQL
引言
PostgreSQL是一款功能非常强大的开源关系型数据库,它支持哈希索引、反向索引、部分索引、Expression 索引、GiST、GIN等多种索引模式,同时可安装功能丰富的扩展包。相较于Mysql,PostgreSQ支持通过PostGIS扩展支持地理空间数据、支持嵌套循环,哈希连接,排序合并三种表连接方式等一系列的强化功能。本文主要整理总结了30个实用SQL,方便大家可以高效利用PostgreSQL。
实用SQL语句
一、数据库连接
1、获取数据库实例连接数
2、获取数据库最大连接数
3、查询当前连接数详细信息
4、查询数据库中各个用户名对应的数据库连接数
二、赋权操作
1、为指定用户赋予指定表的select权限
2、修改数据库表所属的ownner
3、授予指定用户指定表的所有权限
4、授予指定用户所有表的所有权限
三、数据库表或者索引
1、获取数据库表中的索引
2、获取当前db中所有表信息
3、查询数据库安装了哪些扩展
4、查询数据库中的所有表及其描述
四、获取数据大小
1、查询执行数据库大小
2、查询数据库实例当中各个数据库大小
3、查询单表数据大小
4、查询数据库表包括索引的大小
5、查看表中索引大小
6、获取各个表中的数据记录数
7、查看数据库表对应的数据文件
五、数据库分析
1、查看数据库实例的版本
2、查看最新加载配置的时间
3、查看当前wal的buffer中有多少字节未写入磁盘
4、查询最耗时的5个sql
备注:需要开启pg_stat_statements
5、获取执行时间最慢的3条SQL,并给出CPU占用比例
6、分析评估SQL执行情况
7、查看当前长时间执行却不结束的SQL
8、查出使用表扫描最多的表
9、查询读取buffer最多的5个SQL
10、获取数据库当前的回滚事务数以及死锁数
11、查询访问指定表的慢查询
六、数据库备份(非SQL)
1、备份postgres库并tar打包
2、备份postgres库,转储数据为带列名的INSERT命令
总结
本文主要针对PostgreSQL数据库中在日常开发中比较常用的SQL进行了分类的总结,那么大家日常开发工作中,可以在分析数据库性能、数据库连接情况、sql执行情况等数据库分析方面都有对应的SQL语句来进行支撑。
文章转自公众号:慕枫技术笔记
