CREATE DATABASE
CREATE DATABASE — создать базу данных
Синтаксис
CREATE DATABASEимя
[ [ WITH ] [ OWNER [=]имя_пользователя
] [ TEMPLATE [=]шаблон
] [ ENCODING [=]кодировка
] [ LC_COLLATE [=]категория_сортировки
] [ LC_CTYPE [=]категория_типов_символов
] [ TABLESPACE [=]табл_пространство
] [ ALLOW_CONNECTIONS [=]разр_подключения
] [ CONNECTION LIMIT [=]предел_подключений
] [ IS_TEMPLATE [=]это_шаблон
] ]
Описание
Команда CREATE DATABASE
создаёт базу данных Postgres Pro.
Чтобы создать базу данных, необходимо быть суперпользователем или иметь специальное право CREATEDB
. См. CREATE USER.
По умолчанию новая база данных создаётся копированием стандартной системной базы данных template1
. Задать другой шаблон можно, добавив указание TEMPLATE
. В частности, написав имя
TEMPLATE template0
, можно создать девственно чистую базу данных, содержащую только стандартные объекты, предопределённые установленной версией Postgres Pro. Это бывает полезно, когда копировать в новую базу любые дополнительные объекты, добавленные локально в template1
, нежелательно.
Параметры
имя
Имя создаваемой базы данных.
имя_пользователя
Имя пользователя (роли), назначаемого владельцем новой базы данных, либо
DEFAULT
, чтобы владельцем стал пользователь по умолчанию (а именно, пользователь, выполняющий команду). Чтобы создать базу данных и сделать её владельцем другую роль, необходимо быть непосредственным или опосредованным членом этой роли, либо суперпользователем.шаблон
Имя шаблона, из которого будет создаваться новая база данных, либо
DEFAULT
, чтобы выбрать шаблон по умолчанию (template1
).кодировка
Кодировка символов в новой базе данных. Укажите строковую константу (например,
'SQL_ASCII'
) или целочисленный номер кодировки, либоDEFAULT
, чтобы выбрать кодировку по умолчанию (а именно, кодировку шаблона). Наборы символов, которые поддерживает Postgres Pro, перечислены в Подразделе 22.3.1. Дополнительные ограничения описаны ниже.категория_сортировки
Порядок сортировки (
LC_COLLATE
), который будет использоваться в новой базе данных. Этот параметр определяет порядок сортировки строк, например, в запросах с ORDER BY, а также порядок индексов по текстовым столбцам. По умолчанию используется порядок сортировки, установленный в шаблоне. Дополнительные ограничения описаны ниже.категория_типов_символов
Классификация символов (
LC_CTYPE
), которая будет применяться в новой базе данных. Этот параметр определяет принадлежность символов категориям, например: строчные, заглавные, цифры и т. п. По умолчанию используется классификация символов, установленная в шаблоне. Дополнительные ограничения описаны ниже.табл_пространство
Имя табличного пространства, связываемого с новой базой данных, или
DEFAULT
для использования табличного пространства шаблона. Это табличное пространство будет использоваться по умолчанию для объектов, создаваемых в этой базе. За подробностями обратитесь к CREATE TABLESPACE.разр_подключения
Если false, никто не сможет подключаться к этой базе данных. По умолчанию имеет значение true, то есть подключения принимаются (если не ограничиваются другими механизмами, например,
GRANT
/REVOKE CONNECT
).предел_подключений
Максимальное количество одновременных подключений к этой базе данных. Значение -1 (по умолчанию) снимает ограничение.
это_шаблон
Если true, базу данных сможет клонировать любой пользователь с правами
CREATEDB
; в противном случае (по умолчанию), клонировать эту базу смогут только суперпользователи и её владелец.
Дополнительные параметры могут записываться в любом порядке, не обязательно так, как показано выше.
Замечания
CREATE DATABASE
нельзя выполнять внутри блока транзакции.
Ошибки, содержащие сообщение «не удалось инициализировать каталог базы данных», чаще всего связаны с нехваткой прав в каталоге данных, заполнением диска или другими проблемами в файловой системе.
Для удаления базы данных применяется DROP DATABASE.
Программа createdb представляет собой оболочку этой команды, созданную ради удобства.
Конфигурационные параметры уровня базы данных (устанавливаемые командой ALTER DATABASE) и разрешения уровня базы (устанавливаемые командой GRANT) из шаблона не копируются.
Хотя с помощью этой команды можно скопировать любую базу данных, а не только template1
, указав её имя в качестве имени шаблона, она не предназначена (пока) для использования в качестве универсального средства вроде «COPY DATABASE
». Принципиальным ограничением является невозможность копирования базы данных шаблона, если установлены другие подключения к ней. CREATE DATABASE
выдаёт ошибку, если при запуске команды есть другие подключения к этой базе; в противном случае новые подключения к базе блокируются до завершения команды CREATE DATABASE
. За дополнительными сведениями обратитесь к Разделу 21.3.
Кодировка символов, указанная для новой базы данных, должна быть совместима с выбранными параметрами локали (LC_COLLATE
и LC_CTYPE
). Если выбрана локаль C
(или равнозначная ей POSIX
), допускаются все кодировки, но для других локалей правильно будет работать только одна кодировка. (В Windows, однако, кодировку UTF-8 можно использовать с любой локалью.) CREATE DATABASE
позволяет суперпользователям указать кодировку SQL_ASCII
вне зависимости от локали, но этот вариант считается устаревшим и может привести к ошибочному поведению строковых функций, если в базе хранятся данные в кодировке, несовместимой с заданной локалью.
Параметры локали и кодировка должны соответствовать тем, что установлены в шаблоне, если только это не template0
. Это ограничение объясняется тем, что другие базы данных могут содержать данные в кодировке, отличной от заданной, или индексы, порядок сортировки которых определяются параметрами LC_COLLATE
и LC_CTYPE
. При копировании таких данных получится база, которая будет испорченной согласно новым параметрам локали. Однако template0
определённо не содержит какие-либо данные или индексы, зависящие от кодировки или локали.
Ограничение CONNECTION LIMIT
действует только приблизительно; если одновременно запускаются два сеанса, тогда как в базе остаётся только одно «свободное место», может так случиться, что будут отклонены оба подключения. Кроме того, это ограничение не распространяется на суперпользователей и фоновые рабочие процессы.
Примеры
Создание базы данных:
CREATE DATABASE lusiadas;
Создание базы данных sales
, принадлежащей пользователю salesapp
, с табличным пространством по умолчанию salesspace
:
CREATE DATABASE sales OWNER salesapp TABLESPACE salesspace;
Создание базы данных music
с кодировкой ISO-8859-1:
CREATE DATABASE music ENCODING 'LATIN1' TEMPLATE template0;
В этом примере предложение TEMPLATE template0
будет необходимым, только если кодировка template1
отличается от ISO-8859-1. Заметьте, что при смене кодировки может потребоваться также выбрать другие параметры LC_COLLATE
и LC_CTYPE
.
Совместимость
Оператор CREATE DATABASE
отсутствует в стандарте SQL. Базы данных равнозначны каталогам, а их создание в стандарте определяется реализацией.
См. также
ALTER DATABASE, DROP DATABASE39.17. Extension Building Infrastructure
If you are thinking about distributing your Postgres Pro extension modules, setting up a portable build system for them can be fairly difficult. Therefore the Postgres Pro installation provides a build infrastructure for extensions, called PGXS, so that simple extension modules can be built simply against an already installed server. PGXS is mainly intended for extensions that include C code, although it can be used for pure-SQL extensions too. Note that PGXS is not intended to be a universal build system framework that can be used to build any software interfacing to Postgres Pro; it simply automates common build rules for simple server extension modules. For more complicated packages, you might need to write your own build system.
To use the PGXS infrastructure for your extension, you must write a simple makefile. In the makefile, you need to set some variables and include the global PGXS makefile. Here is an example that builds an extension module named isbn_issn
, consisting of a shared library containing some C code, an extension control file, a SQL script, an include file (only needed if other modules might need to access the extension functions without going via SQL), and a documentation text file:
MODULES = isbn_issn EXTENSION = isbn_issn DATA = isbn_issn--1.0.sql DOCS = README.isbn_issn HEADERS_isbn_issn = isbn_issn.h PG_CONFIG = pg_config PGXS := $(shell $(PG_CONFIG) --pgxs) include $(PGXS)
The last three lines should always be the same. Earlier in the file, you assign variables or add custom make rules.
Set one of these three variables to specify what is built:
MODULES
list of shared-library objects to be built from source files with same stem (do not include library suffixes in this list)
MODULE_big
a shared library to build from multiple source files (list object files in
OBJS
)PROGRAM
an executable program to build (list object files in
OBJS
)
The following variables can also be set:
EXTENSION
extension name(s); for each name you must provide an
file, which will be installed intoextension
.controlprefix
/share/extensionMODULEDIR
subdirectory of
into which DATA and DOCS files should be installed (if not set, default isprefix
/shareextension
ifEXTENSION
is set, orcontrib
if not)DATA
random files to install into
prefix
/share/$MODULEDIRDATA_built
random files to install into
, which need to be built firstprefix
/share/$MODULEDIRDATA_TSEARCH
random files to install under
prefix
/share/tsearch_dataDOCS
random files to install under
prefix
/doc/$MODULEDIRHEADERS
HEADERS_built
Files to (optionally build and) install under
.prefix
/include/server/$MODULEDIR/$MODULE_bigUnlike
DATA_built
, files inHEADERS_built
are not removed by theclean
target; if you want them removed, also add them toEXTRA_CLEAN
or add your own rules to do it.HEADERS_$MODULE
HEADERS_built_$MODULE
Files to install (after building if specified) under
, whereprefix
/include/server/$MODULEDIR/$MODULE$MODULE
must be a module name used inMODULES
orMODULE_big
.Unlike
DATA_built
, files inHEADERS_built_$MODULE
are not removed by theclean
target; if you want them removed, also add them toEXTRA_CLEAN
or add your own rules to do it.It is legal to use both variables for the same module, or any combination, unless you have two module names in the
MODULES
list that differ only by the presence of a prefixbuilt_
, which would cause ambiguity. In that (hopefully unlikely) case, you should use only theHEADERS_built_$MODULE
variables.SCRIPTS
script files (not binaries) to install into
prefix
/binSCRIPTS_built
script files (not binaries) to install into
, which need to be built firstprefix
/binREGRESS
list of regression test cases (without suffix), see below
REGRESS_OPTS
additional switches to pass to pg_regress
NO_INSTALLCHECK
don't define an
installcheck
target, useful e.g., if tests require special configuration, or don't use pg_regressEXTRA_CLEAN
extra files to remove in
make clean
PG_CPPFLAGS
will be prepended to
CPPFLAGS
PG_CFLAGS
will be appended to
CFLAGS
PG_CXXFLAGS
will be appended to
CXXFLAGS
PG_LDFLAGS
will be prepended to
LDFLAGS
PG_LIBS
will be added to
PROGRAM
link lineSHLIB_LINK
will be added to
MODULE_big
link linePG_CONFIG
path to pg_config program for the Postgres Pro installation to build against (typically just
pg_config
to use the first one in yourPATH
)
Put this makefile as Makefile
in the directory which holds your extension. Then you can do make
to compile, and then make install
to install your module. By default, the extension is compiled and installed for the Postgres Pro installation that corresponds to the first pg_config
program found in your PATH
. You can use a different installation by setting PG_CONFIG
to point to its pg_config
program, either within the makefile or on the make
command line.
You can also run make
in a directory outside the source tree of your extension, if you want to keep the build directory separate. This procedure is also called a VPATH build. Here's how:
mkdir build_dir cd build_dir make -f /path/to/extension/source/tree/Makefile make -f /path/to/extension/source/tree/Makefile install
Alternatively, you can set up a directory for a VPATH build in a similar way to how it is done for the core code. One way to do this is using the core script config/prep_buildtree
. Once this has been done you can build by setting the make
variable VPATH
like this:
make VPATH=/path/to/extension/source/tree make VPATH=/path/to/extension/source/tree install
This procedure can work with a greater variety of directory layouts.
The scripts listed in the REGRESS
variable are used for regression testing of your module, which can be invoked by make installcheck
after doing make install
. For this to work you must have a running Postgres Pro server. The script files listed in REGRESS
must appear in a subdirectory named sql/
in your extension's directory. These files must have extension .sql
, which must not be included in the REGRESS
list in the makefile. For each test there should also be a file containing the expected output in a subdirectory named expected/
, with the same stem and extension .out
. make installcheck
executes each test script with psql, and compares the resulting output to the matching expected file. Any differences will be written to the file regression.diffs
in diff -c
format. Note that trying to run a test that is missing its expected file will be reported as “trouble”, so make sure you have all expected files.
Tip
The easiest way to create the expected files is to create empty files, then do a test run (which will of course report differences). Inspect the actual result files found in the results/
directory, then copy them to expected/
if they match what you expect from the test.