亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Linux Shell > 正文

Shell腳本中執行sql語句操作mysql的5種方法

2020-07-27 19:12:40
字體:
來源:轉載
供稿:網友

對于自動化運維,諸如備份恢復之類的,DBA經常需要將SQL語句封裝到shell腳本。本文描述了在Linux環境下mysql數據庫中,shell腳本下調用sql語句的幾種方法,供大家參考。對于腳本輸出的結果美化,需要進一步完善和調整。以下為具體的示例及其方法。

1、將SQL語句直接嵌入到shell腳本文件中

復制代碼 代碼如下:

--演示環境 
[root@SZDB ~]# more /etc/issue 
CentOS release 5.9 (Final) 
Kernel /r on an /m 
 
root@localhost[(none)]> show variables like 'version'; 
+---------------+------------+ 
| Variable_name | Value      | 
+---------------+------------+ 
| version       | 5.6.12-log | 
+---------------+------------+ 
 
[root@SZDB ~]# more shell_call_sql1.sh  
#!/bin/bash 
# Define log 
TIMESTAMP=`date +%Y%m%d%H%M%S` 
LOG=call_sql_${TIMESTAMP}.log 
echo "Start execute sql statement at `date`." >>${LOG} 
 
# execute sql stat 
mysql -uroot -p123456 -e " 
tee /tmp/temp.log 
drop database if exists tempdb; 
create database tempdb; 
use tempdb 
create table if not exists tb_tmp(id smallint,val varchar(20)); 
insert into tb_tmp values (1,'jack'),(2,'robin'),(3,'mark'); 
select * from tb_tmp; 
notee 
quit" 
 
echo -e "/n">>${LOG} 
echo "below is output result.">>${LOG} 
cat /tmp/temp.log>>${LOG} 
echo "script executed successful.">>${LOG} 
exit; 
 
[root@SZDB ~]# ./shell_call_sql1.sh  
Logging to file '/tmp/temp.log' 
+------+-------+ 
| id   | val   | 
+------+-------+ 
|    1 | jack  | 
|    2 | robin | 
|    3 | mark  | 
+------+-------+ 
Outfile disabled. 

2、命令行調用單獨的SQL文件

復制代碼 代碼如下:

[root@SZDB ~]# more temp.sql  
tee /tmp/temp.log 
drop database if exists tempdb; 
create database tempdb; 
use tempdb 
create table if not exists tb_tmp(id smallint,val varchar(20)); 
insert into tb_tmp values (1,'jack'),(2,'robin'),(3,'mark'); 
select * from tb_tmp; 
notee 
 
[root@SZDB ~]# mysql -uroot -p123456 -e "source /root/temp.sql" 
Logging to file '/tmp/temp.log' 
+------+-------+ 
| id   | val   | 
+------+-------+ 
|    1 | jack  | 
|    2 | robin | 
|    3 | mark  | 
+------+-------+ 
Outfile disabled. 

3、使用管道符調用SQL文件

復制代碼 代碼如下:

[root@SZDB ~]# mysql -uroot -p123456 </root/temp.sql 
Logging to file '/tmp/temp.log' 
id      val 
1       jack 
2       robin 
3       mark 
Outfile disabled. 
 
#使用管道符調用SQL文件以及輸出日志 
[root@SZDB ~]# mysql -uroot -p123456 </root/temp.sql >/tmp/temp.log 
[root@SZDB ~]# more /tmp/temp.log 
Logging to file '/tmp/temp.log' 
id      val 
1       jack 
2       robin 
3       mark 
Outfile disabled. 

4、shell腳本中MySQL提示符下調用SQL

復制代碼 代碼如下:

[root@SZDB ~]# more shell_call_sql2.sh 
#!/bin/bash 
mysql -uroot -p123456 <<EOF 
source /root/temp.sql; 
select current_date(); 
delete from tempdb.tb_tmp where id=3; 
select * from tempdb.tb_tmp where id=2; 
EOF 
exit; 
[root@SZDB ~]# ./shell_call_sql2.sh 
Logging to file '/tmp/temp.log' 
id      val 
1       jack 
2       robin 
3       mark 
Outfile disabled. 
current_date() 
2014-10-14 
id      val 
2       robin 

5、shell腳本中變量輸入與輸出

復制代碼 代碼如下:

[root@SZDB ~]# more shell_call_sql3.sh 
#!/bin/bash 
cmd="select count(*) from tempdb.tb_tmp" 
cnt=$(mysql -uroot -p123456 -s -e "${cmd}") 
echo "Current count is : ${cnt}" 
exit  
[root@SZDB ~]# ./shell_call_sql3.sh  
Warning: Using a password on the command line interface can be insecure. 
Current count is : 3 
 
[root@SZDB ~]# echo "select count(*) from tempdb.tb_tmp"|mysql -uroot -p123456 -s 

 
[root@SZDB ~]# more shell_call_sql4.sh 
#!/bin/bash 
id=1 
cmd="select count(*) from tempdb.tb_tmp where id=${id}" 
cnt=$(mysql -uroot -p123456 -s -e "${cmd}") 
echo "Current count is : ${cnt}" 
exit  
 
[root@SZDB ~]# ./shell_call_sql4.sh  
Current count is : 1 
 
