iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql数据库的超级管理员密码怎么修改
  • 620
分享到

mysql数据库的超级管理员密码怎么修改

mysql数据库 2023-01-31 21:01:47 620人浏览 八月长安
摘要

这篇文章主要介绍“Mysql数据库的超级管理员密码怎么修改”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql数据库的超级管理员密码怎么修改”文章能帮助大家解决

这篇文章主要介绍“Mysql数据库的超级管理员密码怎么修改”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql数据库的超级管理员密码怎么修改”文章能帮助大家解决问题。

mysql数据库的超级管理员名称是“root”。MySQL在安装时,会默认创建一个名为root的用户,该用户拥有超级权限,可以控制整个MySQL服务器。root用户拥有很高的权限,不仅可以修改自己的密码,还可以修改其他用户的密码。

mysql数据库的超级管理员名称是“root”。

MySQL 在安装时,会默认创建一个名为 root 的用户,该用户拥有超级权限,可以控制整个 MySQL 服务器。

在对 MySQL 的日常管理和操作中,为了避免有人恶意使用 root 用户控制数据库,我们通常创建一些具有适当权限的用户,尽可能地不用或少用 root 用户登录系统,以此来确保数据的安全访问。

一般root超级管理员的权限会比一般用户的权限大很多,所以有些操作要root权限才能运行。

root 用户拥有很高的权限,不仅可以修改自己的密码,还可以修改其他用户的密码。

MySQL修改root密码

在 MySQL 中,root 用户拥有很高的权限,因此必须保证 root 用户密码的安全。修改 root 用户密码的方式有很多种,本节将介绍几种常用的修改 root 用户密码的方法。

  • 修改MySQL数据库的user表

因为所有账户信息都保存在 user 表中,因此可以直接通过修改 user 表来改变 root 用户的密码。

root 用户登录到 MySQL 服务器后,可以使用 UPDATE 语句修改 MySQL 数据库的 user 表的 authentication_string 字段,从而修改用户的密码。

使用 UPDATA 语句修改 root 用户密码的语法格式如下:

UPDATE mysql.user set authentication_string = PASSWord ("rootpwd) WHERE User = "root" and Host="localhost";

新密码必须使用 PASSWORD() 函数来加密。执行UPDATE语句后,需要执行FLUSH PRIVILEGES语句重新加载用户权限。

  • 使用SET语句修改root用户的密码

SET PASSWORD 语句可以用来重新设置其他用户的登录密码或者自己使用的账户的密码。使用 SET 语句修改密码的语法结构如下:

SET PASSWORD = PASSWORD ("rootpwd");

MySQL root修改普通用户密码

  • 使用SET语句修改普通用户的密码

在 MySQL 中,只有 root 用户可以通过更新 MySQL 数据库来更改密码。使用 root 用户登录到 MySQL 服务器后,可以使用 SET 语句来修改普通用户密码。语法格式如下:

SET PASSWORD FOR 'username'@'hostname' = PASSWORD ('newpwd');

其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。

注意:新密码必须使用 PASSWORD() 函数来加密,如果不使用 PASSWORD() 加密,也会执行成功,但是用户会无法登录。

如果是普通用户修改密码,可省略 FOR 子句来更改自己的密码。语法格式如下:

SET PASSWORD = PASSWORD('newpwd');

示例 1

root 用户登录 MySQL 服务器后,再使用 SET 语句将 testuser 用户的密码修改为“newpwd”,SQL 语句和运行结果如下:

mysql> SET PASSWORD FOR 'testuser'@'localhost' = PASSWORD("newpwd");
Query OK, 0 rows affected, 1 warning (0.01 sec)

由运行结果可以看出,SET 语句执行成功,testuser 用户的密码被成功设置为“newpwd”。

  • 使用UPDATE语句修改普通用户的密码

使用 root 用户登录 MySQL 服务器后,可以使用 UPDATE 语句修改 MySQL 数据库的 user 表的 authentication_string 字段,从而修改普通用户的密码。UPDATA 语句的语法如下:

UPDATE MySQL.user SET authentication_string = PASSWORD("newpwd") WHERE User = "username" AND Host = "hostname";

其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。

注意,执行 UPDATE 语句后,需要执行 FLUSH PRIVILEGES 语句重新加载用户权限。

示例 3

使用 root 用户登录 MySQL 服务器,再使用 UPDATE 语句将 testuser 用户的密码修改为“newpwd2”的 SQL 语句和运行结果如下:

mysql> UPDATE MySQL.user SET authentication_string = PASSWORD ("newpwd2")
    -> WHERE User = "testuser" AND Host = "localhost";
Query OK, 1 row affected, 1 warning (0.07 sec)
Rows matched: 1  Changed: 1  Warnings: 1
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.03 sec)

