postgresql中默認(rèn)會(huì)有三個(gè)數(shù)據(jù)庫(kù):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=#
客戶端默認(rèn)會(huì)連接到postgres庫(kù)。可以刪除該庫(kù),不過(guò)會(huì)影響默認(rèn)客戶端連接。
刪除了postgres庫(kù)之后,可以借助模板庫(kù)template1再創(chuàng)建postgres庫(kù):
$ 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=#
其實(shí),在使用create database db_name語(yǔ)句創(chuàng)建新庫(kù)的時(shí)候,就是創(chuàng)建模板庫(kù)template1的一個(gè)拷貝。
那如果我修改了template1庫(kù)會(huì)怎樣呢?
$ 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)建新庫(kù)的時(shí)候,新庫(kù)也會(huì)包含上面的表和擴(kuò)展:
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=#
無(wú)論,在template1中加入了什么,都會(huì)在之后新建的庫(kù)中。
那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庫(kù)對(duì)應(yīng)的datallowconn字段的值是F。這就是上面重建postgres的時(shí)候先登錄template1而不是template0的原因。
template0是默認(rèn)的不可修改的數(shù)據(jù)庫(kù)。不建議用戶對(duì)template0做任何修改。在初始化后的空實(shí)例中,template0和template1是完全相同的。
為什么需要兩個(gè)模板庫(kù)呢?假設(shè)你搞亂了template1,還可以通過(guò)template0恢復(fù)template1。
如果你想創(chuàng)建自己的模板庫(kù),只需將你選中庫(kù)對(duì)應(yīng)的datistemplate(pg_database中的列)設(shè)置為T即可。
當(dāng)然,在創(chuàng)建新庫(kù)的時(shí)候,還可以選擇其他的庫(kù)做為源庫(kù):
db_test=# create database db_test_2 template db_test;
CREATE DATABASE
db_test=#
但是,要求不能有其他連接連接到模板庫(kù),否則會(huì)報(bào)錯(cuò):
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=#
補(bǔ)充:重建postgresql模板數(shù)據(jù)庫(kù)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=#
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- PostgreSQL存儲(chǔ)過(guò)程用法實(shí)戰(zhàn)詳解
- PostgreSQL實(shí)戰(zhàn)之啟動(dòng)恢復(fù)讀取checkpoint記錄失敗的條件詳解
- postgresql影子用戶實(shí)踐場(chǎng)景分析