- Выдаёт привилегии учётным записям пользователей ClickHouse или ролям.
- Назначает роли учётным записям пользователей или другим ролям.
Синтаксис предоставления привилегий
privilege— тип привилегии.role— роль пользователя ClickHouse.user— учетная запись пользователя ClickHouse.
WITH GRANT OPTION дает user или role разрешение выполнять запрос GRANT. Пользователи могут предоставлять привилегии того же или более узкого уровня действия, чем у них самих.
Условие WITH REPLACE OPTION заменяет старые привилегии новыми для user или role; если оно не указано, привилегии добавляются.
Синтаксис назначения роли
role— роль пользователя ClickHouse.user— учётная запись пользователя ClickHouse.
WITH ADMIN OPTION предоставляет привилегию ADMIN OPTION пользователю user или роли role.
Предложение WITH REPLACE OPTION заменяет старые роли новой ролью для user или role; если оно не указано, роли добавляются.
Синтаксис GRANT CURRENT GRANTS
privilege— Тип привилегии.role— Роль пользователя ClickHouse.user— Учётная запись пользователя ClickHouse.
CURRENT GRANTS позволяет предоставить все указанные привилегии указанному пользователю или роли.
Если не указана ни одна привилегия, указанный пользователь или роль получит все доступные привилегии для CURRENT_USER.
Использование
GRANT, у вашей учетной записи должна быть привилегия GRANT OPTION. Вы можете выдавать привилегии только в пределах привилегий своей учетной записи.
Например, администратор выдал привилегии учетной записи john с помощью запроса:
john имеет разрешение выполнять:
SELECT x,y FROM db.table.SELECT x FROM db.table.SELECT y FROM db.table.
john не может выполнить SELECT z FROM db.table. Запрос SELECT * FROM db.table также недоступен. При обработке этого запроса ClickHouse не возвращает никаких данных, даже x и y. Единственное исключение — если таблица содержит только столбцы x и y. В этом случае ClickHouse возвращает все данные.
Кроме того, у john есть привилегия GRANT OPTION, поэтому он может выдавать другим пользователям привилегии того же или меньшего уровня.
Доступ к базе данных system всегда разрешён (поскольку эта база данных используется для обработки запросов).
Хотя по умолчанию новым пользователям доступно множество системных таблиц, без соответствующих grants они могут не иметь доступа ко всем системным таблицам.
Кроме того, доступ к некоторым системным таблицам, таким как
system.zookeeper, ограничен для пользователей Cloud по соображениям безопасности.GRANT SELECT, INSERT ON *.* TO john, robin позволяет учётным записям john и robin выполнять запросы INSERT и SELECT для всех таблиц во всех базах данных на сервере.
Привилегии с подстановочными знаками
*) вместо имени таблицы или базы данных. Например, запрос GRANT SELECT ON db.* TO john позволяет john выполнять запрос SELECT для всех таблиц в базе данных db.
Также можно опустить имя базы данных. В этом случае привилегии выдаются для текущей базы данных.
Например, GRANT SELECT ON * TO john выдаёт привилегию для всех таблиц в текущей базе данных, а GRANT SELECT ON mytable TO john выдаёт привилегию для таблицы mytable в текущей базе данных.
Описанная ниже возможность доступна начиная с версии ClickHouse 24.10.
GRANT SELECT ON db.my_tables* TO john. Этот запрос позволяет john выполнять запрос SELECT для всех таблиц базы данных db с префиксом my_tables*.
Другие примеры:
GRANT SELECT ON db.my_tables* TO john
GRANT SELECT ON db*.* TO john
GRANT SELECT ON db.* TO john, а затем создадите новую таблицу db.new_table, пользователь john сможет выполнить запрос SELECT * FROM db.new_table.
Звёздочку можно указывать только для префиксов:
Привилегии
ALLУПРАВЛЕНИЕ ДОСТУПОМALLOW SQL SECURITY NONEALTER QUOTAALTER ROLEALTER ROW POLICYALTER SETTINGS PROFILEALTER USERCREATE QUOTACREATE ROLECREATE ROW POLICYCREATE SETTINGS PROFILECREATE USERDROP QUOTADROP ROLEDROP ROW POLICYDROP SETTINGS PROFILEDROP USERROLE ADMINSHOW ACCESSSHOW QUOTASSHOW ROLESSHOW ROW POLICIESSHOW SETTINGS PROFILESSHOW USERS
ALTERALTER DATABASEALTER DATABASE SETTINGS
ALTER TABLEALTER COLUMNALTER ADD COLUMNALTER CLEAR COLUMNALTER COMMENT COLUMNALTER DROP COLUMNALTER MATERIALIZE COLUMNALTER MODIFY COLUMNALTER RENAME COLUMN
ALTER CONSTRAINTALTER ADD CONSTRAINTALTER DROP CONSTRAINT
ALTER DELETEALTER FETCH PARTITIONALTER FREEZE PARTITIONALTER INDEXALTER ADD INDEXALTER CLEAR INDEXALTER DROP INDEXALTER MATERIALIZE INDEXALTER ORDER BYALTER SAMPLE BY
ALTER MATERIALIZE TTLALTER MODIFY COMMENTALTER MOVE PARTITIONALTER PROJECTIONALTER SETTINGSALTER STATISTICSALTER ADD STATISTICSALTER DROP STATISTICSALTER MATERIALIZE STATISTICSALTER MODIFY STATISTICS
ALTER TTLALTER UPDATEALTER TABLE EXECUTE
ALTER VIEWALTER VIEW MODIFY QUERYALTER VIEW REFRESHALTER VIEW MODIFY SQL SECURITY
BACKUPCLUSTERCREATECREATE ARBITRARY TEMPORARY TABLECREATE TEMPORARY TABLE
CREATE DATABASECREATE DICTIONARYCREATE FUNCTIONCREATE RESOURCECREATE TABLECREATE VIEWCREATE WORKLOAD
dictGetdisplaySecretsInShowAndSelectDROPDROP DATABASEDROP DICTIONARYDROP FUNCTIONDROP RESOURCEDROP TABLEDROP VIEWDROP WORKLOAD
INSERTINTROSPECTIONaddressToLineaddressToLineWithInlinesaddressToSymboldemangle
KILL QUERYKILL TRANSACTIONMOVE PARTITION BETWEEN SHARDSNAMED COLLECTION ADMINALTER NAMED COLLECTIONCREATE NAMED COLLECTIONDROP NAMED COLLECTIONNAMED COLLECTIONSHOW NAMED COLLECTIONSSHOW NAMED COLLECTIONS SECRETS
OPTIMIZESELECTSET DEFINERSHOWSHOW COLUMNSSHOW DATABASESSHOW DICTIONARIESSHOW TABLES
SHOW FILESYSTEM CACHESSOURCESAZUREFILEHDFSHIVEJDBCKAFKAMONGOMYSQLNATSODBCPOSTGRESRABBITMQREDISREMOTES3SQLITEURL
SYSTEMSYSTEM CLEANUPSYSTEM DROP CACHESYSTEM DROP COMPILED EXPRESSION CACHESYSTEM DROP CONNECTIONS CACHESYSTEM DROP DISTRIBUTED CACHESYSTEM DROP DNS CACHESYSTEM DROP FILESYSTEM CACHESYSTEM DROP FORMAT SCHEMA CACHESYSTEM DROP MARK CACHESYSTEM DROP MMAP CACHESYSTEM DROP PAGE CACHESYSTEM DROP PRIMARY INDEX CACHESYSTEM DROP QUERY CACHESYSTEM DROP S3 CLIENT CACHESYSTEM DROP SCHEMA CACHESYSTEM DROP UNCOMPRESSED CACHE
SYSTEM DROP PRIMARY INDEX CACHESYSTEM DROP REPLICASYSTEM FAILPOINTSYSTEM FETCHESSYSTEM FLUSHSYSTEM FLUSH ASYNC INSERT QUEUESYSTEM FLUSH LOGS
SYSTEM JEMALLOCSYSTEM KILL QUERYSYSTEM KILL TRANSACTIONSYSTEM LISTENSYSTEM LOAD PRIMARY KEYSYSTEM MERGESSYSTEM MOVESSYSTEM PULLING REPLICATION LOGSYSTEM REDUCE BLOCKING PARTSSYSTEM REPLICATION QUEUESSYSTEM REPLICA READINESSSYSTEM RESTART DISKSYSTEM RESTART REPLICASYSTEM RESTORE REPLICASYSTEM RELOADSYSTEM RELOAD ASYNCHRONOUS METRICSSYSTEM RELOAD CONFIGSYSTEM RELOAD DICTIONARYSYSTEM RELOAD EMBEDDED DICTIONARIESSYSTEM RELOAD FUNCTIONSYSTEM RELOAD MODELSYSTEM RELOAD USERS
SYSTEM SENDSSYSTEM DISTRIBUTED SENDSSYSTEM REPLICATED SENDS
SYSTEM SHUTDOWNSYSTEM SYNC DATABASE REPLICASYSTEM SYNC FILE CACHESYSTEM SYNC FILESYSTEM CACHESYSTEM SYNC REPLICASYSTEM SYNC TRANSACTION LOGSYSTEM THREAD FUZZERSYSTEM TTL MERGESSYSTEM UNFREEZESYSTEM UNLOAD PRIMARY KEYSYSTEM VIEWSSYSTEM VIRTUAL PARTS UPDATESYSTEM WAIT LOADING PARTS
TABLE ENGINETRUNCATEUNDROP TABLE
NONE
- Привилегия
ALTERвключает все остальные привилегииALTER*. ALTER CONSTRAINTвключает привилегииALTER ADD CONSTRAINTиALTER DROP CONSTRAINT.
COLUMN— привилегию можно выдать для столбца, таблицы, базы данных или глобально.TABLE— привилегию можно выдать для таблицы, базы данных или глобально.VIEW— привилегию можно выдать для представления, базы данных или глобально.DICTIONARY— привилегию можно выдать для словаря, базы данных или глобально.DATABASE— привилегию можно выдать для базы данных или глобально.GLOBAL— привилегию можно выдать только глобально.GROUP— группирует привилегии разных уровней. Когда выдается привилегия уровняGROUP, выдаются только те привилегии из группы, которые соответствуют используемому синтаксису.
GRANT SELECT(x) ON db.table TO userGRANT SELECT ON db.* TO user
GRANT CREATE USER(x) ON db.table TO userGRANT CREATE USER ON db.* TO user
SELECT, CREATE TABLE, INSERT и DROP TABLE.
SELECT
COLUMN.
Описание
Пользователь, которому выдана эта привилегия, может выполнять запросы SELECT к указанному списку столбцов в указанной таблице и базе данных. Если пользователь укажет столбцы, отличные от разрешённых, запрос не вернёт данных.
Рассмотрим следующую привилегию:
john выполнять любой запрос SELECT, который использует данные из столбцов x и/или y в db.table, например SELECT x FROM db.table. john не может выполнить SELECT z FROM db.table. Запрос SELECT * FROM db.table также недоступен. При обработке этого запроса ClickHouse не возвращает никаких данных, даже x и y. Единственное исключение — если таблица содержит только столбцы x и y, в этом случае ClickHouse возвращает все данные.
INSERT
COLUMN.
Описание
Пользователь, которому выдана эта привилегия, может выполнять запросы INSERT для указанного списка столбцов в указанной таблице и базе данных. Если пользователь указывает столбцы, отличные от разрешённых, запрос не вставляет данные.
Пример
john вставлять данные в столбцы x и/или y таблицы db.table.
ALTER
ALTER. Уровень:COLUMN.ALTER TABLE. Уровень:GROUPALTER UPDATE. Уровень:COLUMN. Псевдонимы:UPDATEALTER DELETE. Уровень:COLUMN. Псевдонимы:DELETEALTER COLUMN. Уровень:GROUPALTER ADD COLUMN. Уровень:COLUMN. Псевдонимы:ADD COLUMNALTER DROP COLUMN. Уровень:COLUMN. Псевдонимы:DROP COLUMNALTER MODIFY COLUMN. Уровень:COLUMN. Псевдонимы:MODIFY COLUMNALTER COMMENT COLUMN. Уровень:COLUMN. Псевдонимы:COMMENT COLUMNALTER CLEAR COLUMN. Уровень:COLUMN. Псевдонимы:CLEAR COLUMNALTER RENAME COLUMN. Уровень:COLUMN. Псевдонимы:RENAME COLUMNALTER INDEX. Уровень:GROUP. Псевдонимы:INDEXALTER ORDER BY. Уровень:TABLE. Псевдонимы:ALTER MODIFY ORDER BY,MODIFY ORDER BYALTER SAMPLE BY. Уровень:TABLE. Псевдонимы:ALTER MODIFY SAMPLE BY,MODIFY SAMPLE BYALTER ADD INDEX. Уровень:TABLE. Псевдонимы:ADD INDEXALTER DROP INDEX. Уровень:TABLE. Псевдонимы:DROP INDEXALTER MATERIALIZE INDEX. Уровень:TABLE. Псевдонимы:MATERIALIZE INDEXALTER CLEAR INDEX. Уровень:TABLE. Псевдонимы:CLEAR INDEXALTER CONSTRAINT. Уровень:GROUP. Псевдонимы:CONSTRAINTALTER ADD CONSTRAINT. Уровень:TABLE. Псевдонимы:ADD CONSTRAINTALTER DROP CONSTRAINT. Уровень:TABLE. Псевдонимы:DROP CONSTRAINTALTER TTL. Уровень:TABLE. Псевдонимы:ALTER MODIFY TTL,MODIFY TTLALTER MATERIALIZE TTL. Уровень:TABLE. Псевдонимы:MATERIALIZE TTLALTER SETTINGS. Уровень:TABLE. Псевдонимы:ALTER SETTING,ALTER MODIFY SETTING,MODIFY SETTINGALTER MOVE PARTITION. Уровень:TABLE. Псевдонимы:ALTER MOVE PART,MOVE PARTITION,MOVE PARTALTER FETCH PARTITION. Уровень:TABLE. Псевдонимы:ALTER FETCH PART,FETCH PARTITION,FETCH PARTALTER FREEZE PARTITION. Уровень:TABLE. Псевдонимы:FREEZE PARTITIONALTER EXECUTE. Уровень:TABLE. Псевдонимы:ALTER TABLE EXECUTEALTER VIEW. Уровень:GROUPALTER VIEW REFRESH. Уровень:VIEW. Псевдонимы:REFRESH VIEWALTER VIEW MODIFY QUERY. Уровень:VIEW. Псевдонимы:ALTER TABLE MODIFY QUERYALTER VIEW MODIFY SQL SECURITY. Уровень:VIEW. Псевдонимы:ALTER TABLE MODIFY SQL SECURITY
- Привилегия
ALTERвключает все остальные привилегииALTER*. ALTER CONSTRAINTвключает привилегииALTER ADD CONSTRAINTиALTER DROP CONSTRAINT.
- Привилегия
MODIFY SETTINGпозволяет изменять настройки движка таблицы. Она не влияет на настройки или параметры конфигурации сервера. - Для операции
ATTACHтребуется привилегия CREATE. - Для операции
DETACHтребуется привилегия DROP. - Чтобы остановить мутацию запросом KILL MUTATION, необходимо иметь привилегию, позволяющую запускать эту мутацию. Например, если вы хотите остановить запрос
ALTER UPDATE, вам нужна привилегияALTER UPDATE,ALTER TABLEилиALTER.
BACKUP
BACKUP] в запросах. Подробнее о резервном копировании см. в разделе “Резервное копирование и восстановление”.
CREATE
CREATE. Уровень:GROUPCREATE DATABASE. Уровень:DATABASECREATE TABLE. Уровень:TABLECREATE ARBITRARY TEMPORARY TABLE. Уровень:GLOBALCREATE TEMPORARY TABLE. Уровень:GLOBAL
CREATE VIEW. Уровень:VIEWCREATE DICTIONARY. Уровень:DICTIONARY
- Чтобы удалить созданную таблицу, пользователю нужна привилегия DROP.
CLUSTER
ON CLUSTER.
Syntax
ON CLUSTER требуется, чтобы пользователю был выдан grant CLUSTER.
Если попытаться использовать ON CLUSTER в запросе без предварительной выдачи привилегии CLUSTER, вы получите следующую ошибку:
on_cluster_queries_require_cluster_grant, расположенной в разделе access_control_improvements файла config.xml (см. ниже), значение false.
config.xml
DROP
DROP. Уровень:GROUPDROP DATABASE. Уровень:DATABASEDROP TABLE. Уровень:TABLEDROP VIEW. Уровень:VIEWDROP DICTIONARY. Уровень:DICTIONARY
TRUNCATE
TABLE.
OPTIMIZE
TABLE.
SHOW
SHOW, DESCRIBE, USE и EXISTS в соответствии со следующей иерархией привилегий:
SHOW. Уровень:GROUPSHOW DATABASES. Уровень:DATABASE. Позволяет выполнять запросыSHOW DATABASES,SHOW CREATE DATABASE,USE <database>.SHOW TABLES. Уровень:TABLE. Позволяет выполнять запросыSHOW TABLES,EXISTS <table>,CHECK <table>.SHOW COLUMNS. Уровень:COLUMN. Позволяет выполнять запросыSHOW CREATE TABLE,DESCRIBE.SHOW DICTIONARIES. Уровень:DICTIONARY. Позволяет выполнять запросыSHOW DICTIONARIES,SHOW CREATE DICTIONARY,EXISTS <dictionary>.
SHOW, если у него есть любая другая привилегия, относящаяся к указанной таблице, словарю или базе данных.
KILL QUERY
GLOBAL.
Примечания
Привилегия KILL QUERY позволяет одному пользователю завершать запросы других пользователей.
УПРАВЛЕНИЕ ДОСТУПОМ
ACCESS MANAGEMENT. Уровень:GROUPCREATE USER. Уровень:GLOBALALTER USER. Уровень:GLOBALDROP USER. Уровень:GLOBALCREATE ROLE. Уровень:GLOBALALTER ROLE. Уровень:GLOBALDROP ROLE. Уровень:GLOBALROLE ADMIN. Уровень:GLOBALCREATE ROW POLICY. Уровень:GLOBAL. Псевдонимы:CREATE POLICYALTER ROW POLICY. Уровень:GLOBAL. Псевдонимы:ALTER POLICYDROP ROW POLICY. Уровень:GLOBAL. Псевдонимы:DROP POLICYCREATE QUOTA. Уровень:GLOBALALTER QUOTA. Уровень:GLOBALDROP QUOTA. Уровень:GLOBALCREATE SETTINGS PROFILE. Уровень:GLOBAL. Псевдонимы:CREATE PROFILEALTER SETTINGS PROFILE. Уровень:GLOBAL. Псевдонимы:ALTER PROFILEDROP SETTINGS PROFILE. Уровень:GLOBAL. Псевдонимы:DROP PROFILESHOW ACCESS. Уровень:GROUPSHOW_USERS. Уровень:GLOBAL. Псевдонимы:SHOW CREATE USERSHOW_ROLES. Уровень:GLOBAL. Псевдонимы:SHOW CREATE ROLESHOW_ROW_POLICIES. Уровень:GLOBAL. Псевдонимы:SHOW POLICIES,SHOW CREATE ROW POLICY,SHOW CREATE POLICYSHOW_QUOTAS. Уровень:GLOBAL. Псевдонимы:SHOW CREATE QUOTASHOW_SETTINGS_PROFILES. Уровень:GLOBAL. Псевдонимы:SHOW PROFILES,SHOW CREATE SETTINGS PROFILE,SHOW CREATE PROFILE
ALLOW SQL SECURITY NONE. Уровень:GLOBAL. Псевдонимы:CREATE SQL SECURITY NONE,SQL SECURITY NONE,SECURITY NONE
ROLE ADMIN позволяет пользователю назначать и отзывать любые роли, включая те, которые не назначены этому пользователю с опцией admin.
SYSTEM
SYSTEM. Уровень:GROUPSYSTEM SHUTDOWN. Уровень:GLOBAL. Псевдонимы:SYSTEM KILL,SHUTDOWNSYSTEM DROP CACHE. Псевдонимы:DROP CACHESYSTEM DROP DNS CACHE. Уровень:GLOBAL. Псевдонимы:SYSTEM CLEAR DNS CACHE,SYSTEM DROP DNS,DROP DNS CACHE,DROP DNSSYSTEM DROP MARK CACHE. Уровень:GLOBAL. Псевдонимы:SYSTEM CLEAR MARK CACHE,SYSTEM DROP MARK,DROP MARK CACHE,DROP MARKSSYSTEM DROP UNCOMPRESSED CACHE. Уровень:GLOBAL. Псевдонимы:SYSTEM CLEAR UNCOMPRESSED CACHE,SYSTEM DROP UNCOMPRESSED,DROP UNCOMPRESSED CACHE,DROP UNCOMPRESSED
SYSTEM RELOAD. Уровень:GROUPSYSTEM RELOAD CONFIG. Уровень:GLOBAL. Псевдонимы:RELOAD CONFIGSYSTEM RELOAD DICTIONARY. Уровень:GLOBAL. Псевдонимы:SYSTEM RELOAD DICTIONARIES,RELOAD DICTIONARY,RELOAD DICTIONARIESSYSTEM RELOAD EMBEDDED DICTIONARIES. Уровень:GLOBAL. Псевдонимы:RELOAD EMBEDDED DICTIONARIES
SYSTEM MERGES. Уровень:TABLE. Псевдонимы:SYSTEM STOP MERGES,SYSTEM START MERGES,STOP MERGES,START MERGESSYSTEM TTL MERGES. Уровень:TABLE. Псевдонимы:SYSTEM STOP TTL MERGES,SYSTEM START TTL MERGES,STOP TTL MERGES,START TTL MERGESSYSTEM FETCHES. Уровень:TABLE. Псевдонимы:SYSTEM STOP FETCHES,SYSTEM START FETCHES,STOP FETCHES,START FETCHESSYSTEM MOVES. Уровень:TABLE. Псевдонимы:SYSTEM STOP MOVES,SYSTEM START MOVES,STOP MOVES,START MOVESSYSTEM SENDS. Уровень:GROUP. Псевдонимы:SYSTEM STOP SENDS,SYSTEM START SENDS,STOP SENDS,START SENDSSYSTEM DISTRIBUTED SENDS. Уровень:TABLE. Псевдонимы:SYSTEM STOP DISTRIBUTED SENDS,SYSTEM START DISTRIBUTED SENDS,STOP DISTRIBUTED SENDS,START DISTRIBUTED SENDSSYSTEM REPLICATED SENDS. Уровень:TABLE. Псевдонимы:SYSTEM STOP REPLICATED SENDS,SYSTEM START REPLICATED SENDS,STOP REPLICATED SENDS,START REPLICATED SENDS
SYSTEM REPLICATION QUEUES. Уровень:TABLE. Псевдонимы:SYSTEM STOP REPLICATION QUEUES,SYSTEM START REPLICATION QUEUES,STOP REPLICATION QUEUES,START REPLICATION QUEUESSYSTEM SYNC REPLICA. Уровень:TABLE. Псевдонимы:SYNC REPLICASYSTEM RESTART REPLICA. Уровень:TABLE. Псевдонимы:RESTART REPLICASYSTEM FLUSH. Уровень:GROUPSYSTEM FLUSH DISTRIBUTED. Уровень:TABLE. Псевдонимы:FLUSH DISTRIBUTEDSYSTEM FLUSH LOGS. Уровень:GLOBAL. Псевдонимы:FLUSH LOGS
SYSTEM RELOAD EMBEDDED DICTIONARIES неявно предоставляется привилегией SYSTEM RELOAD DICTIONARY ON *.*.
INTROSPECTION
INTROSPECTION. Уровень:GROUP. Псевдонимы:INTROSPECTION FUNCTIONSaddressToLine. Уровень:GLOBALaddressToLineWithInlines. Уровень:GLOBALaddressToSymbol. Уровень:GLOBALdemangle. Уровень:GLOBAL
SOURCES
READ. Уровень:GLOBAL_WITH_PARAMETERWRITE. Уровень:GLOBAL_WITH_PARAMETER
AZUREFILEHDFSHIVEJDBCKAFKAMONGOMYSQLNATSODBCPOSTGRESRABBITMQREDISREMOTES3SQLITEURL
Разделение привилегий READ/WRITE для источников доступно начиная с версии 25.7 и только при включённой настройке сервера
access_control_improvements.enable_read_write_grantsВ противном случае следует использовать синтаксис GRANT AZURE ON *.* TO user, который эквивалентен новому GRANT READ, WRITE ON AZURE TO user- Чтобы создать таблицу с движком таблицы MySQL, требуются привилегии
CREATE TABLE (ON db.table_name)иMYSQL. - Чтобы использовать табличную функцию mysql, требуются привилегии
CREATE TEMPORARY TABLEиMYSQL.
Привилегии для фильтрации источников
Эта возможность доступна начиная с версии 25.8 и только при включённой настройке сервера
access_control_improvements.enable_read_write_grantsGRANT OPTION:
Если исходный grant содержит WITH GRANT OPTION, его можно выдать повторно с помощью GRANT CURRENT GRANTS:
- Частичный отзыв не допускается: Нельзя отозвать только часть ранее выданного шаблона фильтра. При необходимости нужно отозвать весь grant и выдать его заново с новыми шаблонами.
- Grant с подстановочными знаками не допускаются: Нельзя использовать
GRANT READ ON *('regexp')или аналогичные шаблоны, состоящие только из подстановочных знаков. Необходимо указать конкретный источник.
dictGet
dictGet. Псевдонимы:dictHas,dictGetHierarchy,dictIsIn
DICTIONARY.
Примеры
GRANT dictGet ON mydb.mydictionary TO johnGRANT dictGet ON mydictionary TO john
displaySecretsInShowAndSelect
SHOW и SELECT, если включены и
display_secrets_in_show_and_select настройка сервера,
и
format_display_secrets_in_show_and_select настройка формата.
NAMED COLLECTION ADMIN
NAMED COLLECTION ADMIN. Уровень:NAMED_COLLECTION. Псевдонимы:NAMED COLLECTION CONTROLCREATE NAMED COLLECTION. Уровень:NAMED_COLLECTIONDROP NAMED COLLECTION. Уровень:NAMED_COLLECTIONALTER NAMED COLLECTION. Уровень:NAMED_COLLECTIONSHOW NAMED COLLECTIONS. Уровень:NAMED_COLLECTION. Псевдонимы:SHOW NAMED COLLECTIONSSHOW NAMED COLLECTIONS SECRETS. Уровень:NAMED_COLLECTION. Псевдонимы:SHOW NAMED COLLECTIONS SECRETSNAMED COLLECTION. Уровень:NAMED_COLLECTION. Псевдонимы:NAMED COLLECTION USAGE, USE NAMED COLLECTION
GRANT CREATE NAMED COLLECTION ON abc TO john
ДВИЖОК ТАБЛИЦЫ
GRANT TABLE ENGINE ON * TO johnGRANT TABLE ENGINE ON TinyLog TO john
По умолчанию, из соображений обратной совместимости, при создании таблицы с конкретным движком таблицы привилегии игнорируются,
однако это поведение можно изменить, установив
table_engines_require_grant в true
в config.xml.READ/WRITE на соответствующий источник. См. Источники.
Например, для движка таблицы AzureBlobStorage может потребоваться следующая привилегия.
GRANT READ, WRITE ON AZURE TO john
ALL
Привилегия
ALL не поддерживается в ClickHouse Cloud, где у пользователя default ограниченные разрешения. Пользователи могут выдать другому пользователю максимальные разрешения, назначив default_role. Подробнее см. здесь.
Пользователи также могут использовать GRANT CURRENT GRANTS от имени пользователя default, чтобы добиться эффекта, аналогичного ALL.NONE
ADMIN OPTION
ADMIN OPTION позволяет пользователю назначить свою роль другому пользователю.