helpful_snippets/MySQL/users.md

101 lines
1.9 KiB
Markdown
Raw Permalink Normal View History

2025-01-22 10:22:37 +01:00
# MySQL users actions
## Show users with hosts
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
SELECT User, Host FROM mysql.user;
```
## Check user privileges
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
SHOW GRANTS FOR 'someuser'@'somehost.somedomain';
```
## Create user
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
CREATE USER 'some_user'@'somehost.somedomain' IDENTIFIED BY 'some_password';
FLUSH PRIVILEGES;
```
## Delete user
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
DROP USER 'some_user'@'somehost.somedomain';
FLUSH PRIVILEGES;
```
## Granting privileges
### Grant all privileges
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
GRANT ALL PRIVILEGES ON *.* TO 'some_user'@'somehost.somedomain' WITH GRANT OPTION;
FLUSH PRIVILEGES;
```
### Grant privilege on database 'some_db'
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
GRANT SELECT ON `some_db`.* TO 'some_user'@'somehost.somedomain';
FLUSH PRIVILEGES;
```
### Grant privilege on table 'some_db'.'some_table'
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
GRANT SELECT ON `some_db`.'some_table' TO 'some_user'@'somehost.somedomain';
FLUSH PRIVILEGES;
```
### Grant privilege to select and update some columns on table 'some_db'.'some_table'
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
GRANT SELECT (id, some_column), UPDATE (some_column) ON `some_db`.`some_table` TO 'some_user'@'somehost.somedomain';
```
### Grant with inheritance
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
GRANT SELECT, INSERT, UPDATE, DELETE ON `some_db`.* TO 'some_user'@'somehost' WITH GRANT OPTION;
FLUSH PRIVILEGES;
```
**'WITH GRANT OPTION'** makes it possible to convey to others what is permitted to oneself.
## Revoking privileges
### Revoke privilege to select from database 'somedb'
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
REVOKE SELECT ON `somedb`.* FROM 'someuser'@'somehost';
FLUSH PRIVILEGES;
```
### Revoke all privileges from user
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
ALL PRIVILEGES ON *.* FROM 'someuser'@'somehost';
FLUSH PRIVILEGES;
```
### Revoke all privileges to database 'somedb' from user
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
ALL PRIVILEGES ON `somedb`.* FROM 'someuser'@'somehost';
FLUSH PRIVILEGES;
```
### Revoke all privileges from user
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'someuser'@'somehost';
FLUSH PRIVILEGES;
```
## Change password
2025-10-16 05:45:04 +02:00
```SQL
2025-01-22 10:22:37 +01:00
ALTER USER 'test_user'@'localhost' IDENTIFIED BY 'new_password';
```