linux下sql腳本教程交流 sql如何保存腳本文件?
sql如何保存腳本文件?1/6首先,在腳本的編輯器中,編輯器輸入所需的腳本信息。2/6然后點擊SqlDbx的菜單中的文件菜單。3/6點擊文件菜單后,彈出下拉菜單,選擇保存文件的選項。4/6這樣會彈出另
sql如何保存腳本文件?
1/6
首先,在腳本的編輯器中,編輯器輸入所需的腳本信息。
2/6
然后點擊SqlDbx的菜單中的文件菜單。
3/6
點擊文件菜單后,彈出下拉菜單,選擇保存文件的選項。
4/6
這樣會彈出另存為窗口界面,選擇要保存的路徑。
5/6
然后在重命名中輸入腳本文件的名稱,然后單擊保存按鈕。
6/6
然后查看相應(yīng)路徑下保存的文件。
Linux中,shell腳本如何使用信號機制去控制線程的開啟關(guān)閉?
Trap是Linux的內(nèi)置命令,用來捕獲信號。trap命令可以指定當(dāng)接收到某個信號時要執(zhí)行的命令。陷阱命令的格式如下:陷阱命令sig1 ,當(dāng)接收到sinN中的任意一個信號時,執(zhí)行command命令,command命令完成后繼續(xù)接收信號前的操作,直到腳本結(jié)束。用trap命令捕獲INT信號(即綁定到Ctrl c的中斷信號)。Trap也可以忽略一些信號,只是用空字符串替換命令,比如trap TERM INT,忽略kill %n和Ctrl c發(fā)送的信號(kill發(fā)送一個$ TERM信號)。Linux和更強大的殺死進程的命令:kill -9進程號(或kill -9 %n nJob號)相當(dāng)于kill -KILL進程號。
例如
:
最近,小啊需要制作2015年全年的KPI數(shù)據(jù)報告?,F(xiàn)在小啊已經(jīng)編寫了生產(chǎn)腳本,生產(chǎn)腳本一次只能生成指定日期的KPI數(shù)據(jù)。假設(shè)運行一次生產(chǎn)腳本需要5分鐘,那么:
如果循環(huán)順序執(zhí)行,需要時間:5 * 365 1825分鐘,大概是6天。
如果將它一次性放入linux后臺并發(fā)執(zhí)行,系統(tǒng)可以 t承擔(dān)365后臺任務(wù)!
因為365任務(wù)可以 t在linux后臺一次執(zhí)行,n個任務(wù)能不能一次自動在后臺執(zhí)行?你當(dāng)然可以。
#!/bin/bash
來源/etc/配置文件
# -
T: sh loop _ KPI 2015-12-01 2015-12-07
2號出口
船方不負擔(dān)裝貨費用
# -
陷阱執(zhí)行1000 gtamp-執(zhí)行1000
mkfifo $tempfifo
exec 1000$tempfifo
rm -rf $tempfifo
for ((i1 i
做
echo gtamp1000
完成的
while [ $begin_date!$end_date ]
做
閱讀-u1000
{
echo $begin_date
hive-f KPI _ report . SQL-hive var date $ begin _ date
echo gtamp1000
}安培
begin_date`date -d第1天$begin_date %Y-%m-%d `天
完成的
等待
回聲完畢?。。。。。。。。?!
第6-22行:例如:sh loop _ KPI _ 2015-01-01 2015-12-01:
$1表示腳本的第一個參數(shù),等于2015-01-01。
$2表示腳本的第二個參數(shù),等于2015-12-01。
$ #表示腳本參數(shù)的數(shù)量,等于2。
第13行用于比較兩個傳入日期的大小,gt是escape。
第26行:表示腳本運行時,如果收到Ctrl C中斷命令,將關(guān)閉文件描述符1000的讀寫,腳本正常退出。
Exec 1000gtamp-表示關(guān)閉文件描述符1000的寫入。
exec 1000
Trap是一個捕獲中斷命令。
第27-29行:
第27行,創(chuàng)建一個管道文件。
第28行,將文件描述符1000綁定到FIFO。如果文件描述符1000被綁定,則表明對文件描述符1000的所有操作都等同于對流水線文件$tempfifo的操作。
第29行,可能會有這樣的疑問:為什么不直接使用管道文件?其實這也不是沒有必要。管道的一個重要特征是讀和寫必須同時存在。如果缺少一個操作,另一個操作就會被擱置,第28行的綁定文件描述符(讀寫綁定)正好解決了這個問題。
第31-34行:寫文件描述符1000。通過循環(huán)書寫8空行,這個8是我們要定義的后臺并發(fā)線程數(shù)。為什么要寫空行而不是其他字符?因為管道文件是以行為單位讀取的。
第37-42行:
第37行,read -u1000的功能是讀取流水線中的一行,本例中為空行;每次讀取管道時,都會減少一個空行。
第39-41行,注意第42行末尾的放大器?這意味著該進程在linux后臺執(zhí)行。
第41行:在執(zhí)行后臺任務(wù)后,在文件描述符1000中寫入一個空行。這是重點,因為read -u1000的每一次操作都會導(dǎo)致流水線中減少一個空行。當(dāng)八個任務(wù)放在linux后臺時,read -u1000會一直等待,因為在文件描述符1000中沒有空行可以讀取。