MySQL之账户管理

账户管理是MySQL用户管理最基本的内容。包括登录,退出MySQL服务器、创建用户、删除用户、密码管理和权限管理等内容。

  其中登录方式非常简单,在这个地址有:http://www.cnblogs.com/kissdodog/p/4154068.html

1、新建普通用户

在MySQL数据库中,建立用户有3种方式:

  • 使用create user语句来创建新的用户;
  • 直接在mysql.user表中insert 用户;
  • 使用grant 语句来新建用户;

(1)、方式一:create user

  使用CREATE USER语句创建用户,必须要拥有CREATE USER权限。其格式如下:

CREATE
USER
user[IDENTIFIED BY [PASSWORD]
'password'],
[user[IDENTIFIED BY [PASSWORD]
'password']]...

  其中,user参数表示新建用户的账户,user由用户名(User)和主机名(Host)构成;IDENTIFIED BY关键字用来设置用户的密码;password参数表示用户的密码;如果密码是一个普通的字符串,就不需要使用PASSWORD关键字。可以没有初始密码。

  示例:

CREATE
USER
'admin'@'%' IDENTIFIED BY
'admin'

  执行之后user表会增加一行记录,但权限暂时全部为'N'。

(2)方式二:用INSERT语句新建普通用户

  可以使用INSERT语句直接将用户的信息添加到mysql.user表。但必须拥有mysql.user表的INSERT权限。

  另外,ssl_cipher、x509_issuer、x509_subject没有值,必须要设置值,否则INSERT语句无法执行。

  示例:

INSERT
INTO mysql.user(Host,User,Password,ssl_cipher,x509_issuer,x509_subject) VALUES('%','newuser1',PASSWORD('123456'),'','','')

  执行INSERT之后,需要使用一下命令来刷新权限:

FLUSH PRIVILEGES

  命令来使用户生效。

(3)、用GRANT语句来新建普通用户

  用GRANT来创建新的用户时,能够在创建用户时为用户授权。但需要拥有GRANT权限。

  语法如下:

GRANT priv_type ON
database.table

TO
user[IDENTIFIED BY [PASSWORD]
'password']

[,user [IDENTIFIED BY [PASSWORD]
'password']...]

  • priv_type:参数表示新yoghurt的权限;
  • databse.table:参数表示新用户的权限范围;
  • user:参数新用户的账户,由用户名和主机构成;
  • IDENTIFIED BY关键字用来设置密码;
  • password:新用户密码;

  GRANT语句可以同时创建多个用户。

GRANT
SELECT
ON
*.*
TO netUser@'%'

  *.*与db.*的区别在于。*.*对所有数据库生效,所以user表的SELECT会变为Y。而db.*user表为'N',更改的是Db表。

2、删除普通用户

(1)、DROP USER语句删除普通用户

需要拥有DROP USER权限。语法如下:

DROP
USER
user[,user]...

user是需要删除的用户,由用户名(User)和主机名(Host)构成。

DROP
USER
'newuser1'@'%'

(2)、DELETE语句删除普通用户

  可以使用DELETE语句直接将用户的信息从mysql.user表中删除。但必须拥有对mysql.user表的DELETE权限。

DELETE
FROM mysql.user
WHERE Host =
'%'
AND
User
=
'admin'

  删除完成后,一样要FLUSH PRIVILEGES才生效。

3、修改密码

(1)、使用mysqladmin命令来修改root用户的密码

  语法:

mysqladmin -u -username -p password "new_password"

  新密码(new_password)必须用括号括起来,单引号会报错。

  示例:

  (注:这个待验证,我怎么执行都不成功!)

(2)、修改user表

UPDATE user表的passwor字段的值,也可以达到修改密码的目的;

UPDATE
user
SET Password = PASSWORD('123') WHERE
USER
=
'myuser'

  FLUSH PRIVILEGES后生效。

(3)、使用SET语句来修改密码

  使用root用户登录到MySQL服务器后,可以使用SET语句来修改密码:

  修改自己的密码,不需要用户名

SET PASSWORD = PASSWORD("123");

  修改其他用户密码:

SET PASSWORD FOR
'myuser'@'%'=PASSWORD("123456")

  FOR 用户名@主机名

(4)、GRANT语句来修改普通用户的密码

  使用GRANT语句修改普通用户的密码,必须拥有GRANT权限。

GRANT priv_type ON
database.table
TO
user
[IDENTIFIED BY [PASSWORD]
'password']

  示例:

GRANT
SELECT
ON
*.*
TO
'test3'@'%' IDENTIFIED BY
'123'

