MySQL创建用户的三种方法 (并授权)转

前言:MySQL创建用户的方法分成三种:INSERT USER表的方法、CREATE USER的方法、GRANT的方法。

一、账号名称的构成方式

账号的组成方式:用户名+主机(所以可以出现重复的用户名,跟其他的数据库不一样)

用户名:16字符以内.

主机名:可以用主机名和IP地址,也可以用通配符

通配符说明:172.18.10.%(IP地址为172.18.10段的所有IP地址都可以访问)

二、通过CREATE USER命令进行创建用户

脚本:CREATE USER ‘[email protected]‘ [IDENTIFIED BY ‘PASSWORD‘] 其中密码是可选项;

例子:CREATE USER ‘[email protected]‘ IDENTIFIED BY "123";

CREATE USER ‘[email protected]%‘ IDENTIFIED BY "123";

CREATE USER ‘[email protected]‘ ;

说明:该方法创建出来的用户只有连接数据库的权限,需要后续继续授权;

注意:用户与@后主机地址是一体的,用一个分号连接,否则会报错,ERROR 1396 (HY000): Operation CREATE USER failed for ‘remote‘@‘%‘

三、通过GRANT命令创建用户

当数据库存在用户的时候GRANT会对用户进行授权,但当数据库不存在该用户的时候,就会创建相应的用户并进行授权。(说明上面那步是多余的)

脚本:

GRANT <ALL|priv1,priv2,.....privn> ON

[object] [IDENTIFIED BY ‘password‘]

[WITH GRANT OPTION];

MAX_QUERIES_PER_HOUR count

MAX_UPDATES_PER_HOUR count

MAX_CONNECTIONS_PER_HOUR count

MAX_USER_CONNECTIONS count

说明:priv代表权限select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14个权限

例子:mysql>grant select,insert,update,delete,create,drop on test.hr to [email protected] identified by ‘123‘;

说明:给主机为192.168.10.1的用户john分配可对数据库test的hr表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123。

mysql>grant all privileges on test.* to [email protected] identified by ‘123‘;

说明:给主机为192.168.10.1的用户john分配可对数据库test所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on *.* to [email protected] identified by ‘123‘;

说明:给主机为192.168.10.1的用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on *.* to [email protected] identified by ‘123‘;

说明:用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

查看权限:

show grants for你的用户;

show grants for[email protected]‘localhost‘;

show grants for [email protected];

show createdatabase dbname; 
这个可以看到创建数据库时用到的一些参数。

showcreatetabletickets;   
可以看到创建表时用到的一些参数

撤销权限:

revoke all on *.* from [email protected];

四、直接向mysql.user表插入记录(该方法个人很少用)

因为数据库的用户信息都是保存在mysql.user这张表的,所以直接对该表进行插入语句,即可完成用户的创建;

mysql> insert into user (host,user,password) values (‘%‘,‘john‘,password(‘123‘));

五、完成用户的创建后,请记得刷新系统权限表;

mysql>flush privileges;

总结:虽然创建用户的方法有三种,个人还是倾向于第二种方法,一步到位,简单明了;

其他的两种方法只是有助于理解数据库的原理而已。

时间: 2024-08-02 02:48:47

MySQL创建用户的三种方法 (并授权)转的相关文章

MySQL创建用户的三种方法

前言:MySQL创建用户的方法分成三种:INSERT USER表的方法.CREATE USER的方法.GRANT的方法. 一.账号名称的构成方式 账号的组成方式:用户名+主机(所以可以出现重复的用户名,跟其他的数据库不一样) 用户名:16字符以内. 主机名:可以用主机名和IP地址,也可以用通配符 通配符说明:172.18.10.%(IP地址为172.18.10段的所有IP地址都可以访问) 二.通过CREATE USER命令进行创建用户 脚本:CREATE USER '[email protect

mysql分表的三种方法

mysql分表的3种方法 一,先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目的就在于此,减小数据库的负担,缩短查询时间. 根据个人经验,mysql执行一个sql的过程如下:1,接收到sql;2,把sql放到排队队列中 ;3,执行sql;4,返回执行结果.在这个执行过程中最花时间在什么地方呢?第一,是排队等待的时间,第二,sql的执行时间.其实这二个是一回事,等待的同时,肯定有sql在执行.所以我们要缩短sql的执行

mysql数据库改名的三种方法

前不久去面试,被问到Innodb引擎的表如何改数据库名,当时我也只回答了MyISAM改如何操作,被一些细节问题打败,真是操蛋. 如果表示MyISAM那么可以直接去到数据库目录mv就可以. Innodb完全不行,自己测试过,会提示相关表不存在. 第一种方法: RENAME database olddbname TO newdbname 这个是5.1.7到5.1.23版本可以用的,但是官方不推荐,会有丢失数据的危险 第二种方法: 1.创建需要改成新名的数据库.2.mysqldum 导出要改名的数据库

cocos2dx中创建动画的三种方法

1.最最原始的方法,先创建动画帧,再创建动画打包(animation),再创建动画(animate) 第一步: 创建动画帧:CCSpriteFrame,依赖于原始的资源图片(xx.png,xx.jpg) CCSpriteFrame *frame1=CCSpriteFrame::create("1.png"); CCSpriteFrame *frame2=CCSpriteFrame::create("2.png"); CCSpriteFrame *frame3=CCS

MySQL 添加用户设置两种方法

在mysql中root 最高的用户权限,权限分别为 SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,下面简单说说是如何分别用户的. 1,为添加用户的的实例,用户名为dc3688,密码为123456,并授权用户可进行 SELECT, INSERT 和 UPDATE操作权限 [email protected]# mysql -u root -p Enter password:******* mysql> use mysql; Database changed INSE

java中创建线程的三种方法以及区别

Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例.Java可以用三种方式来创建线程,如下所示: 1)继承Thread类创建线程 2)实现Runnable接口创建线程 3)使用Callable和Future创建线程 下面让我们分别来看看这三种创建线程的方法. ------------------------继承Thread类创建线程--------------------- 通过继承Thread类来创建并启动多线程的一般步骤如下 1]d定义Thread类的子类

Jenkins 批量创建任务的三种方法

最近,要搭建多套测试环境,需要把 Jenkins 中 dev 视图下的所有任务批量复制到 sit 等视图下. 说明 Jenkins 任务名称规则为:[测试环境标识]-[工程名称],如:dev-daodaotest,sit-daodaotest. 视图中显示任务的正则表达式:[测试环境标识]-.* ,如:dev-.*,sit-.*. 第一种:目录下批量复制 Jenkins 的任务都是以 xml 文件方式存储的,所有可以通过复制 xml 的方式来批量创建. # 进入 jobs 目录下 $ cd ~/

动态创建标记的三种方法

动态创建标记: 1.document.write() 可以直接把字符串插入文档中,最大的缺点是它违背了“行为应该与表现分离”的原则.避免使用document.write()方法. 2.innerHtml属性: innerHtml属性可以用来读.写某给定元素的html内容,是HTML的专有属性. 3.DOM方法: (1)创建新的元素:createElement()方法: (2)把新创建的节点插入某个文档的节点树:appendChild()方法: (3)创建文本结点:createTextNode()

[前端]创建新元素的三种方法

第一种:通过text/HTML var txt1="<h1>Text.</h1>"; 第二种:通过jQuery var txt2=$("<h2></h2>").text("Text."); 第三种:通过JavaScript/DOM var txt3=document.createElement("h3");txt3.innerHTML="Text.";