由运行结果可以看出,密码修改成功。testuser 的密码被修改成了 newpwd2。使用 FLUSH PRIVILEGES 重新加载权限后,就可以使用新的密码登录 testuser 用户了。

删除MySQL的默认root用户

需求分析:

  • root密码在多个地方出现过,比如分享的技术文档,邮件,截图.

  • MySQL默认安装的管理员帐号名称root,众所周知.为了增强安全性,需要更换一个用户名称,例如换成superuser,或者有公司特色的.例如xxx_admin.

应对策略:

  • 首先创建一个与root用户权限一样的用户.

GRANT ALL PRIVILEGES ON *.* TO 'x_admin'@'127.0.0.1' IDENTIFIED BY 'xxxx';

  • 删除默认的root用户.

drop user root@'127.0.0.1';
drop user root@'localhost';
drop user root@'::1';

用户账号:

格式为 user_name'@'host_name。

这里的user_name是用户名,host_name为主机名,即用户连接 MySQL 时所用主机的名字。

如果在创建的过程中,只给出了用户名,而没指定主机名,那么主机名默认为“%”,表示一组主机,即对所有主机开放权限。

注意问题:

1、视图

曾经用root帐号为DEFINER的视图,如果将root删除,将提示该视图无法使用,没有权限.所以要注意提前查看是否存在视图,存在的话,需要修改该视图的DEFINER属性.

修改视图,是瞬间就能完成的操作,除非该视图被其他sql语句占用,处于定的状态.

查看视图

select TABLE_SCHEMA, TABLE_NAME, VIEW_DEFINITION, DEFINER from infORMation_schema.VIEWS;

修改视图(非root的暂不修改)

ALTER DEFINER=`x_admin`@`127.0.0.1` SQL SECURITY DEFINER VIEW v_name AS...

2、存储过程/函数

情况与视图类似

查看存储过程/视图

select ROUTINE_SCHEMA,ROUTINE_NAME,ROUTINE_TYPE,DEFINER from information_schema.ROUTINES;

或者

select db,name,type,definer from mysql.proc;

修改存储例程,可直接修改mysql.proc

update mysql.proc set definer='x_admin@127.0.0.1'where db='db_name';

如果修改所有库

update mysql.proc set definer='x_admin@127.0.0.1';

2、用root用户连接MySQL的脚本

此类问题比较好解决,可单独为脚本创建帐号用来执行脚本中指定的操作,该用户名可用script_,或者脚本名命名.权限够用就行,不要分配过多的权限.

4、方法:一个增加用户的脚本.(配合批量执行)

#!/usr/bin/python
#-*- coding: UTF-8 -*-
# ########################################################################
# This program
# Version: 2.0.0 (2012-10-10)
# Authors: lianjie.ning@qunar.com
# History:
# ########################################################################

import os
import Socket
import subprocess
import sys
import traceback
from ConfigParser import ConfigParser

