欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

玩轉(zhuǎn)PostgreSQL之30個實用SQL語句

 更新時間:2022年11月15日 23:01:22   作者:慕楓  
本文主要整理總結(jié)了30個實用SQL,方便大家可以高效利用PostgreSQL,需要的朋友可以參考下

引言

PostgreSQL是一款功能非常強大的開源關(guān)系型數(shù)據(jù)庫,它支持哈希索引、反向索引、部分索引、Expression 索引、GiST、GIN等多種索引模式,同時可安裝功能豐富的擴展包。相較于Mysql,PostgreSQ支持通過PostGIS擴展支持地理空間數(shù)據(jù)、支持嵌套循環(huán),哈希連接,排序合并三種表連接方式等一系列的強化功能。本文主要整理總結(jié)了30個實用SQL,方便大家可以高效利用PostgreSQL。

實用SQL語句

一、數(shù)據(jù)庫連接

1、獲取數(shù)據(jù)庫實例連接數(shù)

select count(*) from pg_stat_activity;

2、獲取數(shù)據(jù)庫最大連接數(shù)

show max_connections

3、查詢當前連接數(shù)詳細信息

select * from pg_stat_activity;

4、查詢數(shù)據(jù)庫中各個用戶名對應(yīng)的數(shù)據(jù)庫連接數(shù)

select usename, count(*) from pg_stat_activity group by usename;?

二、賦權(quán)操作

1、為指定用戶賦予指定表的select權(quán)限

GRANT SELECT ON table_name TO username;

2、修改數(shù)據(jù)庫表所屬的ownner

alter table table_name owner to username;

3、授予指定用戶指定表的所有權(quán)限

grant all privileges on table product to username

4、授予指定用戶所有表的所有權(quán)限

GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;

三、數(shù)據(jù)庫表或者索引

1、獲取數(shù)據(jù)庫表中的索引

select * from pg_indexes where tablename = 'product';?

2、獲取當前db中所有表信息

?select * from pg_tables;

3、查詢數(shù)據(jù)庫安裝了哪些擴展

select * from pg_extension;?

4、查詢數(shù)據(jù)庫中的所有表及其描述

select relname as TABLE_NAME ,col_description(c.oid, 0) as COMMENTS from pg_class c where relkind = 'r' and relname not like 'pg_%' and relname not like 'sql_%'

四、獲取數(shù)據(jù)大小

1、查詢執(zhí)行數(shù)據(jù)庫大小

select pg_size_pretty (pg_database_size('db_product'));

2、查詢數(shù)據(jù)庫實例當中各個數(shù)據(jù)庫大小

select datname, pg_size_pretty (pg_database_size(datname)) AS size from pg_database;

3、查詢單表數(shù)據(jù)大小

select pg_size_pretty(pg_relation_size('table_name')) as size;

4、查詢數(shù)據(jù)庫表包括索引的

select pg_size_pretty(pg_total_relation_size('table_name')) as size;

5、查看表中索引大小

select pg_size_pretty(pg_indexes_size('table_name'));

6、獲取各個表中的數(shù)據(jù)記錄數(shù)

select relname as TABLE_NAME, reltuples as rowCounts from pg_class where relkind = 'r' order by rowCounts desc

7、查看數(shù)據(jù)庫表對應(yīng)的數(shù)據(jù)文件

select pg_relation_filepath('product');

五、數(shù)據(jù)庫分析

1、查看數(shù)據(jù)庫實例的版本

select version();

2、查看最新加載配置的時間

select pg_conf_load_time();

3、查看當前wal的buffer中有多少字節(jié)沒有寫入到磁盤中

select pg_xlog_location_diff(pg_current_xlog_insert_location(),pg_current_xlog_location());

4、查詢最耗時的5個sql

select * from pg_stat_statements order by total_time desc limit 5;

備注:需要開啟pg_stat_statements

5、獲取執(zhí)行時間最慢的3條SQL,并給出CPU占用比例

SELECT substring(query, 1, 1000) AS short_query,
round(total_time::numeric, 2) AS total_time,
calls,
round((100 * total_time / sum(total_time::numeric) OVER ())::numeric, 2) AS percentage_cpu
FROM pg_stat_statements
ORDER BY total_time DESC
LIMIT 3;

6、分析評估SQL執(zhí)行情況

EXPLAIN ANALYZE SELECT * FROM product

7、查看當前長時間執(zhí)行卻不結(jié)束的SQL

select datname, usename, client_addr, application_name, state, backend_start, xact_start, xact_stay, query_start, query_stay, replace(query, chr(10), ' ') as query from (select pgsa.datname as datname, pgsa.usename as usename, pgsa.client_addr client_addr, pgsa.application_name as application_name, pgsa.state as state, pgsa.backend_start as backend_start, pgsa.xact_start as xact_start, extract(epoch from (now() - pgsa.xact_start)) as xact_stay, pgsa.query_start as query_start, extract(epoch from (now() - pgsa.query_start)) as query_stay , pgsa.query as query from pg_stat_activity as pgsa where pgsa.state != 'idle' and pgsa.state != 'idle in transaction' and pgsa.state != 'idle in transaction (aborted)') idleconnections order by query_stay desc limit 5;

8、查出使用表掃描最多的表

select * from pg_stat_user_tables where n_live_tup > 100000 and seq_scan > 0 order by seq_tup_read desc limit 10;

9、查詢讀取buffer最多的5個SQL

select * from pg_stat_statements order by shared_blks_hit+shared_blks_read desc limit 5;

10、獲取數(shù)據(jù)庫當前的回滾事務(wù)數(shù)以及死鎖數(shù)

select datname,xact_rollback,deadlocks from pg_stat_database

11、查詢指定表的慢查詢

select * from pg_stat_activity where query ilike '%<table_name>%' and query_start - now() > interval '10 seconds';

六、數(shù)據(jù)庫備份

1、備份postgres庫并tar打包

pg_dump -h 127.0.0.1 -p 5432 -U postgres -f postgres.sql.tar -Ft

2、備份postgres庫,轉(zhuǎn)儲數(shù)據(jù)為帶列名的INSERT命令

pg_dumpall -d postgres -U postgres -f postgres.sql --column-inserts

總結(jié)

本文主要針對PostgreSQL數(shù)據(jù)庫中在日常開發(fā)中比較常用的SQL進行了分類的總結(jié),那么大家日常開發(fā)工作中,可以在分析數(shù)據(jù)庫性能、數(shù)據(jù)庫連接情況、sql執(zhí)行情況等方面都有對應(yīng)的SQL語句來進行支撐。

相關(guān)文章

最新評論