mysql -e详解
可以用shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改、查)等各种操作。
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}"
● 若要同时显示语句本身:-v
● 若要增加查询结果行数:-vv
● 若要增加执行时间:-vvv
在一些监控脚本中可以用来简化代码
[plain]view plaincopyprint?㈠不带v测试:[mysql@even~]$mysql-uroot-poracle-e"SELECTVERSION();SELECTNOW()">/home/mysql/test.sql[mysql@even~]$cat/home/mysql/test.sqlVERSION()5.5.16-logNOW()2013-05-0818:06:35㈡带一个v测试:[mysql@even~]$mysql-uroot-poracle-e"SELECTVERSION();SELECTNOW()"-v>/home/mysql/test02.sql[mysql@even~]$cat/home/mysql/test02.sql--------------SELECTVERSION()--------------VERSION()5.5.16-log--------------SELECTNOW()--------------NOW()2013-05-0818:08:40㈢带两个v测试:[mysql@even~]$mysql-uroot-poracle-e"SELECTVERSION();SELECTNOW()"-vv>/home/mysql/test03.sql[mysql@even~]$cat/home/mysql/test03.sql--------------SELECTVERSION()--------------VERSION()5.5.16-log1rowinset--------------SELECTNOW()--------------NOW()2013-05-0818:14:051rowinsetBye㈢带三个v测试:[mysql@even~]$mysql-uroot-poracle-e"SELECTVERSION();SELECTNOW()"-vvv>/home/mysql/test04.sql[mysql@even~]$cat/home/mysql/test04.sql--------------SELECTVERSION()--------------+------------+|VERSION()|+------------+|5.5.16-log|+------------+1rowinset(0.00sec)--------------SELECTNOW()--------------+---------------------+|NOW()|+---------------------+|2013-05-0818:14:49|+---------------------+1rowinset(0.00sec)Bye声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。