MySQL 密码设置_Mysql

一个重要的应用就是如何在遗忘root用户密码的时候修改密码,使用的方法是启动MySQL服务器时忽略加载授权表。
由MySQL使用用户名和口令的方法与Unix或Windows使用的方式有很多不同之处:
  ·MySQL 使用于认证目的的用户名,与Unix用户名(登录名字)或Windows用户名无关。缺省地,大多数MySQL客户尝试使用当前 Unix用户名作为MySQL用户名登录,但是这仅仅为了方便。客户程序允许用-u或--user选项指定一个不同的名字,这意味着无论如何你不能使得一个数据库更安全,除非所有的MySQL用户名都有口令。任何人可以试图用任何名字连接服务器,而且如果他们指定了没有口令的任何名字,他们将成功。
  ·MySQL用户名最长可以是16各字符;典型地,Unix用户名限制为8个字符。
  ·MySQL口令与Unix口令没关系。在你使用登录到一台Unix机器口令和你使用在那台机器上存取一个数据库的口令之间没有必要有关联。
  ·MySQL加密口令使用了一个Unix登录期间所用的不同算法。
  本节将介绍如何为MySQL数据库系统的用户修改密码。
  使用myadmin实用程序
  使用mysqladmin实用程序修改密码的命令行是:
  shell>mysqladmin -u user -p password "newpassword"
  运行这个命令,在提示输入密码时,数据就密码,则用户user的密码就被改为newpassword
  。如果,原来的用户没有密码,则不比指定-p选项。例如,初始化授权表之后,root用户的密码就是空的,你可以这样为root用户设立密码:
  shell>mysqladmin -u root password "newpassword"
  使用语句SET PASSWORD
  使用mysqladmin为用户修改密码有一个明显的缺点,就是必须知道用户原来的密码,如果是为了给遗忘了密码的用户重设密码就无能为力了。一个专门用于修改密码的SQL语句为SET PASSWORD:
  ·SET PASSWORD = PASSWORD('some password')
  设置当前用户的口令。任何非匿名的用户能改变他自己的口令!
  连接到服务器后,你可以这样改变自己的密码:

