在 PostgreSQL 数据库中,创建表时你可以选择不同的持久性(Persistence)选项。这些选项控制表在数据库中的存储方式及其对持久化数据的处理。你提供的界面显示了三个选项:PERSISTENT
、UNLOGGED
和 TEMPORARY
。下面是它们的含义:
1. PERSISTENT (持久的)
- 解释: 这是默认选项,表示该表是持久化的,也就是表的数据会被永久保存到磁盘上,并且在数据库崩溃后,数据也能够被恢复。
- 何时选择: 当你需要确保数据的长期存储和完整性时,应该选择这个选项。大多数情况下,你会使用这个选项,因为它提供了数据持久性和完整性保证。
2. UNLOGGED (未记录)
- 解释 :
UNLOGGED
表的变化不会被写入 PostgreSQL 的 Write-Ahead Logging (WAL) 日志中。这意味着此类表的数据在数据库崩溃时无法恢复。 - 优点 : 因为没有 WAL 日志记录,
UNLOGGED
表可以比PERSISTENT
表更快地写入数据。 - 缺点: 由于不写入 WAL,数据库崩溃后,表中的数据会丢失。
- 何时选择 : 当你需要高写入性能且可以容忍数据丢失时(例如缓存表或临时数据),可以选择
UNLOGGED
表。
3. TEMPORARY (临时的)
- 解释 :
TEMPORARY
表仅在当前数据库会话(或事务)中存在,一旦会话结束,表及其数据会自动删除。 - 何时选择 : 当你只需要在当前会话中使用表并且不需要保存数据时,选择
TEMPORARY
表非常合适。常用于存储中间计算结果或临时数据。
如何选择
- 持久性要求高 : 选择
PERSISTENT
,这是大多数生产环境下的默认选择。 - 需要更高的写入性能且可以接受数据丢失 : 选择
UNLOGGED
。 - 只需要临时表来存储短期数据 : 选择
TEMPORARY
。