class Finger(object):
   'finger.py'

   def __init__ (self):
       print '---- %s, %s' % (socket.gethostname(), self.__doc__)

   def load_config (self, file="finger.ini"):
       if not os.path.exists(file):
           print file,"is not exists, but is created, please fix it"
           temp_ini = '''[conn_db]
login_pwd =
exec_sql =
'''
           open(file, 'w').write(temp_ini)
           os.chmod(file, 0600)
           sys.exit()
       config = ConfigParser()
       config.read(file)
       if config.has_section('conn_db') is True:
           if config.has_option('conn_db', 'login_pwd') is True:
               login_pwd = config.get('conn_db', 'login_pwd')
           if config.has_option('conn_db', 'exec_sql') is True:
               exec_sql = config.get('conn_db', 'exec_sql')
           return (login_pwd, exec_sql)

   def grant_user(self, login_pwd, exec_sql):
       if os.path.exists('/usr/local/bin/mysql'):
           mysql = '/usr/local/bin/mysql'
       elif os.path.exists('/usr/bin/mysql'):
           mysql = '/usr/bin/mysql'
       elif os.path.exists('/bin/mysql'):
           mysql = '/bin/mysql'
       else:
           print "command not fount of mysql"
           sys.exit()

       user = 'xxxx'
       conn_port = [3306,3307,3308,3309,3310]
       for i in conn_port:
           ss = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
           address = ('127.0.0.1', int(i))
           status = ss.connect_ex(address)
           ss.settimeout(3)
           ss.close()
           if status == 0:
               conn_mysql  = '%s -u%s -p%s -h227.0.0.1 -P%d -N -s -e"%s"' % (mysql, user, login_pwd, i, exec_sql)
               p = subprocess.call(conn_mysql, shell=True, stdout=open("/dev/null"))
               if p == 0:
                   print "---- checking port: %s is NORMAL" % i
               else:
                   print "---- checking prot: %s is ERROR" % i

if __name__ == '__main__':
   try:
       process = Finger()
       (login_pwd, exec_sql) = process.load_config()
       process.grant_user(login_pwd, exec_sql)
   except Exception, e:
       print str(e)
       traceback.print_exc()
       sys.exit()

关于“mysql数据库的超级管理员密码怎么修改”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网数据库频道,小编每天都会为大家更新不同的知识点。

您可能感兴趣的文档:

--结束END--

本文标题: mysql数据库的超级管理员密码怎么修改

