开发者

GRANT with database name wildcard in MySQL?

开发者 https://www.devze.com 2022-12-27 15:29 出处:网络
I want to create a user \'projectA\' that has the same permissions to every database named \'proj开发者_Python百科ectA_%\'

I want to create a user 'projectA' that has the same permissions to every database named 'proj开发者_Python百科ectA_%'

I know its possible but MySQL doesn't like my syntax:

grant all on 'projectA\_%'.* to 'projectA'@'%';

Reference: http://dev.mysql.com/doc/refman/5.1/en/grant.html


If I use back-tics instead of single quotes in the syntax, it appears to work just fine:

grant all on `projectA\_%`.* to `projectA`@`%`;


GRANT ALL PRIVILEGES ON `projectA\_%`.* TO 'projectA'@'%' IDENTIFIED BY 'your_passwd';

back-tics are needed for the database name

Edited:Underscore is now escaped.


As per MySQL's GRANT documentation:

The “_” and “%” wildcards are permitted when specifying database names in GRANT statements that grant privileges at the global or database levels. This means, for example, that if you want to use a “_” character as part of a database name, you should specify it as “\_” in the GRANT statement, to prevent the user from being able to access additional databases matching the wildcard pattern; for example, GRANT ... ON `foo\_bar`.* TO ....

0

精彩评论

暂无评论...
验证码 换一张
取 消