# 前言在 PostgreSQL 中,我们推荐使用批量操作来进行插入,更新和删除数据,这样可以减少客户端与数据库的交互次数,进而提高数据库的吞吐量。# 批量插入数据### 1.使用insert into...select的方式```sqldbtest=# create table test(id serial, login varchar(10),time_now date);CREATE TABLEdbtest=# INSERT INTO test (id, login ,time_now) SELECT GENERATE_SERIES(1,10000),'dbtest',NOW();INSERT 0 10000dbtest=# ...
# 前言在 PostgreSQL 中,我们推荐使用批量操作来进行插入,更新和删除数据,这样可以减少客户端与数据库的交互次数,进而提高数据库的吞吐量。# 批量插入数据### 1.使用insert into...select的方式```sqldbtest=# create table test(id serial, login varchar(10),time_now date);CREATE TABLEdbtest=# INSERT INTO test (id, login ,time_now) SELECT GENERATE_SERIES(1,10000),'dbtest',NOW();INSERT 0 10000dbtes...
postgres=# select distinct(context) from pg_settings;```# 用户场景用户想设置参数 max_parallel_workers 和 max_parallel_workers_per_gather 来改善特定分析场景下,特定应用程序的查询效率,但是不想全局生效,该如何设置?```Plain Textpostgres=# select name,setting,context from pg_settings where name in ('max_parallel_workers','max_parallel_workers_per_gather'); name | setti...
# 前言PostgreSQL 中可以使用角色来控制访问数据库对象的权限,在 PostgreSQL 中,角色在一定程度上可以等同为数据库用户或数据库用户组,同时 PostgreSQL 还允许将一个角色的权限赋予另外一个角色。本章内容将介绍如何查询用户所继承的权限。# 问题复现查看 auser 有具有对象级别的权限,可以看到用户 auser 具有表 t1 的 insert,update,delete,select 权限:````undefinedpostgres=# select table_catalog,table_schema,table_...
# 前言在 PostgreSQL 中,有如下场景我们需要进行重建索引1. 索引膨胀。2. 当修改了某些参数,为了使之完全生效,需要进行 reindex 操作,如 fillfactor。3. 索引损坏。4. 在线创建索引失败,索引状态为 "invaild... SELECT n, n||'_reindex_test',current_timestamp FROM generate_series(1,10000000) n;INSERT 0 10000000rudonx=# CREATE INDEX old_index ON reindex_test USING BTREE(create_date);CREATE INDEX```执...
# 问题描述数据库创建索引可能会锁住创建索引的表,这样阻塞业务在生产中一般是不被允许的,那么 PostgreSQL 如何解决这个问题哪?# 问题分析PostgreSQL 在 CREATE INDEX 命令中新增CONCURRENTLY 选项来实现索引的并发创建# 验证方法1. 创建测试表并插 3000000 条 数据```sqlpostgres=# CREATE TABLE demo(id int);CREATE TABLEpostgres=# INSERT INTO demo SELECT generate_series(1,3000000);INSERT 0 3000000```...
# 问题描述PostgreSQL 数据库中如果有长时间未提交的 2PC,会对数据库造成哪些影响。```Plain Textrudonx=> begin;BEGINrudonx=> insert into accounts values(1,100);INSERT 0 1rudonx=> prepare transaction 'test'; PREPARE TRANSACTIONrudonx=> select * from pg_prepared_xacts ; transaction | gid | prepared | owner | database -------------+------+-----------------------------...
# 前言在配置好逻辑复制之后,我们需要了解逻辑复制相关信息,如复制延迟,replication slot 相关位点信息。PostgreSQL 为我们提供了丰富的表/视图,方便我们进行监控。## 检查逻辑复制的基本配置信息在订阅端查看基本配置信息:从下述信息来看,subname 为订阅者名称,subconninfo 为发布者相关的连接信息。````undefinedrudonx=# select * from pg_subscription;-[ RECORD 1 ]---+--------------------------------------------...
在 PostgreSQL 中可以设置字符串排序,字符归类方法,数值格式,日期格式,时间格式,货币格式。比较常见的是字符串排序以及字符分类| **LC_COLLATE** | **String sort order** || --- | --- || LC_CTYPE | 字符分类 || LC_MESSAGES | 消息的语言 || LC_MONETARY | 货币使用的格式 || LC_NUMERIC | 数字使用的格式 || LC_TIME | 时间日期使用的格式 |# 查看字符集支持的LC_COLLATE和LC_CTYPE```sqldbtest=# select pg_enc...
# 前言在 PostgreSQL 中可以设置字符串排序,字符归类方法,数值格式,日期格式,时间格式,货币格式。比较常见的是字符串排序以及字符分类| LC_COLLATE | String sort order || ----------- | --------------... dbtest=# select pg_encoding_to_char(collencoding) as encoding,collname,collcollate,collctype from pg_collation; encoding | collname | collcollate | collctype ----------+-...
PostgreSQL 是一种常用的关系型数据库,数据集成同步任务为您提供读取和写入 PostgreSQL 数据源的双向通道能力。本文为您介绍 DataSail 的 PostgreSQL 数据源配置、同步任务可视化和脚本模式(DSL)配置能力,实现与不... 使用select a,b from table_a join table_b on table_a.id = table_b.id。 说明 配置该高级参数项后,数据同步任务仍需配置 table_name、column 、split_pk 、shard_split_mode 等必填配置项。然而,在执行同步时,系...
# 前言PostgreSQL 在 9.1 中推出了一种特殊的表:unlogged table,使用 unlogged table 最大的特点是涉及到表的更新,删除等操作不会记录 WAL 日志,这样可以大大的提高性能。不过需要特别注意的是,在数据库异常宕机... 如运行 kill -9 postgresql_pid,数据库重启时自动清空unlogged table的数据。4. 如果正常关闭数据库,如(pg_ctl stop -D /home/pgsql11.5/data/ -m fast),再启动时,unlogged table 中是有数据的。同时,unlogged...
# 前言PostgreSQL 在 9.1 中推出了一种特殊的表:unlogged table,使用 unlogged table 最大的特点是涉及到表的更新,删除等操作不会记录 WAL 日志,这样可以大大的提高性能。不过需要特别注意的是,在数据库异常宕机时... 如运行 kill -9 postgresql_pid,数据库重启时自动清空unlogged table的数据。4. 如果正常关闭数据库,如(pg_ctl stop -D /home/pgsql11.5/data/ -m fast),再启动时,unlogged table 中是有数据的。同时,unlogged ...