MySQL: Grant **all** privileges on database

后端 未结 11 1206
庸人自扰
庸人自扰 2020-11-22 09:23

I\'ve created database, for example \'mydb\'.

CREATE DATABASE mydb CHARACTER SET utf8 COLLATE utf8_bin;
CREATE USER \'myuser\'@\'%\' IDENTIFIED BY PASSWORD          


        
相关标签:
11条回答
  • 2020-11-22 09:55

    To grant all priveleges on the database: mydb to the user: myuser, just execute:

    GRANT ALL ON mydb.* TO 'myuser'@'localhost';
    

    or:

    GRANT ALL PRIVILEGES ON mydb.* TO 'myuser'@'localhost';
    

    The PRIVILEGES keyword is not necessary.

    Also I do not know why the other answers suggest that the IDENTIFIED BY 'password' be put on the end of the command. I believe that it is not required.

    0 讨论(0)
  • 2020-11-22 10:01

    This will be helpful for some people:

    From MySQL command line:

    CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';
    

    Sadly, at this point newuser has no permissions to do anything with the databases. In fact, if newuser even tries to login (with the password, password), they will not be able to reach the MySQL shell.

    Therefore, the first thing to do is to provide the user with access to the information they will need.

    GRANT ALL PRIVILEGES ON * . * TO 'newuser'@'localhost';
    

    The asterisks in this command refer to the database and table (respectively) that they can access—this specific command allows to the user to read, edit, execute and perform all tasks across all the databases and tables.

    Once you have finalized the permissions that you want to set up for your new users, always be sure to reload all the privileges.

    FLUSH PRIVILEGES;
    

    Your changes will now be in effect.

    For more information: http://dev.mysql.com/doc/refman/5.6/en/grant.html

    If you are not comfortable with the command line then you can use a client like MySQL workbench, Navicat or SQLyog

    0 讨论(0)
  • 2020-11-22 10:01

    This SQL grants on all databases but just basic privileges. They're enough for Drupal or Wordpress and as a nicety, allows one developer account for local projects.

    GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, 
        INDEX, ALTER, CREATE TEMPORARY TABLES 
    ON *.* TO 'username'@'localhost' IDENTIFIED BY 'password';
    
    0 讨论(0)
  • 2020-11-22 10:02

    I could able to make it work only by adding GRANT OPTION, without that always receive permission denied error

    GRANT ALL PRIVILEGES ON mydb.* TO 'myuser'@'localhost' WITH GRANT OPTION;
    
    0 讨论(0)
  • 2020-11-22 10:06

    Hello I used this code to have the super user in mysql

    GRANT EXECUTE, PROCESS, SELECT, SHOW DATABASES, SHOW VIEW, ALTER, ALTER ROUTINE,
        CREATE, CREATE ROUTINE, CREATE TEMPORARY TABLES, CREATE VIEW, DELETE, DROP,
        EVENT, INDEX, INSERT, REFERENCES, TRIGGER, UPDATE, CREATE USER, FILE,
        LOCK TABLES, RELOAD, REPLICATION CLIENT, REPLICATION SLAVE, SHUTDOWN,
        SUPER
            ON *.* TO mysql@'%'
        WITH GRANT OPTION;
    

    and then

    FLUSH PRIVILEGES;
    
    0 讨论(0)
  • 2020-11-22 10:12
    GRANT ALL PRIVILEGES ON mydb.* TO myuser@localhost IDENTIFIED BY 'mypasswd';
    

    Works for privileges on schema :)

    Optional: after mypasswd you can add WITH GRANT OPTION

    0 讨论(0)
提交回复
热议问题