PostgreSQL中的template0和template1庫使用實戰(zhàn)
postgresql中默認會有三個數(shù)據(jù)庫:postgres、template0、template1。
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =T/postgres +
| | | | | postgres=CTc/postgres
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
(3 rows)
postgres=#
客戶端默認會連接到postgres庫??梢詣h除該庫,不過會影響默認客戶端連接。
刪除了postgres庫之后,可以借助模板庫template1再創(chuàng)建postgres庫:
$ psql template1
psql (11.9)
Type "help" for help.
template1=# drop database postgres;
DROP DATABASE
template1=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
(2 rows)
template1=# create database postgres;
CREATE DATABASE
template1=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
(3 rows)
template1=#
其實,在使用create database db_name語句創(chuàng)建新庫的時候,就是創(chuàng)建模板庫template1的一個拷貝。
那如果我修改了template1庫會怎樣呢?
$ psql template1
psql (11.9)
Type "help" for help.
template1=# create table my_test_tab(a int);
CREATE TABLE
template1=# create extension hstore;
CREATE EXTENSION
template1=# \dx
List of installed extensions
Name | Version | Schema | Description
---------+---------+------------+--------------------------------------------------
hstore | 1.5 | public | data type for storing sets of (key, value) pairs
plpgsql | 1.0 | pg_catalog | PL/pgSQL procedural language
(2 rows)
template1=#
修改以后,再創(chuàng)建新庫的時候,新庫也會包含上面的表和擴展:
template1=# create database db_test;
CREATE DATABASE
template1=# \c db_test
You are now connected to database "db_test" as user "postgres".
db_test=# \dx
List of installed extensions
Name | Version | Schema | Description
---------+---------+------------+--------------------------------------------------
hstore | 1.5 | public | data type for storing sets of (key, value) pairs
plpgsql | 1.0 | pg_catalog | PL/pgSQL procedural language
(2 rows)
db_test=# \d
List of relations
Schema | Name | Type | Owner
--------+-------------+-------+----------
public | my_test_tab | table | postgres
(1 row)
db_test=#
無論,在template1中加入了什么,都會在之后新建的庫中。
那template0的用途是什么呢?
db_test=# select datname,datallowconn,datistemplate from pg_database order by 3; datname | datallowconn | datistemplate -----------+--------------+--------------- postgres | t | f db_test | t | f template1 | t | t template0 | f | t (4 rows) db_test=#
從這里可以看到,只有template0庫對應的datallowconn字段的值是F。這就是上面重建postgres的時候先登錄template1而不是template0的原因。
template0是默認的不可修改的數(shù)據(jù)庫。不建議用戶對template0做任何修改。在初始化后的空實例中,template0和template1是完全相同的。
為什么需要兩個模板庫呢?假設(shè)你搞亂了template1,還可以通過template0恢復template1。
如果你想創(chuàng)建自己的模板庫,只需將你選中庫對應的datistemplate(pg_database中的列)設(shè)置為T即可。
當然,在創(chuàng)建新庫的時候,還可以選擇其他的庫做為源庫:
db_test=# create database db_test_2 template db_test; CREATE DATABASE db_test=#
但是,要求不能有其他連接連接到模板庫,否則會報錯:
db_test=# create database db_test_2 template db_test; ERROR: source database "db_test" is being accessed by other users DETAIL: There is 1 other session using the database. db_test=#
補充:重建postgresql模板數(shù)據(jù)庫template1
$ psql -U postgres postgres postgres=# update pg_database set datistemplate = false where datname='template1'; UPDATE 1 postgres=# drop database template1; DROP DATABASE postgres=# create database template1 template=template0; CREATE DATABASE postgres=# update pg_database set datistemplate = true where datname='template1'; UPDATE 1 postgres=#
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL之分區(qū)表(partitioning)
通過合理的設(shè)計,可以將選擇一定的規(guī)則,將大表切分多個不重不漏的子表,這就是傳說中的partitioning。比如,我們可以按時間切分,每天一張子表,比如我們可以按照某其他字段分割,總之了就是化整為零,提高查詢的效能2016-11-11
postgresql如何找到表中重復數(shù)據(jù)的行并刪除
這篇文章主要介紹了postgresql如何找到表中重復數(shù)據(jù)的行并刪除問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
如何將postgresql數(shù)據(jù)庫表內(nèi)數(shù)據(jù)導出為excel格式(推薦)
這篇文章主要介紹了如何將postgresql數(shù)據(jù)庫表內(nèi)數(shù)據(jù)導出為excel格式(推薦),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
使用PostgreSQL創(chuàng)建高級搜索引擎的代碼示例
本文我們將探索PostgreSQL中的全文搜索功能,并研究我們能夠復制多少典型搜索引擎功能,文中有詳細的代碼示例供大家參考,需要的朋友可以參考下2023-07-07
PostgreSQL查看數(shù)據(jù)庫占用空間大小的幾種常用方法
在PostgreSQL中,查看數(shù)據(jù)庫及數(shù)據(jù)表當前數(shù)據(jù)的占用量可以通過執(zhí)行特定的SQL查詢來實現(xiàn),本文給大家介紹了幾種常用的方法,并通過代碼示例講解的非常詳細,需要的朋友可以參考下2024-05-05
Postgresql 跨庫同步表及postgres_fdw的用法說明
這篇文章主要介紹了Postgresql 跨庫同步表及postgres_fdw的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

