我想在MySQL中创建一个新用户,并只赋予它对一个数据库的完全访问权,比如dbTest,我使用create database dbTest;这样的命令创建这个数据库。MySQL的命令是什么呢?


当前回答

尝试使用运行在Windows机器上的MySQL Workbench在MySQL上创建数据库时遇到此问题。

下面的命令适用于Linux机器MySQL CLI:

CREATE DATABASE my-database ;
USE my-database ;
GRANT ALL PRIVILEGES ON 'my-database'.* TO 'my_user'@'%' IDENTIFIED BY 'my-password' ;

但是不能在运行在Windows机器上的MySQL Workbench上工作。我不得不使用下面的命令。注意如何

`

符号和

'

用于以下命令:

CREATE DATABASE `my-database` ;
USE `my-database` ;
GRANT ALL PRIVILEGES ON `my-database`.`*` TO `my_user`@`%` IDENTIFIED BY 'my-password' ;

OR

CREATE SCHEMA `my-database` ;
USE `my-database` ;
GRANT ALL PRIVILEGES ON `my-database`.`*` TO `my_user`@`%` IDENTIFIED BY 'my-password' ;

其他回答

下面的命令可以工作,如果你想创建一个新用户,让他访问本地主机上的特定数据库(不是Mysql中的所有数据库)。

GRANT ALL PRIVILEGES ON test_database.* TO 'user'@'localhost' IDENTIFIED BY 'password';

这将把一个数据库test_database(在本例中为dbTest)的所有特权授予本地主机上的该用户。

通过运行下面的命令,检查上面的命令授予该用户的权限。

SHOW GRANTS FOR 'user'@'localhost'

以防万一,如果您希望将用户访问限制为仅一个表

GRANT ALL ON mydb.table_name TO 'someuser'@'host';
$ mysql -u root -p -e "grant all privileges on dbTest.* to
`{user}`@`{host}` identified by '{long-password}'; flush privileges;"

忽略-p选项,如果mysql用户没有密码或只是按“[Enter]”键旁路。需要用实际值替换花括号括起来的字符串。

尝试这样创建用户:

CREATE USER 'user'@'hostname';

尝试让它访问数据库dbTest:

GRANT ALL PRIVILEGES ON dbTest.* To 'user'@'hostname' IDENTIFIED BY 'password';

如果你在同一台机器上运行代码/站点访问MySQL,主机名应该是localhost。

现在我们来分析一下。

GRANT -该命令用于创建用户并授予数据库、表等权限。

ALL PRIVILEGES——这告诉它用户将拥有所有标准权限。但是,这并不包括使用GRANT命令的特权。

印度生物技术部。* -指示MySQL在整个dbtest数据库中应用这些权限。如果愿意,可以用特定的表名或存储例程替换*。

TO 'user'@'hostname' - 'user'是您创建的用户帐户的用户名。注意:这里必须有单引号。“hostname”告诉MySQL用户可以从哪个主机连接。如果您只想从同一台机器上获取,请使用localhost

IDENTIFIED BY 'password' -正如你已经猜到的那样,这设置了该用户的密码。

您可以使用create USER语句创建新用户,并使用GRANT授予他们权限。

尝试使用运行在Windows机器上的MySQL Workbench在MySQL上创建数据库时遇到此问题。

下面的命令适用于Linux机器MySQL CLI:

CREATE DATABASE my-database ;
USE my-database ;
GRANT ALL PRIVILEGES ON 'my-database'.* TO 'my_user'@'%' IDENTIFIED BY 'my-password' ;

但是不能在运行在Windows机器上的MySQL Workbench上工作。我不得不使用下面的命令。注意如何

`

符号和

'

用于以下命令:

CREATE DATABASE `my-database` ;
USE `my-database` ;
GRANT ALL PRIVILEGES ON `my-database`.`*` TO `my_user`@`%` IDENTIFIED BY 'my-password' ;

OR

CREATE SCHEMA `my-database` ;
USE `my-database` ;
GRANT ALL PRIVILEGES ON `my-database`.`*` TO `my_user`@`%` IDENTIFIED BY 'my-password' ;