#以上腳本演示中,作拋磚引玉只用,對于輸出的結果不是很規整友好,需要進一步改善和提高。 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩精品久久| 国产成人久久精品| 欧美日韩国产123| 亚洲最大的av网站| 久久精彩免费视频| 日韩av最新在线观看| 亚洲精品一区av在线播放| 国产91精品不卡视频| 欧美日韩成人在线观看| 亚洲天堂视频在线观看| 国产成人精品午夜| 亚洲片在线资源| 26uuu国产精品视频| 欧美性xxxxx极品| 91网站免费看| 日韩精品欧美激情| 亚洲国产精品视频在线观看| 欧美日韩性视频| 黑人狂躁日本妞一区二区三区| 欧美与欧洲交xxxx免费观看| 精品视频偷偷看在线观看| 欧美日韩爱爱视频| 国产精品日韩欧美| 亚洲男人第一网站| 日韩欧美精品在线观看| 日韩视频在线观看免费| 国产精品偷伦视频免费观看国产| 亚洲石原莉奈一区二区在线观看| 亚洲国产中文字幕在线观看| 国模叶桐国产精品一区| 亚洲精品xxxx| 亚洲成人久久久久| 欧美大片va欧美在线播放| 国产成人在线一区| 97精品国产aⅴ7777| 国内免费久久久久久久久久久| 国产精品自拍视频| 久久久这里只有精品视频| 日韩在线免费观看视频| 欧美最顶级的aⅴ艳星| 日韩精品免费综合视频在线播放| 日本一区二区在线播放| 国产亚洲精品久久久优势| 精品中文字幕在线观看| 亚洲精品suv精品一区二区| 一区二区国产精品视频| 日韩精品高清在线| 国产精品久久久久免费a∨大胸| 中文字幕日本精品| 日韩精品视频中文在线观看| 久久99精品久久久久久青青91| 亚洲精品久久久久久下一站| 欧美日韩国产91| 欧美老女人xx| 国产精品国产亚洲伊人久久| 欧美区二区三区| 欧美日韩一区二区三区在线免费观看| 欧美亚洲国产日韩2020| www.日韩av.com| 91wwwcom在线观看| 亚洲人成网在线播放| 日韩成人在线视频观看| 日韩成人中文字幕| 亚洲第一男人av| 色婷婷av一区二区三区久久| 成人久久久久久久| 成人激情黄色网| 影音先锋欧美在线资源| 成人有码视频在线播放| 中文字幕自拍vr一区二区三区| 欧美在线观看一区二区三区| 最好看的2019的中文字幕视频| 91久久在线观看| 国产精品三级久久久久久电影| 亚洲自拍偷拍色片视频| 欧美激情一级精品国产| 97在线视频免费看| 欧洲亚洲在线视频| 26uuu国产精品视频| 7777精品久久久久久| 日韩精品极品视频免费观看| 激情懂色av一区av二区av| 中文字幕精品—区二区| 国产精品精品一区二区三区午夜版| 国产视频综合在线| 国产精品视频成人| 国产视频综合在线| 亚洲精品视频网上网址在线观看| 91视频九色网站| 综合久久五月天| 国产精品高潮呻吟久久av黑人| 亚洲人成在线播放| 国产精品6699| 日韩在线资源网| 美女精品视频一区| 亚洲视频在线观看网站| 欧美第一黄色网| 有码中文亚洲精品| 最近2019年好看中文字幕视频| 久久精品国产2020观看福利| 色偷偷av一区二区三区| 国产精品久久久久av免费| 亚洲电影免费观看高清完整版在线| 国产高清在线不卡| 这里只有精品丝袜| 国产欧美日韩视频| 国产精品色午夜在线观看| 欧美国产在线视频| 日韩中文字幕在线| 一区二区三区四区视频| 欧美日韩亚洲成人| 91中文精品字幕在线视频| 精品亚洲一区二区三区在线播放| 欧美精品在线免费观看| 国产精品第1页| 亚洲精品国产精品久久清纯直播| 欧美激情伊人电影| 亚洲性av网站| 国产日韩欧美在线看| 亚洲国产女人aaa毛片在线| 亚洲人成网站在线播| 国产欧美一区二区三区久久人妖| 国产视频久久久久久久| 日韩av中文字幕在线播放| 亚洲精品国产免费| 亚洲精品有码在线| 欧美激情国产高清| 国模吧一区二区| 精品五月天久久| 91深夜福利视频| 日韩av网站在线| 亚洲在线免费观看| 91精品国产91| 国产suv精品一区二区| 成人免费在线网址| 久久久成人精品| 欧美人与物videos| 色久欧美在线视频观看| 亚洲国产高潮在线观看| 国产精品久久久久久久久久久久| 亚洲自拍偷拍色片视频| 亚洲国产精品成人av| 亚洲国产成人精品女人久久久| 日本人成精品视频在线| 亚洲xxxxx电影| 久久天天躁狠狠躁夜夜躁| 亚洲欧美一区二区精品久久久| 国产欧美日韩专区发布| 国产91在线高潮白浆在线观看| 久久久久久久一| 久久精品久久久久久国产 免费| 国产精品一区二区电影| 色综合久久天天综线观看| 欧美精品久久一区二区| 日韩av免费在线观看| 亚洲天堂男人天堂女人天堂| 久久九九精品99国产精品| 亚洲欧美日韩在线一区| 97在线视频免费| 日韩精品免费一线在线观看| 久久久av网站| 日本一区二三区好的精华液| 中文字幕欧美日韩va免费视频| 精品亚洲国产成av人片传媒|