本文链接: https://www.lsjlt.com/news/193772.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql数据库的超级管理员密码怎么修改
    这篇文章主要介绍“mysql数据库的超级管理员密码怎么修改”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql数据库的超级管理员密码怎么修改”文章能帮助大家解决...
    99+
    2023-01-31
    mysql数据库
  • mysql怎么修改管理员密码
    这篇文章主要讲解了“mysql怎么修改管理员密码”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql怎么修改管理员密码”吧! ...
    99+
    2022-10-18
  • mysql数据库忘记管理员密码怎么办
    这篇文章主要介绍mysql数据库忘记管理员密码怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.输入命令  mysqld --skip-grant-tables (前...
    99+
    2022-10-18
  • 帝国cms怎么修改管理员密码
    帝国cms修改管理员密码方法:1、登录后台管理界面;2、找到管理员设置;3、进入管理员设置界面;4、修改管理员密码;5、输入新密码;6、确认密码修改;7、保存密码修改;8、测试新密码。本教程操作环境:windows10系统、帝国cms7.5...
    99+
    2023-07-25
  • mysql数据库管理员密码忘记了怎么办
    小编给大家分享一下mysql数据库管理员密码忘记了怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!我们在Windows操作系...
    99+
    2022-10-18
  • MySQL数据库中怎么修改密码
    今天就跟大家聊聊有关MySQL数据库中怎么修改密码,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  MySQL数据库修改MySQL密码有哪些措施  ...
    99+
    2022-10-18
  • 怎样修改mysql数据库的密码
    本篇内容介绍了“怎样修改mysql数据库的密码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mysql忘记...
    99+
    2022-10-18
  • 云服务器怎么修改管理员密码
    在云服务器中更改管理员密码的方法:1.远程登录云服务器;2.打开计算机管理窗口;3.查找administrator管理员用户选项;4.右键点击“设置密码”选项;5.填写管理员密码,确认;具体步骤如下:首先,远程登录云服务器,进入到云服务器操...
    99+
    2022-10-23
  • XP系统超级管理员密码忘记了怎么办
    这篇文章主要讲解了“XP系统超级管理员密码忘记了怎么办”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“XP系统超级管理员密码忘记了怎么办”吧!什么是管理员密码 安装系统时自动生成的第一个用户,...
    99+
    2023-06-14
  • 修改XAMPP中mysql数据库的密码
    修改XAMPP中MySQL数据库的密码XAMPP只为开发者服务,不可将其用于生产环境。首先,MySQL管理员(root)未设置密码,用户可以直接通过phpmyadmin访问mysql服务器,修改数据库中的数...
    99+
    2022-10-18
  • navicat怎么修改数据库密码
    navicat中修改数据库密码的方法:1、打开navicat工具;2、连接数据库;3、点击顶部“用户”菜单栏;4、选择需要修改密码的数据库用户进行编辑;5、最后在用户信息对话框中重新设置密码并点击“保存”使其生效即可。具体操作步骤:打开na...
    99+
    2022-10-11
  • 数据库 之 更改用户密码和忘记管理员密码解决方法
    1  正常更改用户密码记得密码的情况下,有以下三个方法修改用户密码:(1) SET PASSWORD [FOR 'user'@'host'] = PASSWOR&#...
    99+
    2022-10-18
  • 怎么使用phpMyAdmin修改数据库密码
    这篇文章给大家分享的是有关怎么使用phpMyAdmin修改数据库密码的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。第一步,点击phpMyAdmin里的用户选项选择root loc...
    99+
    2022-10-18
  • sql数据库中怎么修改sa密码
    这期内容当中小编将会给大家带来有关sql数据库中怎么修改sa密码,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、如何修改SQL Server 2000身份验证模式? 分...
    99+
    2022-10-18
  • phpStudy V8怎么修改数据库root密码
    这篇文章将为大家详细讲解有关phpStudy V8怎么修改数据库root密码,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。phpStudy V8如何修改数据库root密码?phpStudy V8修改数据库...
    99+
    2023-06-07
  • java怎么修改数据库个人密码
    要修改数据库个人密码,你需要使用Java程序连接数据库并执行相应的SQL语句。首先,你需要导入相应的数据库连接驱动。根据你所使用的数...
    99+
    2023-08-15
    java 数据库
  • win7怎么解决管理员账户无法修改密码问题
    这篇文章将为大家详细讲解有关win7怎么解决管理员账户无法修改密码问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在桌面上找到计算机图标,右键计算机点击打开计算机“管理”项。在计算机管理界面,依次展开本...
    99+
    2023-06-28
  • 如何在Navicat中修改MySQL数据库的密码
    本篇文章为大家展示了如何在Navicat中修改MySQL数据库的密码,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。方法1: 用SET PASSWORD命令 首先登录...
    99+
    2022-10-18
  • Mysql数据库--修改root密码的几种方法(忘记密码&知道密码)
    Mysql数据库--修改root密码的几种方法(忘记密码&知道密码) 🔻一、知道密码情况--修改root密码⛳ 1.1 方式1:`alter` 命令修改⛳ 1.2 方式2:`s...
    99+
    2023-09-11
    mysql 数据库 mysql修改root密码 mysql忘记root密码 linux 运维 服务器
  • 修改Mysql数据库的用户名和密码【详细】
    数据库的用户名默认是root 1进入到Mysql         首先要登录数据库         1win+r输入cmd【管理员身份打开】或者  2搜索输入命令提示符。 2 输入mysql -uroot -p点击回车         注...
    99+
    2023-09-09
    mysql 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作