4、忘记密码的解决方案

  如果root用户密码丢失了,会给用户造成很大的麻烦。但是,可以通过某种特殊方法登录到root用户下,然后修改密码。

  (1)、使用--skip-grant-tables选项启动MySQL服务

  该选项将使MySQL服务器停止权限判断,任何用户都能够访问数据库。

  在Windows操作系统下,使用mysqlid或mysqlid-nt来启动MySQL服务。

  mysqld命令:

  mysqld --skip-grant-tables

  mysqld-nt命令:

  mysqld-nt --skip-grant-tables

  net start mysql命令:

  net start mysql --skip-grant-tables

  (2)、登录root用户,并且设置新密码

  mysql -u root

  必须使用UPDATE语句更新mysql数据库下的user表,而不能使用SET语句,因为--skip-grant-tables不能使用SET语句。

  修改完密码以后,FLUSH PRIVILEGES语句加载权限表,新密码即生效。

MySQL之账户管理的更多相关文章

  1. mysql的账户管理

    mysql中账户管理:1 查看所有用户: 所有用户及权限信息都存储在mysql数据库中的user表中 查看user表的结构 desc user\G; 主要字段: host: 表示允许访问的主机 use ...

  2. MySQL用户账户管理/权限管理/资源限制

    MySQL 的权限表在数据库启动的时候就载入内存,当用户通过身份认证后,就在内存中进行相应权限的存取,这样,此用户就可以在数据库中做权限范围内的各种操作了. mysql 的权限体系大致分为5个层级: ...

  3. MySQL账户管理

    body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...

  4. MySQL数据库的账户管理

    账户管理 在生产环境下操作数据库时,绝对不可以使用root账户连接,而是创建特定的账户,授予这个账户特定的操作权限,然后连接进行操作,主要的操作就是数据的crud MySQL账户体系:根据账户所具有的 ...

  5. MySQL账户管理和主从同步

    账户管理 在生产环境下操作数据库时,绝对不可以使用root账户连接,而是创建特定的账户,授予这个账户特定 的操作权限,然后连接进行操作,主要的操作就是数据的CRUD(增删改查) MySQL账户体系:根 ...

  6. MySQL之权限管理

    MySQL之权限管理 一.MySQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你全力以内的事情,不可以越界.比如只允许你执行select操作, 那么你就不能执行update操作.只 ...

  7. CentOS下的账户管理

    在Linux中,每个文件都分3类权限:账户本身的权限,账户所在群组的权限和其它权限.账户和群组是多对多的关系,即一个账户可以属于多个群组,一个群组可以包含多个账户.但是,对于每一个已登录的账户,只能存 ...

  8. MySQL介绍及安装&MySQL软件基本管理

    mysql介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好 ...

  9. ClickHouse学习系列之六【访问权限和账户管理】

    背景 在之前写的文章[用户权限管理]里已经介绍了应该如何设置用户密码以及权限控制.但是只是针对修改配置文件的方式来进行用户权限管理,其实ClickHouse也支持基于RBAC(Role-Based A ...

随机推荐

  1. Python os._exit() sys.exit()

    os._exit()会直接将python程序终止,之后的所有代码都不会继续执行. sys.exit()会引发一个异常:SystemExit,如果这个异常没有被捕获,那么python解释器将会退出.如果 ...

  2. kylin(二): Calcite

    Apache Calcite是面向Hadoop新的查询引擎,它提供了标准的SQL语言.多种查询优化和连接各种数据源的能力,除此之外,Calcite还提供了OLAP和流处理的查询引擎.Calcite之前 ...

  3. NSUserDefault的使用

    NSUserDefaults 在我们编写代码中是最常用的一个永久保存数据的方法,也是最简单的. 使用NSUserDefault需要注意: 1.数据的本地化保存不是实时的,如果需要实时保存,调用sync ...

  4. TCP打洞和UDP打洞的区别 (转)

    为什么网上讲到的P2P打洞基本上都是基于UDP协议的打洞?难道TCP不可能打洞?还是TCP打洞难于实现?     假设现在有内网客户端A和内网客户端B,有公网服务端S.     如果A和B想要进行UD ...

  5. Python入门2

    字符串操作 字符串是语言中使用最多的,下面我们来看看python为字符串提供哪些方法: 1.upper().lower().title() 这3个方法都是返回一个新的字符串.重要性:** name = ...

  6. [Maven]Maven安装简述

    maven安装简述 1检查jdk安装 1.1cmd输入echo %JAVA_HOME%检查JAVA_HOME是否指向了正确的jdk安装目录 1.2cmd输入java-version检查window是否 ...

  7. class中new与未new的区别 类对象占用空间--转载

    转载自http://blog.sina.com.cn/shuiwuhendeboke    颗颗的博客 (1)作用域不同 不用new:作用域限制在定义类对象的方法中,当方法结束时,类对象也被系统释放了 ...

  8. 【转】EXCEL不显示科学计数法

    源地址:http://jingyan.baidu.com/article/e4d08ffdcc304e0fd3f60d69.html 2法无效,不知道为何

  9. linux journel

    http://www.linuxjournal.com/article/8545 http://www.linuxjournal.com/article/8093 http://www.linuxjo ...

  10. js疑问

    var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];var aCopy = arr.slice();aCopy; // ['A', 'B', 'C', 'D', ...