当前位置: 首页 > news >正文

pgsql模板是什么?

查找所有的数据库

select datname from pg_database

运行该命令后,我们会发现其中出现了一些其它的数据库

在这里插入图片描述

接下来,我们分析 template0template1 的作用。


template1

template1 是 PostgreSQL 默认用于创建新数据库的模板。当执行 CREATE DATABASE new_db; 时,PostgreSQL 实际上会复制 template1 的内容来创建 new_db

这意味着:

  • 你可以修改 template1:如果你在 template1 中添加了表、函数、扩展或其他对象,那么之后所有基于 template1 创建的新数据库都会包含这些对象。这对于在所有新数据库中预装一些常用结构或扩展非常有用。
  • 需要小心修改:虽然可以修改 template1,但修改后,所有新数据库都会继承这些修改。如果你只想某个数据库有特定对象,最好在创建该数据库后再添加,而不是修改 template1

template0

template0 也是一个模板数据库,但它有一个关键特性:它被设计成一个 “纯净”的模板

这意味着:

  • 不能修改 template0:你不能直接在 template0 中添加、删除或修改对象。

  • 用于恢复或特定编码template0 的主要用途是当 template1 被修改后,如果你需要创建一个完全没有任何自定义对象的新数据库时,可以使用 template0。例如,当你需要创建使用不同字符集编码的数据库时,通常会基于 template0 来创建,以确保编码的一致性。
    你可以通过以下方式基于 template0 创建数据库:

    CREATE DATABASE my_clean_db TEMPLATE template0;
    

简而言之,template1 是你常用的模板,可以自定义;而 template0 是一个干净的、不可修改的模板,用于特定情况,比如创建纯净的数据库或者处理字符集问题。


创建更多自定义的模板

  1. 创建一个普通的数据库: 首先,你需要创建一个常规的数据库。
CREATE DATABASE my_custom_template;
  1. 配置你的新数据库: 连接到这个新创建的数据库 (my_custom_template),并向其中添加所有你希望在新数据库中自动包含的对象。这包括:

    • 表结构(CREATE TABLE
    • 视图(CREATE VIEW
    • 函数和存储过程(CREATE FUNCTION
    • 扩展(CREATE EXTENSION), 例如 uuid-ossppg_trgm 等。
    • 预设数据(INSERT INTO
    • 权限设置(GRANT
-- 添加一个扩展
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";-- 创建一个表
CREATE TABLE users (id UUID DEFAULT uuid_generate_v4() PRIMARY KEY,username VARCHAR(50) NOT NULL UNIQUE,email VARCHAR(100) NOT NULL
);-- 插入一些初始数据
INSERT INTO users (username, email) VALUES ('admin', 'admin@example.com');
  1. 将数据库标记为模板: 完成配置后,断开与该数据库的所有连接。然后,你需要修改其属性,将其标记为一个模板。这个操作需要超级用户权限,并且不能在连接到该数据库时执行。
update pg_database set datistemplate = true where datname = 'my_custom_template';
  1. 根据模板创建数据库
create database mydb template my_custom_template

注意:
只有超级用户才能将数据库标记为模板。

断开连接: 在将数据库标记为模板(ALTER DATABASE ... IS TEMPLATE TRUE;)之前,必须确保没有其他会话连接到该数据库。否则,操作会失败。

模板的修改: 理论上,你可以修改一个已经被标记为模板的数据库。但是,当你修改它时,所有当前连接到它的会话也必须被断开。最佳实践是,如果你需要更新模板,可以先将它设置为 IS TEMPLATE FALSE,进行修改,然后再设置为 IS TEMPLATE TRUE

  1. 查看有哪些template
SELECT datname
FROM pg_database
WHERE datistemplate = TRUE;
http://www.dtcms.com/a/275596.html

相关文章:

  • 深入理解设计模式:建造者模式详解
  • AI产品经理面试宝典第12天:AI产品经理的思维与转型路径面试题与答法
  • 分音塔科技(BABEL Technology) 的公司背景、股权构成、产品类型及技术能力的全方位解读
  • LRU缓存机制完全实战:链表的工程落地与面试通关
  • 杭州乐湾科技有限公司的背景、产品体系与技术能力的全方位深度分析
  • [论文阅读] 人工智能 + 软件工程 | AI助力软件可解释性:从用户评论到自动生成需求与解释
  • 仅27M参数!SamOutVX轻量级语言模型刷新认知,小身材也有大智慧
  • 后端定时过期方案选型
  • 构建AI Agent的完整实战指南:从邮件助手案例看6步落地方法
  • SpringBoot整合Swagger2快速指南
  • Elasticsearch 线程池
  • nginx反向代理实现跨域请求
  • 从零到一:企业如何组建安全团队
  • Go语言高并发聊天室(二):WebSocket服务器实现
  • 白皮精读——2025医疗数据合规白皮书 【附全文阅读】
  • JVM 类加载过程
  • 5. JVM 的方法区
  • 云端docker小知识
  • Vue Vue-route (6)
  • 【SpringAI】7. 基于 milvus 的向量检索
  • Go语言生态成熟度分析:为何Go还无法像Java那样实现注解式框架?
  • 个人面经250712
  • JDK的Stream API使用详解
  • HTML(上)
  • 基于Opencv的缺陷检测实战
  • 《目标检测模块实践手册:从原理到落地的尝试与分享》第一期
  • 服务器怎么跑Python项目?
  • 【408考研知识点全面讲解计算机学科专业基础综合(408)】——数据结构之排序
  • 无法打开windows安全中心解决方案
  • 从基础加热到智能生态跨越:艾芬达用创新重构行业价值边界!