mysql 修改普通用户密码_修改mysql中普通用户的密码

为mysql建立普通用户的连接,在mysql数据库的mysql库中,在user表中建立了新用户后,一般是空密码,需要修改密码,最简单的方法是:

1.用root登录mysql:mysql -u root -p root的密码,进入mysql>状态;

2.mysql> UPDATE user SET password=PASSWORD('新密码') WHERE user='已创建的普通用户名';

3.mysql> grant select on 要授权使用的数据库名.* to '普通用户名'@'%';

4.mysql> flush privileges;

mysql用户管理

给mysql的管理员设了密码后,登陆和关闭

[root@test81 mysql]# bin/mysqladmin -uroot -p123 shutdown

mysql只有启动后,才可以登陆

[root@test81 mysql]# bin/mysql -uroot

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

启动后

匿名用户都可以登陆,执行相关操作。具有information_schema和test库的相关权限.

[root@test81 mysql]# bin/mysql -ux3

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 1

Server version: 5.1.44-log MySQL Community Server (GPL)

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| test               |

+--------------------+

2 rows in set (0.00 sec)

------------------

删除匿名用户的办法

让匿名用户只能登陆information_schema库

mysql> drop user ''@'localhost';

mysql> drop user ''@'%';

直接删除用户

mysql> delete from user where user='';

