經過shell腳本進行數據庫操做

在作一些平常的運維工做的時候,常常須要些一些shell腳本進行設備性能以及其它參數的監控。在過去的一年工做中,接觸到的比較多的是對數據庫中某些信息的監控。mysql

因而就想到了用shell+mysql+crontab進行實現。sql

下面附上經過shell命令行非交互式的操做數據庫的方法:shell

mysql -hhostname -Pport -uusername -ppassword -e 相關mysql的sql語句,不用在mysql的提示符下運行mysql,便可以在shell中操做mysql的方法。數據庫

#!/bin/bash

HOSTNAME="192.168.111.84"  #數據庫信息

PORT="3306"

USERNAME="root"

PASSWORD=""


DBNAME="test_db_test"  #數據庫名稱

TABLENAME="test_table_test" #數據庫中表的名稱


#建立數據庫

create_db_sql="create database IF NOT EXISTS ${DBNAME}"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -e "${create_db_sql}"


#建立表

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} ${DBNAME} -e "${create_table_sql}"


#插入數據

insert_sql="insert into ${TABLENAME} values('billchen',2)"

mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"


#查詢

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}"
相關文章
相關標籤/搜索