shell腳本中執行mysql sql腳本文件並傳遞參數


1 shell 文件內容替換

sed是一個很好的文件處理工具,本身是一個管道命令,主要是以行為單位進行處理,可以將數據行進行替換、刪除、新增、選取等特定工作,下面先了解一下sed的用法。

調用sed命令有兩種形式:

sed [options] 'command' file(s)
 
sed [options] -f scriptfile file(s)

常用選項:

       -n∶使用安靜(silent)模式。在一般sed 的用法中,所有來自 STDIN的資料一般都會被列出到螢幕上。但如果加上 -n 參數后,則只有經過sed特殊處理的那一行(或者動作)才會被列出來。
       -e∶直接在指令列模式上進行 sed 的動作編輯;
       -f∶直接將 sed 的動作寫在一個檔案內, -f filename 則可以執行 filename 內的sed動作;
       -r∶sed 的動作支援的是延伸型正規表示法的語法。(預設是基礎正規表示法語法)
       -i∶直接修改讀取的檔案內容,而不是由螢幕輸出。       


常用命令:

        a∶新增, a 的后面可以接字串,而這些字串會在新的一行出現(目前的下一行)~
        c∶取代, c 的后面可以接字串,這些字串可以取代n1,n2 之間的行!
        d∶刪除,因為是刪除啊,所以 d后面通常不接任何咚咚;
        i∶插入, i的后面可以接字串,而這些字串會在新的一行出現(目前的上一行);
        p∶列印,亦即將某個選擇的資料印出。通常 p 會與參數 sed-n 一起運作~
        s∶取代,可以直接進行取代的工作哩!通常這個 s的動作可以搭配正規表示法!例如 1,20s/old/new/g 就是啦!

 

舉例:

#刪除第一行
sed '1d' abc.file  
 
#刪除最后一行
sed '$d' abc.file
 
#刪除第一行到第二行
sed '1,2d' abc.file
 
#刪除第二行到最后一行
sed '2,$d' abc.file
 
#顯示第一行
sed -n '1p' abc.file
      
#顯示最后一行 
sed -n '$p' abc.file           
 
#顯示第一行到第二行 
sed -n '1,2p' abc.file       
 
#顯示第二行到最后一行 
sed -n '2,$p' abc.file
 
#查詢包括關鍵字ruby所在所有行 
sed -n '/ruby/p' abc.file
    
#查詢包括關鍵字$所在所有行,使用反斜線\屏蔽特殊含義 
sed -n '/\$/p' abc.file

#第一行后增加字符串"drink tea"
sed '1a drink tea' abc.file  && cat abc.file
 
Hello!
drink tea
ruby is me,welcome to my blog.
end

#第一行到第三行后增加字符串"drink tea"
sed '1,3a drink tea' abc.file && cat abc.file
Hello!
drink tea
ruby is me,welcome to my blog.
drink tea
end
drink tea

#第一行后增加多行,使用換行符\n     
sed '1a drink tea\nor coffee' abc.file  && cat abc.file
Hello!
drink tea
or coffee
ruby is me,welcome to my blog.
end
 

#第一行代替為Hi 
sed '1c Hi' abc.file                
Hi
ruby is me,welcome to my blog.
end

#第一行到第二行代替為Hi
sed '1,2c Hi' abc.file
Hi
end
 
#替換一行中的某部分格式:sed 's/要替換的字符串/新的字符串/g'   (要替換的字符串可以用正則表達式)
#替換ruby為bird
sed -n '/ruby/p' abc.file | sed 's/ruby/bird/g'
  
#刪除ruby    
sed -n '/ruby/p' abc.file | sed 's/ruby//g'  
 
#將當前目錄下包含ruby串的文件中,ruby字符串替換為java
sed -i "s/ruby/java/g" `grep "ruby" -rl ./`

#將某個文件中的jack字符串替換為tom
sed -i "s/ruby/java/g" abc.file


#在文件abc.file中最后一行直接輸入"bye"
sed -i '$a bye' abc.file && cat abc.file
Hello!
ruby is me,welcome to my blog.
end
bye

2. shell 執行mysql文件

2.1 語法

mysql -h host -P port_number -u username -p password <file_to_execute.sql

 

2.2 shell執行sql文件,並傳參

給mysql的.sql的腳本文件傳遞參數,只能利用本文1部分介紹的sed在調用mysql執行命令前,把sql文件中的變量值替換掉,然后調用mysql命令執行sql腳本文件。

舉例:

准備mysql數據庫

create database if not exists  test;
use test;
drop table if  exists demo_table;
create table demo_table(a varchar(20),age int);

insertstmt.sql

insert into test.demo_table values(@name,@age);
exit

該腳本文件往mysql數據庫test中的表demo_table中插入一條記錄,這條記錄的兩個值都是變量,需要外面傳遞進來

 

execute.sh

#!/bin/sh
NAME="lenmom"
AGE=1

# set parameters as sql variables && add them to the first line of t.sql
sed -i "1 i\ set @name='$NAME';" insertstmt.sql
sed -i "1 i\ set @age=$AGE;"   insertstmt.sql

# execute sql script
mysql -u root < insertstmt.sql

# clear sql script variables
sed -i "1d" insertstmt.sql
sed -i "1d" insertstmt.sql

 執行效果:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM