使用 mysql -e 參數能夠執行各類 sql 的各類操做語句。不用在mysql的提示符下運行mysql,便可以在shell中操做mysql的方法。mysql
格式:mysql -hhostname -Pport -uusername -ppassword -e 「」 sql
#!/bin/bash shell
HOSTNAME="192.168.70.161" #數據庫服務器地址
PORT="3306"
USERNAME="root"
PASSWORD="123456"數據庫
DBNAME="test_db_test" #數據庫名稱
TABLENAME="test_table_test" #數據庫中表的名稱bash
#也能夠寫 HOSTNAME="localhost",端口號 PORT能夠不設定服務器
#建立數據庫
create_db_sql="create database IF NOT EXISTS ${DBNAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -e "${create_db_sql}"ide
注意:-p${PASSWORD}中間不能有空格it
#建立表
create_table_sql="create table IF NOT EXISTS ${TABLENAME} ( name varchar(20), id int(11) default 0 )"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -D ${DBNAME} -e "${create_db_sql}"table
#插入數據
insert_sql="insert into ${TABLENAME} values('billchen',2)"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"class
#查詢
select_sql="select * from ${TABLENAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"
#更新數據
update_sql="update ${TABLENAME} set id=3"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${update_sql}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"
#刪除數據delete_sql="delete from ${TABLENAME}"mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${delete_sql}"mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"