路由器通过域名解析做网站,北京高端网站设计公司,微网站制作需要多少钱,竞价托管推广哪家好发布主题
设置发布为true
这个语句是针对 PostgreSQL 数据库中的逻辑复制功能中的逻辑发布#xff08;Logical Publication#xff09;进行设置的。
PostgreSQL 中#xff0c;逻辑复制是一种基于逻辑日志的复制方法#xff0c;允许将数据更改从一个数据库实例复制到另一…发布主题
设置发布为true
这个语句是针对 PostgreSQL 数据库中的逻辑复制功能中的逻辑发布Logical Publication进行设置的。
PostgreSQL 中逻辑复制是一种基于逻辑日志的复制方法允许将数据更改从一个数据库实例复制到另一个数据库实例而不是通过传统的物理复制方式复制数据文件。逻辑发布是逻辑复制的一部分用于定义要复制的数据对象。
update pg_publication set puballtablestrue where pubname is not null;创建发布主题例子
-- 把所有表进行发布 也可指定CREATE PUBLICATION 发布名 FOR ALL TABLES;-- 指定表发布 创建发布名 for table代表含有哪些表被发布create PUBLICATION 发布名 FOR TABLE表名,表名表名...;DROP PUBLICATION [ IF EXISTS ] name [, ...] [ CASCADE | RESTRICT ]
-- 删除发布的表名
DROP PUBLICATION mypublication;-- 查询所有发布的主题(postgreSQL中的数据库)
select * from pg_publication;
-- 查询 发布名 含哪些表发布
select * from pg_catalog.pg_publication_tables ppt where pubname 表名;
-- 查询所有发布表
select * from pg_publication_tables; ALTER PUBLICATION — 修改发布的定义
ALTER PUBLICATION name ADD TABLE [ ONLY ] table_name [ * ] [, ...]
ALTER PUBLICATION name SET TABLE [ ONLY ] table_name [ * ] [, ...]
ALTER PUBLICATION name DROP TABLE [ ONLY ] table_name [ * ] [, ...]
ALTER PUBLICATION name SET ( publication_parameter [ value] [, ... ] )
ALTER PUBLICATION name OWNER TO { new_owner | CURRENT_USER | SESSION_USER }
ALTER PUBLICATION name RENAME TO new_name命令ALTER PUBLICATION可以更改发布的属性。
更改表的复制标识包含更新和删除的值
-- (如果一张表缺少主键并且涉及到复制就需要执行这条语句)
-- 更改复制标识包含更新和删除之前值
ALTER TABLE [表名] REPLICA IDENTITY FULL;
-- 查看复制标识为f标识说明设置成功
select relreplident from pg_class where relname表名;slot 插槽
查看solt使用情况 删除solt
-- 查看solt使用情况
SELECT * FROM pg_replication_slots;
-- 删除solt zd_org_goods_solt为slot名
SELECT pg_drop_replication_slot(zd_org_goods_solt); 用户连接
查看用户连接数
-- 查询用户当前连接数
select usename, count(*) from pg_stat_activity group by usename order by count(*) desc;
-- 设置用户最大连接数
alter role odps_etl connection limit 200;分区
查询所属表的主表的分区表有哪些 并查看分区表的模式
-- 查询所属表的主表的分区表有哪些 并查看分区表的模式
SELECT parent.relname ASpartitioned_table,child.relname AS partition,ns.nspname AS schema
FROM pg_inheritsJOINpg_class AS parent ON parent.oid pg_inherits.inhparentJOIN pg_class AS child ON child.oid pg_inherits.inhrelidJOIN pg_namespace AS ns ON ns.oid parent.relnamespace
WHERE parent.relkind p-- ns.nspname 为你的模式名AND ns.nspname your schema name-- parent.relname 你的表名AND parent.relname your table name
ORDER BY parent.relname, child.relname;判断分区。 查询分区表信息的 SQL
-- 查询表 是什么表类型是否有子表是否为一个分区表
SELECT relname, relkind, relhassubclass, relispartition
-- pg_class 表字段解释 如下表格
FROM pg_class
-- relname 你要查询的表名
WHERE relname inp_order;查询分区主表所属类型
SELECT c.relname AS table_name, p.partstrat AS partition_strategy
FROM pg_partitioned_table pJOIN pg_class c ON p.partrelid c.oid
-- c.relname 为主表名称
WHERE c.relname tablename查询分区键
SELECT pg_attribute.attname AS partition_key
FROM pg_attributeJOIN pg_partitioned_table ON pg_attribute.attrelid pg_partitioned_table.partrelidJOIN pg_class ON pg_partitioned_table.partrelid pg_class.oidJOIN pg_namespace ON pg_class.relnamespace pg_namespace.oid
-- pg_class.relname 为表名
WHERE pg_class.relname tableName
-- pg_namespace.nspname 为模式名 AND pg_namespace.nspname schemaName AND pg_attribute.attnum ANY (pg_partitioned_table.partattrs) 删除 创建 分区
ALTER TABLE [tablename] DROP PARTITION 分区表名;pg_class 表详细信息
名称类型引用描述oidoid行标识符relnamename表、索引、视图等的名字relnamespaceoidpg_namespace.oid包含该关系的名字空间的OIDreltypeoidpg_type.oid可能存在的表行类型所对应数据类型的OID对索引为0索引没有pg_type项reloftypeoidpg_type.oid对于有类型的表为底层组合类型的OID对于其他所有关系为0relowneroidpg_authid.oid关系的拥有者relamoidpg_am.oid如果这是一个表或者索引表示索引使用的访问方法堆、B树、哈希等relfilenodeoid该关系的磁盘文件的名字0表示这是一个“映射”关系其磁盘文件名取决于低层状态reltablespaceoidpg_tablespace.oid该关系所存储的表空间。如果为0使用数据库的默认表空间。如果关系无磁盘文件时无意义relpagesint4该表磁盘表示的尺寸以页面计页面尺寸为BLCKSZ。这只是一个由规划器使用的估计值。它被VACUUM、ANALYZE以及一些DDL命令如CREATE INDEX所更新reltuplesfloat4表中的存活行数。这只是一个由规划器使用的估计值。它被VACUUM、ANALYZE以及一些DDL命令如CREATE INDEX所更新。relallvisibleint4在表的可见性映射表中被标记为全可见的页数。这只是一个由规划器使用的估计值。它被VACUUM、ANALYZE以及一些DDL命令如CREATE INDEX所更新reltoastrelidoidpg_class.oid与该表相关联的TOAST表的OID如果没有则为0。TOAST表将大属性“线外”存储在一个二级表中relhasindexbool如果这是一个表并且其上建有或最近建有索引则为真relissharedbool如果该表在集簇中的所有数据库间共享则为真。只有某些系统目录如pg_database是共享的relpersistencecharp 永久表u 无日志表 t 临时表relkindcharr 普通表 i 索引 S 序列 t TOAST表 v 视图 m 物化视图 c 组合类型 f 外部表 p 分区表 I 分区索引relnattsint2关系中用户列的数目系统列不计算在内。在pg_attribute中必须有这么多对应的项。另请参阅pg_attribute.attnum。relchecksint2表上CHECK约束的数目参见pg_constraint目录relhasrulesbool如果表有或曾有规则则为真参见 pg_rewrite目录relhastriggersbool如果表有或曾有触发器则为真目录relhassubclassbool如果表或者索引有或曾有任何继承子女则为真relrowsecuritybool如果表上启用了行级安全性则为真参见 pg_policy目录relforcerowsecuritybool如果行级安全性启用时也适用于表拥有者则为真参见 pg_policy目录relispopulatedbool如果表已被填充则为真对于所有关系该列都为真但对于某些物化视图却不是relreplidentchar用来为行形成“replica identity”的列 d 默认 (主键如果存在), n 无, f 所有列 i 索引的indisreplident被设置或者为默认relispartitionbool如果表或索引是一个分区则为真relrewriteoidpg_class.oid对于在要求表重写的DDL操作期间被写入的新关系这个域包含原始关系的OID否则为0。那种状态仅在内部可见对于一个用户可见的关系这个域应该从不包含不是0的值relfrozenxidxid在此之前的所有事务ID在表中已经被替换为一个永久的“冻结的”) 事务ID。这用于跟踪表是否需要被清理以便阻止事务ID回卷或者允许pg_xact被收缩。如果该关系不是一个表则为0InvalidTransactionIdrelminmxidxid在此之前的多事务ID在表中已经被替换为一个事务ID。这被用于跟踪表是否需要被清理以阻止 多事务ID回卷或者允许pg_multixact被收缩。如果关系不是一个表则 为0InvalidMultiXactIdrelaclaclitem[]访问权限reloptionstext[]访问方法相关的选项以“keywordvalue”字符串形式relpartboundpg_node_tree如果表示一个分区见relispartition分区边界的内部表达
索引
查询索引
-- schemaname 指定模式名tablename 指定表名
SELECT * FROM pg_indexes WHERE schemaname %s and tablename %spg_indexes 表详细信息
名字类型引用描述schemanamenamepg_namespace.nspname包含表和索引的模式的名字tablenamenamepg_class.relname此索引所服务的表的名字indexnamenamepg_class.relname索引的名字tablespacenamepg_tablespace.spcname包含索引的表空间名字(如果是数据库缺省则为 NULL)indexdeftext索引定义(一个重建的CREATE INDEX命令)
索引CRD增加查看删除
-- 查看索引
SELECT * FROM pg_indexes WHERE tablename表名;
-- 或者
SELECT * FROM pg_statio_all_indexes WHERE relname表名;
-- 创建索引
CREATE INDEX IF NOT EXISTS [表名] ON [索引名称](字段...);
-- 删除索引
DROP INDEX [索引名称];