GRANT <privileges>

This statement allocates privileges to a pre-existing user in TiDB. The privilege system in TiDB follows MySQL, where credentials are assigned based on a database/table pattern. Executing this statement requires the GRANT OPTION privilege and all privileges you allocate.

Synopsis

GrantStmt

GRANT - 图1

PrivElemList

GRANT - 图2

PrivElem

GRANT - 图3

PrivType

GRANT - 图4

ObjectType

GRANT - 图5

PrivLevel

GRANT - 图6

UserSpecList

GRANT - 图7

  1. GrantStmt ::=
  2. 'GRANT' PrivElemList 'ON' ObjectType PrivLevel 'TO' UserSpecList RequireClauseOpt WithGrantOptionOpt
  3. PrivElemList ::=
  4. PrivElem ( ',' PrivElem )*
  5. PrivElem ::=
  6. PrivType ( '(' ColumnNameList ')' )?
  7. PrivType ::=
  8. 'ALL' 'PRIVILEGES'?
  9. | 'ALTER' 'ROUTINE'?
  10. | 'CREATE' ( 'USER' | 'TEMPORARY' 'TABLES' | 'VIEW' | 'ROLE' | 'ROUTINE' )?
  11. | 'TRIGGER'
  12. | 'DELETE'
  13. | 'DROP' 'ROLE'?
  14. | 'PROCESS'
  15. | 'EXECUTE'
  16. | 'INDEX'
  17. | 'INSERT'
  18. | 'SELECT'
  19. | 'SUPER'
  20. | 'SHOW' ( 'DATABASES' | 'VIEW' )
  21. | 'UPDATE'
  22. | 'GRANT' 'OPTION'
  23. | 'REFERENCES'
  24. | 'REPLICATION' ( 'SLAVE' | 'CLIENT' )
  25. | 'USAGE'
  26. | 'RELOAD'
  27. | 'FILE'
  28. | 'CONFIG'
  29. | 'LOCK' 'TABLES'
  30. | 'EVENT'
  31. | 'SHUTDOWN'
  32. ObjectType ::=
  33. 'TABLE'?
  34. PrivLevel ::=
  35. '*' ( '.' '*' )?
  36. | Identifier ( '.' ( '*' | Identifier ) )?
  37. UserSpecList ::=
  38. UserSpec ( ',' UserSpec )*

Examples

  1. mysql> CREATE USER 'newuser' IDENTIFIED BY 'mypassword';
  2. Query OK, 1 row affected (0.02 sec)
  3. mysql> GRANT ALL ON test.* TO 'newuser';
  4. Query OK, 0 rows affected (0.03 sec)
  5. mysql> SHOW GRANTS FOR 'newuser';
  6. +-------------------------------------------------+
  7. | Grants for newuser@% |
  8. +-------------------------------------------------+
  9. | GRANT USAGE ON *.* TO 'newuser'@'%' |
  10. | GRANT ALL PRIVILEGES ON test.* TO 'newuser'@'%' |
  11. +-------------------------------------------------+
  12. 2 rows in set (0.00 sec)

MySQL compatibility

  • Similar to MySQL, the USAGE privilege denotes the ability to log into a TiDB server.
  • Column level privileges are not currently supported.
  • Similar to MySQL, when the NO_AUTO_CREATE_USER sql mode is not present, the GRANT statement will automatically create a new user with an empty password when a user does not exist. Removing this sql-mode (it is enabled by default) presents a security risk.
  • In TiDB, after the GRANT <privileges> statement is executed successfully, the execution result takes effect immediately on the current connection. Whereas in MySQL, for some privileges, the execution results take effect only on subsequent connections. See TiDB #39356 for details.

See also