受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: 19 / devel
此文档适用于不受支持的 PostgreSQL 版本。
您可能需要查看当前版本的相同页面,或上面列出的其他受支持版本。

DISCARD

DISCARD — 丢弃会话状态

Synopsis

DISCARD { ALL | PLANS | SEQUENCES | TEMPORARY | TEMP }

描述

DISCARD释放与数据库会话关联的内部资源。 该命令可用于部分或完全重置会话状态。 它提供了若干子命令,用于释放不同类型的资源; DISCARD ALL变体涵盖了其他所有子命令, 并且还会重置额外的状态。

参数

PLANS #

释放所有缓存的查询计划,从而在下一次使用相关预备语句时强制重新规划。

SEQUENCES #

丢弃所有缓存的序列相关状态,包括 currval()/lastval()信息, 以及所有尚未由nextval()返回的预分配序列值。 (关于预分配序列值的说明,请参见CREATE SEQUENCE。)

TEMPORARYTEMP #

删除当前会话中创建的所有临时表。

ALL #

释放与当前会话相关的所有临时资源,并将会话重置为其初始状态。 目前,这与执行下列语句序列的效果相同:

CLOSE ALL;
SET SESSION AUTHORIZATION DEFAULT;
RESET ALL;
DEALLOCATE ALL;
UNLISTEN *;
SELECT pg_advisory_unlock_all();
DISCARD PLANS;
DISCARD TEMP;
DISCARD SEQUENCES;

注解

DISCARD ALL不能在事务块内部执行。

兼容性

DISCARDPostgreSQL扩展。