Query OK, 2 rows affected (0.00 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

[root@test81 mysql]# bin/mysql -ux3

ERROR 1045 (28000): Access denied for user 'x3'@'localhost' (using password: NO)

------------------------

以root用户登陆时,必须需要密码。

----------

mysql> create database test1;

Query OK, 1 row affected (0.00 sec)

通过grant命令创建用户。

mysql> grant select,insert,update,delete on test1.* to 'z2'@'%' identified by '123';

Query OK, 0 rows affected (0.00 sec)

直接操作权限表。因db表存在于mysql库中,所以要先选择库

mysql> insert into db (host,db,user,select_priv,insert_priv,update_priv,delete_priv) values('%','test1','z2','Y','Y','Y','Y');

ERROR 1046 (3D000): No database selected

mysql> use mysql

Database changed

mysql> insert into db (host,db,user,select_priv,insert_priv,update_priv,delete_priv) values('%','test1','z2','Y','Y','Y','Y');

Query OK, 1 row affected (0.01 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.01 sec)

记得执行以上的命令,否则不会立即生效。

-----------查看或更改账户权限

show grants for user@host;

mysql> show grants for z2@'%';

+---------------------------------------------------------------------------------------------------+

| Grants for z2@%                                                                                   |

+---------------------------------------------------------------------------------------------------+

| GRANT USAGE ON *.* TO 'z2'@'%' IDENTIFIED BY PASSWORD '*23AE809DDACAF96AF0FD78ED04B6A265E05AA257' |

| GRANT SELECT, INSERT, UPDATE, DELETE ON `test`.* TO 'z2'@'%'                                      |

| GRANT SELECT, INSERT, UPDATE, DELETE ON `test1`.* TO 'z2'@'%'                                     |

+---------------------------------------------------------------------------------------------------+

3 rows in set (0.00 sec)

----看如下的命令所返回的值,直接user,user后默认是@‘%’,只有这种情况是可以的。相对于z5用户就会报错了。

mysql> show grants for z2;

+---------------------------------------------------------------------------------------------------+

| Grants for z2@%                                                                                   |

+---------------------------------------------------------------------------------------------------+

| GRANT USAGE ON *.* TO 'z2'@'%' IDENTIFIED BY PASSWORD '*23AE809DDACAF96AF0FD78ED04B6A265E05AA257' |

| GRANT SELECT, INSERT, UPDATE, DELETE ON `test`.* TO 'z2'@'%'                                      |

| GRANT SELECT, INSERT, UPDATE, DELETE ON `test1`.* TO 'z2'@'%'                                     |

+---------------------------------------------------------------------------------------------------+

3 rows in set (0.00 sec)

mysql> show grants for z1;

+---------------------------------------------------------------------------------------------------+

| Grants for z1@%                                                                                   |

+---------------------------------------------------------------------------------------------------+

| GRANT USAGE ON *.* TO 'z1'@'%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |

+---------------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

mysql> show grants for z5;

ERROR 1141 (42000): There is no such grant defined for user 'z5' on host '%'

mysql>

新版本的mysql-5.0以后的版本,也可以通过information_schema库进行权限的查看。

mysql> use information_schema;

Database changed

mysql> select * from SCHEMA_PRIVILEGES where grantee="'z1'@'localhost'";

+------------------+---------------+--------------+-------------------------+--------------+

| GRANTEE          | TABLE_CATALOG | TABLE_SCHEMA | PRIVILEGE_TYPE          | IS_GRANTABLE |

+------------------+---------------+--------------+-------------------------+--------------+

| 'z1'@'localhost' | NULL          | test         | SELECT                  | YES          |

| 'z1'@'localhost' | NULL          | test         | INSERT                  | YES          |

| 'z1'@'localhost' | NULL          | test         | UPDATE                  | YES          |

| 'z1'@'localhost' | NULL          | test         | DELETE                  | YES          |

| 'z1'@'localhost' | NULL          | test         | CREATE                  | YES          |

| 'z1'@'localhost' | NULL          | test         | DROP                    | YES          |

| 'z1'@'localhost' | NULL          | test         | REFERENCES              | YES          |

| 'z1'@'localhost' | NULL          | test         | INDEX                   | YES          |

| 'z1'@'localhost' | NULL          | test         | ALTER                   | YES          |

| 'z1'@'localhost' | NULL          | test         | CREATE TEMPORARY TABLES | YES          |

| 'z1'@'localhost' | NULL          | test         | LOCK TABLES             | YES          |

| 'z1'@'localhost' | NULL          | test         | EXECUTE                 | YES          |

| 'z1'@'localhost' | NULL          | test         | CREATE VIEW             | YES          |

| 'z1'@'localhost' | NULL          | test         | SHOW VIEW               | YES          |

| 'z1'@'localhost' | NULL          | test         | CREATE ROUTINE          | YES          |

| 'z1'@'localhost' | NULL          | test         | ALTER ROUTINE           | YES          |

| 'z1'@'localhost' | NULL          | test         | EVENT                   | YES          |

| 'z1'@'localhost' | NULL          | test         | TRIGGER                 | YES          |

+------------------+---------------+--------------+-------------------------+--------------+

18 rows in set (0.00 sec)

mysql> select * from SCHEMA_PRIVILEGES where grantee="'z2'@'%'";

+----------+---------------+--------------+----------------+--------------+

| GRANTEE | TABLE_CATALOG | TABLE_SCHEMA | PRIVILEGE_TYPE | IS_GRANTABLE |

+----------+---------------+--------------+----------------+--------------+

| 'z2'@'%' | NULL          | test         | SELECT         | NO           |

| 'z2'@'%' | NULL          | test         | INSERT         | NO           |

| 'z2'@'%' | NULL          | test         | UPDATE         | NO           |

| 'z2'@'%' | NULL          | test         | DELETE         | NO           |

| 'z2'@'%' | NULL          | test1        | SELECT         | NO           |

| 'z2'@'%' | NULL          | test1        | INSERT         | NO           |

| 'z2'@'%' | NULL          | test1        | UPDATE         | NO           |

| 'z2'@'%' | NULL          | test1        | DELETE         | NO           |

+----------+---------------+--------------+----------------+--------------+

8 rows in set (0.00 sec)

附:必须使用表内的相关描述才能返回,以下z2@‘%’就为空。

mysql> select * from SCHEMA_PRIVILEGES where grantee="z2@'%'";

Empty set (0.00 sec)

----------更改权限

mysql> show grants for z1@localhost \G;

*************************** 1. row ***************************

Grants for z1@localhost: GRANT ALL PRIVILEGES ON *.* TO 'z1'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' WITH GRANT OPTION

*************************** 2. row ***************************

Grants for z1@localhost: GRANT ALL PRIVILEGES ON `test`.* TO 'z1'@'localhost' WITH GRANT OPTION

2 rows in set (0.00 sec)

ERROR:

No query specified

mysql> show grants for z2@localhost \G;

ERROR 1141 (42000): There is no such grant defined for user 'z2' on host 'localhost'

ERROR:

No query specified

可能看出Z2对localhost没有权限

----赋予z2对localhost上的所有库的两个权限,执行后只列出了select 权限。

mysql> show grants for z2@localhost;

+----------------------------------------+

| Grants for z2@localhost                |

+----------------------------------------+

| GRANT USAGE ON *.* TO 'z2'@'localhost' |

+----------------------------------------+

1 row in set (0.00 sec)

mysql> grant select on *.* to z2@localhost;

Query OK, 0 rows affected (0.00 sec)

mysql> show grants for z2@localhost;

+-----------------------------------------+

| Grants for z2@localhost                 |

+-----------------------------------------+

| GRANT SELECT ON *.* TO 'z2'@'localhost' |

+-----------------------------------------+

1 row in set (0.00 sec)

继续给z2赋予权限,进行select,insert的合并

mysql> grant select,insert on *.* to z2@localhost;

Query OK, 0 rows affected (0.00 sec)

mysql> show grants for z2@localhost;

+-------------------------------------------------+

| Grants for z2@localhost                         |

+-------------------------------------------------+

| GRANT SELECT, INSERT ON *.* TO 'z2'@'localhost' |

+-------------------------------------------------+

1 row in set (0.00 sec)

-----

收回权限,使用revoke,注意,这里是from而不是to了

mysql> revoke select,insert on *.* from z2@localhost;

Query OK, 0 rows affected (0.00 sec)

mysql> show grants for z2@localhost;

+----------------------------------------+

| Grants for z2@localhost                |

+----------------------------------------+

| GRANT USAGE ON *.* TO 'z2'@'localhost' |

+----------------------------------------+

1 row in set (0.00 sec)

只剩下USAGE的权限了,revoke只进行权限的收回,并不会删除用户。

但USAGE的权限却不能被收回。

mysql> revoke usage on *.* from z2@localhost;

Query OK, 0 rows affected (0.00 sec)

mysql> show grants for z2@localhost;

+----------------------------------------+

| Grants for z2@localhost                |

+----------------------------------------+

| GRANT USAGE ON *.* TO 'z2'@'localhost' |

+----------------------------------------+

1 row in set (0.00 sec)

----------------修改密码

法一:

mysqladmin -u user_name -h host_name password "newpwd"

修改root密码

[root@test81 mysql]# bin/mysqladmin -u root -p123456 password '123'

法二:

mysql> set password for 'user'@'host_name'= password('1234');

修改自己的密码可以这么做

mysql> set password = password('1234');

Query OK, 0 rows affected (0.00 sec)

法三:

mysql> grant usage on *.* to 'root'@'localhost' identified by '12345';

法四:

mysql> use mysql

Database changed

mysql> update user set password=password('123456') where Host='localhost' and User='root';

Query OK, 1 row affected (0.00 sec)

Rows matched: 1 Changed: 1 Warnings: 0

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

也可以先建立用户

mysql> insert into user

-> (Host,User,Password)

-> VALUES('','',PASSWORD(''))

-> ;

Query OK, 1 row affected, 3 warnings (0.00 sec)

---------删除用户

mysql> show grants for z3@localhost;

+-------------------------------------------------------+

| Grants for z3@localhost                               |

+-------------------------------------------------------+

| GRANT PROCESS, FILE, SUPER ON *.* TO 'z3'@'localhost' |

+-------------------------------------------------------+

1 row in set (0.00 sec)

mysql> drop user z3@localhost;

Query OK, 0 rows affected (0.00 sec)

mysql> show grants for z3@localhost;

ERROR 1141 (42000): There is no such grant defined for user 'z3' on host 'localhost'

Mysql的安全问题

一。严格控制操作系统账号和权限,

锁定mysql

其他用户都采用独立方式,管理员通过专有用户或通过root su到mysql用户下管理

mysql用户目录下除了数据文件外,其他文件和目录都属主为root

二。避免用root运行mysql

[root@test81 mysql]# bin/mysql --user=root &

不能使用该命令。

一般使用--user=mysql

注:测试时,使用root,再无法使用mysql 用户启动,原因是

100813 23:36:05 [ERROR] Failed to open log (file './mysql-bin.000017', errno 13)

100813 23:36:05 [ERROR] Could not open log file

100813 23:36:05 [ERROR] Can't init tc log

100813 23:36:05 [ERROR] Aborting

修改file './mysql-bin.000017'的属主属组为mysql即可。

三。mysql的相关安全问题

删除匿名用户:

删除匿名用户的办法

让匿名用户只能登陆information_schema库

mysql> use msyql

mysql> select * from user \G'

mysql> select * from db \G'

mysql> drop user ''@'localhost';

mysql> drop user ''@'%';

直接删除用户

mysql> delete from user where user='';

Query OK, 2 rows affected (0.00 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

给root账户设置口令

设置安全密码

密码直接写在命令行

交互式登陆

用户名和密码写在配置文件中/etc/my.cnf

[client]

user            = root

password        = 123456

[root@test81 mysql]# bin/mysql

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 2

Server version: 5.1.44-log MySQL Community Server (GPL)

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> select current_user();

+----------------+

| current_user() |

+----------------+

| root@localhost |

+----------------+

1 row in set (0.00 sec)

只授予必须的权限

all privileges的权限除了grant外的全部

一般的权限如select,insert,update,delete

除root外,其他用户不应该有mysql库中的user表的存取权限

用root登陆数据库后,赋予z3的相关权限

mysql> grant select,insert, update,delete on mysql.user to z3@localhost;

mysql> show grants for z3@localhost;

+----------------------------------------------------------------------------+

| Grants for z3@localhost                                                    |

+----------------------------------------------------------------------------+

| GRANT USAGE ON *.* TO 'z3'@'localhost'                                     |

| GRANT SELECT, INSERT, UPDATE, DELETE ON `mysql`.`user` TO 'z3'@'localhost' |

+----------------------------------------------------------------------------+

2 rows in set (0.00 sec)

mysql> exit

[root@test81 mysql]# bin/mysql -uz3

ERROR 1045 (28000): Access denied for user 'z3'@'localhost' (using password: YES)

[root@test81 tmp]# vi /etc/my.cnf

[client]

#user           = root

#password       = 123456

[root@test81 mysql]# bin/mysql -uz3

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 3

Server version: 5.1.44-log MySQL Community Server (GPL)

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> use mysql

Database changed

mysql> show tables;

+-----------------+

| Tables_in_mysql |

+-----------------+

| user            |

+-----------------+

1 row in set (0.00 sec)

mysql> update user set password=password('abcd') where user='root' and host='localhost';

Query OK, 1 row affected (0.00 sec)

Rows matched: 1 Changed: 1 Warnings: 0

mysql> flush privileges;

ERROR 1227 (42000): Access denied; you need the RELOAD privilege for this operation

不能使用该选项,为root所有。

----使用root 登陆还是可以的,但刷新数据库后,再登陆就报错了

[root@test81 mysql]# bin/mysql -uroot -p123456

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 5

Server version: 5.1.44-log MySQL Community Server (GPL)

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

mysql> \q

[root@test81 mysql]# bin/mysql -uroot -p123456

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

[root@test81 mysql]# bin/mysql -uroot -pabcd

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 7

Server version: 5.1.44-log MySQL Community Server (GPL)

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

阅读(2895) | 评论(0) | 转发(0) |

你可能感兴趣的:(mysql,修改普通用户密码)