Reference for working with MySQL.
For database, table and column names that are reserved words or irregular names, surround the names with backticks `
. For string values, wrap the values with single '
or double "
quotes.
If you are operating on a local MySQL database, <host>
in the examples below will be localhost
.
Linux
sudo apt-get install mysql-server
macOS
brew install mysql
Secure MySQL installation
mysql_secure_installation
macOS post install instructions via homebrew
unset TMPDIR
mysql_install_db
mysql.server start
mysql_secure_installation
Show installed MySQL version
mysql -V
Linux
service mysql start | stop | restart | status
macOS
mysql.server start | stop | restart | status
mysql.server reload | force-reload
Run MySQL as a background service (Homebrew / macOS)
brew services start mysql@<version>
macOS homebrew executable location
/usr/local/Cellar/mysql/<version>/support-files
Log into MySQL as root
mysql -u root -p
Log into MySQL as <user>
mysql -u <user> -p
Exit MySQL
mysql> exit
Linux
/var/lib/mysql
macOS
/usr/local/var/mysql
Report total size of MySQL databases
sudo du -skh <mysql-directory>
Create a user
mysql> CREATE USER '<user>'@'<host>' IDENTIFIED BY '<password>';
mysql> FLUSH PRIVILEGES;
Delete a user
mysql> DROP USER '<user>'@'<host>';
Change a user's password (as root)
mysql> SET PASSWORD FOR '<user>'@'<host>' = PASSWORD('<password>');
Show list of users
mysql> SELECT User FROM mysql.user;
Assign database privileges
Privileges:
- SELECT - Read only
- INSERT - Insert rows/data
- UPDATE - Change inserted rows/data
- DELETE - Delete drop rows of data
- CREATE - Create new tables
- ALTER - Change table/column names
- DROP - Drop columns/tables
Grant all privileges
mysql> GRANT ALL PRIVILEGES ON <database>.* TO '<user>'@'<host>';
mysql> FLUSH PRIVILEGES;
Grant general privileges
mysql> GRANT SELECT, INSERT, UPDATE, DELETE ON <database>.* TO '<user>'@'<host>';
mysql> FLUSH PRIVILEGES;
Grant table privileges
mysql> GRANT CREATE, DROP, ALTER ON <database>.* TO '<user>'@'<host>';
Revoke all privileges
mysql> REVOKE ALL ON <database>.* FROM '<user>'@'<host>';
Revoke specific privileges
mysql> REVOKE DELETE, INSERT ON <database>.* FROM '<user>'@'<host>';
Show privileges
mysql> SHOW GRANTS FOR '<user>'@'<host>';
Show list of available databases
mysql> SHOW DATABASES;
Select database to use for subsequent SQL commands
mysql> USE <database>;
Show tables for selected database
mysql> SHOW TABLES;
Show the column names and column types for a table
mysql> DESCRIBE <table>;
Show all rows that exist in a column
mysql> SELECT * FROM <column>;
Create a new database
mysql> CREATE DATABASE <database>;
Delete an existing database
mysql> DROP DATABASE <database>;
Create a table and columns
mysql> CREATE TABLE <table> (<column> <type> <settings>);
Create a table and columns (example)
mysql> CREATE TABLE <table> (id INT NOT NULL PRIMARY KEY AUTO_INCREMENT, <column> VARCHAR(45));
Rename table
mysql> RENAME TABLE <table> to <new table>;
Delete table
mysql> DROP TABLE <table>;
Add table column
mysql> ALTER TABLE <table> ADD <column> <type> <settings>;
Add table column in location (example)
mysql> ALTER TABLE <table> ADD <new column> VARCHAR(45) NULL AFTER `<column>`;
Insert record
mysql> INSERT INTO <table> (<column>, <other column>) VALUES ('<value>', '<other value>');
Select records
mysql> SELECT * FROM <table>;
Update record
mysql> UPDATE <table> SET <column> = '<value>';
Update record with condition
mysql> UPDATE <table> SET <column> = '<value>' WHERE <table>.<other column> = <condition>;
Delete all rows
mysql> DELETE FROM <table>;
Delete specific record
mysql> DELETE FROM <table> WHERE <table>.<column> = '<value>';
Export database
mysqldump -u root -p <database> > <file.sql>
Import database
mysqladmin -u root -p create <database>
mysql -u root -p <database> < <file.sql>
Executing .sql files
mysql> source <file.sql>
Alternative way to execute .sql files
mysql> \. <file.sql>
Output MySQL settings
mysql> \s
mysqldump -u root -p -v <database> > <file.sql>
mysqladmin -u root -p create <new database>
mysql -u root -p <new database> < <file.sql>
Show current character set configuration
mysql> show variables like 'char%';