首页数据库mysql创建用户并授权数据库,如何给MySql创建连接用户并授权

mysql创建用户并授权数据库,如何给MySql创建连接用户并授权

编程之家2023-10-19105次浏览

大家好,如果您还对mysql创建用户并授权数据库不太了解,没有关系,今天就由本站为大家分享mysql创建用户并授权数据库的知识,包括如何给MySql创建连接用户并授权的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

mysql创建用户并授权数据库,如何给MySql创建连接用户并授权

mysql创建用户,怎样指定管理多个数据库

增加新用户

格式:grant权限 on数据库.* to用户名@登录主机 identified by"密码"

如,增加一个用户user1密码为password1,让其可以在本机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:

mysql创建用户并授权数据库,如何给MySql创建连接用户并授权

grant select,insert,update,delete on*.* touser1@localhost Identified by"password1";

如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。

如果你不想user1有密码,可以再打一个命令将密码去掉。

all代表所有权限;

mysql创建用户并授权数据库,如何给MySql创建连接用户并授权

grant select,insert,update,delete on mydb.*to user1@localhost identified by"";

例:

grant all on dbname.* to user@”%”identified by"password";

grant all on dbname.* to user@”%” identifiedby"password";

如何让mysql新建的用户只对自己创建的数据库拥有权限

用户对哪一个数据库有操作权限,是要用root用户进行授权的。

创建用户:

CREATE USER'username'@'host' IDENTIFIED BY'password';

其中username是用户名,host是可以进行远程访问数据库的服务器地址。

给用户授权:

GRANT privileges ONdatabasename.tablename TO'username'@'host';

给'username'@'host'用户进行授权,其中privileges是要授予的权限,可以是all privileges、select、update等。databasename.tablename是要访问的某个数据库中的某张表,如果是所有的,则可以用*。

mysql怎么授予创建数据库的权限

MySQL命令行能否实现新建用户呢?答案无疑是肯定的。而且在使用使用MySQL命令行新建用户后,还可以为用户授予权限。

首先要声明一下:一般情况下,修改MySQL密码,授权,是需要有mysql里的root权限的。

注:本操作是在WIN命令提示符下,phpMyAdmin同样适用。

用户:phplamp

用户数据库:phplampDB

1.MySQL命令行新建用户

//登录MYSQL

@>mysql-u root-p

@>密码

//创建用户

mysql> insert into mysql.user(Host,User,Password) values('localhost','phplamp',password('1234'));

//刷新系统权限表

mysql>flush privileges;

这样就创建了一个名为:phplamp密码为:1234的用户。

//退出后登录一下

mysql>exit;

@>mysql-u phplamp-p

@>输入密码

mysql>登录成功

2.MySQL命令行为用户授权

//登录MYSQL(有ROOT权限)。我里我以ROOT身份登录.

@>mysql-u root-p

@>密码

//首先为用户创建一个数据库(phplampDB)

mysql>create database phplampDB;

//授权phplamp用户拥有phplamp数据库的所有权限

@>grant all privileges on phplampDB.* to phplamp@localhost identified by'1234';//这里需要注意,如果发现找不到用户,需要执行命令 flush privilieges;

//刷新系统权限表

mysql>flush privileges;

mysql>其它操作

//如果想指定部分权限给一用户,可以这样来写:

mysql>grant select,update on phplampDB.* to phplamp@localhost identified by'1234';

//刷新系统权限表。

mysql>flush privileges;

mysql> grant权限1,权限2,…权限n on数据库名称.表名称 to用户名@用户地址 identified by‘连接口令’;

权限1,权限2,…权限n代表select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14个权限。

当权限1,权限2,…权限n被all privileges或者all代替,表示赋予用户全部权限。

当数据库名称.表名称被*.*代替,表示赋予用户操作服务器上所有数据库所有表的权限。

用户地址可以是localhost,也可以是ip地址、机器名字、域名。也可以用’%'表示从任何地址连接。

‘连接口令’不能为空,否则创建失败。

例如:

mysql>grant select,insert,update,delete,create,drop on vtdc.employee to joe@10.163.225.87 identified by‘123′;

给来自10.163.225.87的用户joe分配可对数据库vtdc的employee表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123。

mysql>grant all privileges on vtdc.* to joe@10.163.225.87 identified by‘123′;

给来自10.163.225.87的用户joe分配可对数据库vtdc所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on*.* to joe@10.163.225.87 identified by‘123′;

给来自10.163.225.87的用户joe分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on*.* to joe@localhost identified by‘123′;

给本机用户joe分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

如何给MySql创建连接用户并授权

一般在为MySql创建用户时建议使用GRANT前台命令,当然如果对我们开发者而言,方法还有很多种,比如使用INSERT命令,甚至是直接修改mysql user数据表,但仍然建议按照MySQL规范去授权账户。因为它太容易忘记,特别整理方便参考。

1、登录MySQL

输入mysql-u root和密码即可登录到Mysql。

2、选择数据库

语句如下:use mysql;

3、在mysql的user表中增加连接用户

GRANT USAGE ON*.* TO'username'@'localhost' IDENTIFIED BY'password' WITH GRANT OPTION;

其中:

“username”替换为将要授权的用户名,比如clientusr;

“password”替换为clientusr设置的密码;

4、可访问数据表授权

创建好帐户之后,就开始给上面的common user进行数据表授权,步骤3中增加的连接用户默认权限都是“N”的,必须在db表中为该帐户授权,允许其访问专用数据库,当然超级用户就不说了。

使用下面语句:

GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP ON dbx.* TO'username'@'localhost' IDENTIFIED BY'password';

本语句中的权限根据实际需要确定:

"dbx"替换为授权访问的数据库名,如果只给某张表授权:dbx.tablename

"username"是步骤2授权用户名

"password"是步骤2授权用户的设置密码

这样就为该用户授予了对某数据表的SELECT, INSERT, UPDATE, DELETE, CAREATE, DROP权限。

5、生效授权,创建完毕

FLUSH PRIVILEGES;

备注:

1、不要直接使用INSERT语句添加user记录,使用INSERT可能出现:ERROR 1364(HY000): Field'ssl_cipher' doesn't have a default value错误。不过早期的MYSQL版本笔者倒没出现这个错误,因为天缘一直都是直接修改user表或直接使用INSERT语句完成,后来升级MYSQL到5.1的时候,发现可能会出现这个错误。

2、上文3和4,也可使用一句话GRANT ALL ON tbx.* TO'username' IDENTIFIED BY'password',这句话会自动创建username并为之授权。更多授权权限可参考MYSQL官方网站。

mysql创建用户并授权数据库和如何给MySql创建连接用户并授权的问题分享结束啦,以上的文章解决了您的问题吗?欢迎您下次再来哦!

数据库系统原理与设计 数据库系统原理与应用的图书目录电脑主机怎么接地线,组装了台电脑,主机机箱有电怎么接地线