如何修改mysql数据库中的用户名和密码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何修改mysql数据库中的用户名和密码相关的知识,希望对你有一定的参考价值。

首先应该知道mysql数据库中的口令存储必须用password()函数加密它。因为在user表中是以加密形式存储口令,而不是作为纯文本。如果没有加密,直接在数据库中执行以下语句:
use mysql insert into user (host,user,password) values(%,user_name,your password);
flush privileges;
相信结果不会满意。因为服务器比较的是加密的值,所以服务器连接一定失败。
这里需要说明的是flush privileges;这条命令起到了重新加载授权表。也可以在shell下直接用mysqladmin -u root reload或者mysqladmin -u root flush-privileges来实现重载授权表。
在Mysql环境下,可以使用以下语句进行设置密码:
1 insert into user(host,user,password) values(%,user_name,password("your password");
2 set password for user_name = password("your password")
以上两种方法都必须进行重载授权表。
3 当然也可以在创建一个用户时直接设置密码,grant语句将为你自动加密口令。
如:grant all on *.* to user_name@% identified by "your password";
另外也可以在shell环境下用mysqladmin程序来设置密码。
参考技术A

mysql的用户与密码都在系统表 `mysql`.`user` 里,只要修改相应的字段就可以了。

USE mysql;
UPDATE `user` SET `authentication_string`=PASSWORD('123456') WHERE `User`='user';
FLUSH PRIVILEGES;

其中,123456是密码,user是用户,你如果要该用户名的话 ,注意where后面的条件就可以了,

UPDATE `user` SET `User`='user2',`authentication_string`=PASSWORD('123456') WHERE `User`='user';
FLUSH PRIVILEGES;

我的mysql版本是:5.7.12

SELECT VERSION();

本回答被提问者采纳
参考技术B 方法一:
(适用于管理员或者有全局权限的用户重设其它用户的密码)
进入命令行模式
mysql -u root -p

mysql>use mysql;
mysql> UPDATE user SET password=PASSWORD("new password") WHERE user='username';
mysql> FLUSH PRIVILEGES;
mysql> quit;

方法二:
mysql -u root -p
mysql>use mysql;
mysql> SET PASSWORD FOR username=PASSWORD('new password');
mysql> QUIT

方法三:
mysqladmin -u root "old password" "new password"

mysql 用户创建,修改和忘记root密码的操作

#创建用户
CREATE USER ‘zzq‘@‘localhost‘ IDENTIFIED by ‘zzq‘;
#flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里。
#MySQL用户数据和权限有修改后,希望在"不重启MySQL服务"的情况下直接生效,那么就需要执行这个命令。
#通常是在修改ROOT帐号的设置后,怕重启后无法再登录进来,那么直接flush之后就可以看权限设置是否生效。
#而不必冒太大风险。
flush privileges;
SELECT PASSWORD(‘zzq‘);
#GRANT创建用户,可以赋予权限
GRANT SELECT,UPDATE ON *.* TO ‘testzzq‘@‘localhost‘ IDENTIFIED by ‘zzq‘;
#删除用户
DROP user ‘zzq‘@‘localhost‘;

#root用户修改自己的密码

mysqladmin -u root -p PASSWORD "root";#新密码一定用双引号,单引号会报错,然后输入原密码就设置成功了。
#也可以用update方法进行修改。set password=PASSWORD(‘新密码‘)

#root用户修改普通给用户的密码
SET PASSWORD FOR ‘testzzq‘@‘localhost‘=PASSWORD(‘newpass‘);
GRANT SELECT,UPDATE,DELETE ON *.* TO ‘testzzq‘@‘localhost‘ IDENTIFIED by ‘zzq‘;
#保证不修改用户权限的前提下,修改用户的密码
GRANT USAGE ON *.* TO ‘testzzq‘@‘localhost‘ IDENTIFIED by ‘zzq‘;


#如果忘记了root的密码,我们可以采取以下的方法进入
windows系统:
net stop MySql 停止mysql服务
运行 mysqld --skip-grant-tables或者 mysqld-nt --skip-grant-tables
运行 mysql -u root
设置新密码即可

Linux,和mac系统
mysqld_safe mysqld-nt --skip-grant-tables

或者 /etc/init.d/mysql start-mysqld --skip-grant-tables
























以上是关于如何修改mysql数据库中的用户名和密码的主要内容,如果未能解决你的问题,请参考以下文章

如何MySQL和MariaDB数据库修改root密码

Mysql如何修改用户密码

ubuntu下root用户名进不去mysql,如何查看用户名和密码,如何修改root密码,ubuntumysql

如何MySQL和MariaDB数据库修改root密码

如何修改MySql数据库的用户名和密码?

如何修改连接mysql的用户名和密码