Advertisement
onejdc

MySQL: Command Line Create User

May 27th, 2015
352
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Bash 2.28 KB | None | 0 0
  1. Creating a MySQL database and user on the command line, and a bash script to automate the process
  2.  
  3. After having to look up the syntax for creating a MySQL user for the umpteenth time, I've decided to jot it down here for future reference. I've also included a bash script, which automates the process of creating the database and setting up the user privileges.
  4.  
  5. For the following examples, I assume that you're running a MySQL server, and have logged into it. All text within brackets, e.g. <text>, is meant to be replaced with a value of your choosing.
  6.  
  7. Let's start with the basics. Create a new database:
  8.  
  9. CREATE DATABASE <database>;
  10. Next, we create a new user:
  11.  
  12. GRANT USAGE ON *.* TO <username>@localhost IDENTIFIED BY '<password>';
  13. Now we allow the new user access to the database we've just created:
  14.  
  15. GRANT ALL PRIVILEGES ON <database_name>.* TO <username>@localhost;
  16. Finally, we tell MySQL to reload its grant tables:
  17.  
  18. FLUSH PRIVILEGES;
  19. You should now be able to log in to the server and access the database with the credentials you supplied:
  20.  
  21. mysql -u<username> -p<password> <database>
  22. Right, so if this is something you have to do often, entering all of that quickly becomes a bit of a pain. Brian Racer has published a bash script, which automates the above steps. Brian's example gives the new user access to all the databases on the server, which is not what you might want or expect, so I've modified the script to give the user access to only the database being created:
  23.  
  24. #!/bin/bash
  25.  
  26. EXPECTED_ARGS=3
  27. E_BADARGS=65
  28. MYSQL=`which mysql`
  29.  
  30. Q1="CREATE DATABASE IF NOT EXISTS $1;"
  31. Q2="GRANT USAGE ON *.* TO $2@localhost IDENTIFIED BY '$3';"
  32. Q3="GRANT ALL PRIVILEGES ON $1.* TO $2@localhost;"
  33. Q4="FLUSH PRIVILEGES;"
  34. SQL="${Q1}${Q2}${Q3}${Q4}"
  35.  
  36. if [ $# -ne $EXPECTED_ARGS ]
  37. then
  38.  echo "Usage: $0 dbname dbuser dbpass"
  39.  exit $E_BADARGS
  40. fi
  41.  
  42. $MYSQL -uroot -p -e "$SQL"
  43. Following Brian's example, I've named the script createdb and moved it to the /usr/bin directory on my server, after applying executable permissions to it:
  44.  
  45. chmod 755 createdb
  46. Creating a new database and user is now as simple as:
  47.  
  48. createdb <database> <user> <password>
  49.  
  50.  
  51. Taken from: http://www.bluepiccadilly.com/2011/12/creating-mysql-database-and-user-command-line-and-bash-script-automate-process
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement