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.
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.
Let's start with the basics. Create a new database:
CREATE DATABASE < database >;
|
Next, we create a new user:
GRANT USAGE ON *.* TO <username>@localhost IDENTIFIED BY '<password>' ;
|
Now we allow the new user access to the database we've just created:
GRANT ALL PRIVILEGES ON <database_name>.* TO <username>@localhost;
|
Finally, we tell MySQL to reload its grant tables:
You should now be able to log in to the server and access the database with the credentials you supplied:
mysql -u<username> -p<password> <database>
|
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:
#!/bin/bash
EXPECTED_ARGS=3
E_BADARGS=65
MYSQL=` which mysql`
Q1= "CREATE DATABASE IF NOT EXISTS $1;"
Q2= "GRANT USAGE ON *.* TO $2@localhost IDENTIFIED BY '$3';"
Q3= "GRANT ALL PRIVILEGES ON $1.* TO $2@localhost;"
Q4= "FLUSH PRIVILEGES;"
SQL= "${Q1}${Q2}${Q3}${Q4}"
if [ $
then
echo "Usage: $0 dbname dbuser dbpass"
exit $E_BADARGS
fi
$MYSQL -uroot -p -e "$SQL"
|
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:
Creating a new database and user is now as simple as:
createdb <database> <user> <password>
0 Response to "Creating a MySQL database and user on the command line, and a bash script to automate the process"
Post a Comment