复制代码 代码如下:

  mysql> SET PASSWORD = PASSWORD('another pass');
  ·SET PASSWORD FOR user = PASSWORD('some password')

  设置当前服务器主机上的一个特定用户的口令。只有具备存取mysql数据库的用户可以这样做。用户应该以user@hostname格式给出,这里 user和hostname完全与他们列在mysql.user表条目的User和Host列一样。例如,如果你有一个条目其User和Host字段是 'bob'和'%.loc.gov',你将写成:
  mysql> SET PASSWORD FOR bob@"%.loc.gov" = PASSWORD("newpass");
  直接修改授权表
  另一种修改,密码的方法是直接修改授权表user。只有具备存取mysql数据库的用户可以这样做。
  例如,如果你有一个条目其User和Host字段是'bob'和'%.loc.gov',你将写成:
  mysql> UPDATE mysql.user SET password=PASSWORD("newpass") where user="bob' AND host="%.loc.gov";
  mysql>FLUSH PRIVILEGES;
  重新设置一个遗忘的root口令
  如果你遗忘了root用户的口令,那么将会是一件非常麻烦的事。除非你有其它有特权的用户,否则很多操作都无法完成,例如,关闭数据库等等。
  你应当选用--without-grant-tables选项启动mysqld服务,你可以在这时更改授权表的相关内容,也可以用mysqlaccess检查你的授权是否到位。
  例如,如果你忘记了你的MYSQL的root口令的话,你可以通过下面的过程恢复。
  1、关闭MySQL服务器
  向mysqld server 发送kill命令关掉mysqld server(不是 kill -9),存放进程ID的文件通常在MYSQL的数据库所在的目录中。
  kill `cat /mysql-data-directory/hostname.pid`
  你必须是UNIX的root用户或者是你所运行的SERVER上的同等用户,才能执行这个操作。
  如果在windows平台上,也可以停止进程。如果是NT还可以用net stop mysql命令关闭数据库。
  2、使用'--skip-grant-tables' 参数来启动 mysqld。
  Unix平台:
  $su mysql
  $safe_mysqld --skip-grant-tables &
  Windows平台:
  C:\mysql\bin>mysqld --skip-grant-tables
  以上语句,假定都位于正确的目录。
  3、连接到服务器,修改口令
  使用'mysql -h hostname mysql'命令登录到mysqld server ,用grant命令改变口令:
  mysql>GRANT ALL ON *.* TO root@localhost INDENTIFIED BY 'new password'
  -> WITH GRANT OPTION;
  mysql>GRANT ALL ON *.* TO root@% INDENTIFIED BY 'new password'
  -> WITH GRANT OPTION;
  (如果存在一个能从任意地址登录的root用户,初始化授权表后,生成该用户,为了安全,你可能已经删除该用户)。
  其实也可以直接修改授权表:
  mysql> use mysql;
  mysql> update user set password =password('yourpass') where user='root';
  你可能使用工具mysqladmin修改密码:
  shell> mysqladmin -h hostname -u root password 'new password
  但是它修改的密码语服务器匹配的用户有关。如果,你从服务器主机连接,那么服务器匹配的是root@localhost,修改该用户密码,否则一般修改root@%密码,除非你有其它root用户存在。
  4. 载入权限表:
  shell> mysqladmin -h hostname flush-privileges
  或者使用 SQL 命令`FLUSH PRIVILEGES'。
  当然,在这里,你也可以重启mysqld。

时间: 2024-11-05 12:13:25

MySQL 密码设置_Mysql的相关文章

Windows环境下重置mysql密码操作命令_Mysql

本地环境:Windows XP系统.xampp集成环境. xampp安装目录:d:/xampp 1.首先停止正在运行的MySQL进程 复制代码 代码如下: >net stop mysql 如未加载为服务,可直接在进程管理器或者服务中进行关闭. 2.以安全模式启动MySQL 进入mysql目录在命令行下运行 复制代码 代码如下: >d: >cd xampp/mysql/bin >mysqld.exe --skip-grant-tables 3.完成以后就可以不用密码进入MySQL了

MySQL的安装以及基本的管理命令和设置_Mysql

MySQL 安装 Linux/UNIX上安装MysqlLinux平台上推荐使用RPM包来安装Mysql,MySQL AB提供了以下RPM包的下载地址: MySQL - MySQL服务器.你需要该选项,除非你只想连接运行在另一台机器上的MySQL服务器. MySQL-client - MySQL 客户端程序,用于连接并操作Mysql服务器. MySQL-devel - 库和包含文件,如果你想要编译其它MySQL客户端,例如Perl模块,则需要安装该RPM包. MySQL-shared - 该软件包

使用SKIP-GRANT-TABLES 解决 MYSQL ROOT密码丢失_Mysql

忘记MySQL(和PHP搭配之最佳组合) ROOT密码是在MySQL(和PHP搭配之最佳组合)使用中很常见的问题,可是有很多朋友并不会重置ROOT密码,那叫苦啊,我有深有感触,特写此文章与大家交流: 1.编辑MySQL(和PHP搭配之最佳组合)配置文件: windows环境中:%MySQL(和PHP搭配之最佳组合)_installdir%\my.ini //一般在MySQL(和PHP搭配之最佳组合)安装目录下有my.ini即MySQL(和PHP搭配之最佳组合)的配置文件. linux环境中:/e

MySQL数据库设置远程访问权限方法小结_Mysql

MySQL基础知识第一期,如何远程访问MySQL数据库设置权限方法总结,讨论访问单个数据库,全部数据库,指定用户访问,设置访问密码,指定访问主机. 1,设置访问单个数据库权限 复制代码 代码如下: mysql>grant all privileges on test.* to 'root'@'%'; 说明:设置用户名为root,密码为空,可访问数据库test 2,设置访问全部数据库权限 复制代码 代码如下: mysql>grant all privileges on *.* to 'root'

MySQL 密码增强插件_Mysql

介绍 以前没有太注意MySQL密码安全策略的配置方法,只是人为了将密码设为复杂密码,但是没有找到配置的方法,今天姜承尧的微信公众号正好发布了一篇关于这个的文章,所以在这里也顺便将方法写下来.首先该功能是在5.5以后的mysql版本才引入的插件,默认源码安装和二进制安装都没有启用该功能,如果没有开启该功能设置简单密码mysql只是会给予提示但还是会允许通过. 启用功能 在my.cnf文件中加入 plugin-load=validate_password.so validate-password=F

MySQL远程访问设置终极方法_Mysql

数据库对于服务端开发人员来说,几乎就是左膀右臂.几乎每一个服务端开发人员都要和数据库打交道.而MySQL又以其开源免费,小巧玲珑,简单易用,功能强大占据中国数据库使用份额的半壁江山.从去年接触到Vagrant以来,Vagrant以其方便易用深深吸引了D瓜哥.为了尽可能地和生产环境保持尽可能的一致性,减少不必要的问题的发生,Vagrant+Ubuntu+MySQL几乎是绝配. MySQL允许远程访问的设置 1.注释bind-address = 127.0.0.1. 复制代码 代码如下: >cd /

详解MySQL数据库的安装与密码配置_Mysql

MySQL是由MySQL AB公司开发,后由Oracle公司收购 MySQL是一个关系型数据库管理系统 分为社区版和企业版 MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言,  由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,搭配 PHP 和 Apache 可组成良好的开发环境  安装方式: 安装方式MSI 安装和ZIP安装 Typical:典型安装      建议使用 Custom:自定义安装 Complete:完全安装 一.下载MySQL软件 1.去oracl

windows下忘记MySQL密码的修改方法_Mysql

一.windows下修改MySQL密码的方法如果在Windows下忘记了MySQL的密码,可以这样做:1.关闭正在运行的MySQL服务:net stop mysql或 在windows 任务管理器中结束 mysqld.exe 进程或在 管理工具里面的服务找到 mysql服务 ,将其停止: 复制代码 代码如下: C:\Users\Administrator>net stop mysqlMySQL 服务正在停止.MySQL 服务已成功停止. 2.打开命令行,转到mysql的bin目录下: 复制代码

忘记Mysql密码的解决办法小结_Mysql

方法1: 用SET PASSWORD命令 mysql -u root mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); 方法2:用mysqladmin mysqladmin -u root password "newpass" 如果root已经设置过密码,采用如下方法 mysqladmin -u root password oldpass "newpass" 方法3: 用UPDA