CREATE COLLATION
CREATE COLLATION — создать правило сортировки
Синтаксис
CREATE COLLATIONимя
( [ LOCALE =локаль
, ] [ LC_COLLATE =категория_сортировки
, ] [ LC_CTYPE =категория_типов_символов
] ) CREATE COLLATIONимя
FROMсуществующее_правило
Описание
CREATE COLLATION
определяет новое правило сортировки, используя параметры локали операционной системы, либо копируя существующее правило.
Чтобы создать правило сортировки, необходимо иметь право CREATE
в целевой схеме.
Параметры
имя
Имя правила сортировки, возможно, дополненное схемой. Если схема не указана, правило сортировки создаётся в текущей схеме. Заданное имя правила должно быть уникальным в этой схеме. (Системные каталоги могут содержать правила сортировки с одним именем, но предназначенные для разных кодировок, однако они будут игнорироваться, если их кодировка не совпадает с кодировкой базы данных.)
локаль
Это краткая запись для одновременной установки
LC_COLLATE
иLC_CTYPE
. Если указан этот вариант, задать любой из этих параметров отдельно нельзя.категория_сортировки
Указанная локаль операционной системы устанавливается в качестве категории локали
LC_COLLATE
. Эта локаль должна быть применимой к кодировке текущей базы данных. (Точные правила описаны в CREATE DATABASE.)категория_типов_символов
Указанная локаль операционной системы устанавливается в качестве категории локали
LC_CTYPE
. Эта локаль должна быть применимой к кодировке текущей базы данных. (Точные правила описаны в CREATE DATABASE.)существующее_правило
Имя копируемого существующего правила сортировки. Новое правило сортировки получит те же свойства, что и существующее, но будет независимым объектом.
Замечания
Для удаления созданных пользователем правил сортировки применяется команда DROP COLLATION
.
Дополнительные сведения о поддержке правил сортировки можно найти в Разделе 22.2.
Примеры
Создание правила сортировки из локали операционной системы fr_FR.utf8
(предполагается, что кодировка текущей базы данных — UTF8
):
CREATE COLLATION french (LOCALE = 'fr_FR.utf8');
Создание правила сортировки из уже существующего:
CREATE COLLATION german FROM "de_DE";
Иногда удобно использовать в приложениях имена правил сортировки, не зависящие от операционной системы.
Совместимость
Оператор CREATE COLLATION
определён в стандарте SQL, но его действие ограничено копированием существующего правила сортировки. Синтаксис создания нового правила сортировки представляет собой расширение Postgres Pro.
См. также
ALTER COLLATION, DROP COLLATIONREASSIGN OWNED
REASSIGN OWNED — change the ownership of database objects owned by a database role
Synopsis
REASSIGN OWNED BY {old_role
| CURRENT_ROLE | CURRENT_USER | SESSION_USER } [, ...] TO {new_role
| CURRENT_ROLE | CURRENT_USER | SESSION_USER }
Description
REASSIGN OWNED
instructs the system to change the ownership of database objects owned by any of the old_roles
to new_role
.
Parameters
old_role
The name of a role. The ownership of all the objects within the current database, and of all shared objects (databases, tablespaces), owned by this role will be reassigned to
new_role
.new_role
The name of the role that will be made the new owner of the affected objects.
Notes
REASSIGN OWNED
is often used to prepare for the removal of one or more roles. Because REASSIGN OWNED
does not affect objects within other databases, it is usually necessary to execute this command in each database that contains objects owned by a role that is to be removed.
REASSIGN OWNED
requires membership on both the source role(s) and the target role.
The DROP OWNED
command is an alternative that simply drops all the database objects owned by one or more roles.
The REASSIGN OWNED
command does not affect any privileges granted to the old_roles
on objects that are not owned by them. Likewise, it does not affect default privileges created with ALTER DEFAULT PRIVILEGES
. Use DROP OWNED
to revoke such privileges.
See Section 21.4 for more discussion.
Compatibility
The REASSIGN OWNED
command is a PostgreSQL extension.