使用sed做特殊的行列轉換
行列轉換在資料庫,開發語言中都是一個津津樂道的話題,今天來簡單演示一個使用sed所作的特殊行列轉換。
日誌的內容如下:
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO
1936470 rows created.
Elapsed: 00:01:01.53
Commit complete.
Elapsed: 00:00:00.03
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO
873897 rows created.
Elapsed: 00:00:22.67
Commit complete.
Elapsed: 00:00:00.02
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO
1702297 rows created.
Elapsed: 00:00:57.67
Commit complete.
Elapsed: 00:00:00.04
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO
1280364 rows created.
Elapsed: 00:00:52.77
現在想把特定的一些行轉列,實現類似如下的效果。 這樣資料條數,插入時間等就一目瞭然了,可以在此基礎上成為報告,便於檢視狀態和監控。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
這個時候可以使用sed來做處理,完成特定的行列轉換。
首先刪除多餘的空行
sed -e '/^$/d' append_details.log
然後在此基礎上根據”append data from“來做第一次行列轉換。
sed '/append data from/{N;N; s/\n/ /}'
這樣,格式化後的內容就類似下面的形式。
append data from MIG_TEST.MO1_MEMO_EXT_11 to MIG_TEST.MO1_MEMO 2083618 rows created.
Elapsed: 00:01:24.92
Commit complete.
Elapsed: 00:00:00.08
append data from MIG_TEST.MO1_MEMO_EXT_12 to MIG_TEST.MO1_MEMO 976772 rows created.
Elapsed: 00:00:32.67
Commit complete.
Elapsed: 00:00:00.05
append data from MIG_TEST.MO1_MEMO_EXT_13 to MIG_TEST.MO1_MEMO 851574 rows created.
Elapsed: 00:00:30.06
Commit complete.
Elapsed: 00:00:00.02
然後再做一次行列轉換,按照關鍵字“rows created" 來做行列轉換
最後的輸入類似下面。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO 1702297 rows created. Elapsed: 00:00:57.67
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO 1280364 rows created. Elapsed: 00:00:52.77
完整的命令如下:
sed -e '/^$/d' append_details.log|sed '/append data from/{N;N; s/\n/ /}' |sed '/rows created/{N;s/\n/ / }'|grep 'append'
日誌的內容如下:
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO
1936470 rows created.
Elapsed: 00:01:01.53
Commit complete.
Elapsed: 00:00:00.03
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO
873897 rows created.
Elapsed: 00:00:22.67
Commit complete.
Elapsed: 00:00:00.02
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO
1702297 rows created.
Elapsed: 00:00:57.67
Commit complete.
Elapsed: 00:00:00.04
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO
1280364 rows created.
Elapsed: 00:00:52.77
現在想把特定的一些行轉列,實現類似如下的效果。 這樣資料條數,插入時間等就一目瞭然了,可以在此基礎上成為報告,便於檢視狀態和監控。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
這個時候可以使用sed來做處理,完成特定的行列轉換。
首先刪除多餘的空行
sed -e '/^$/d' append_details.log
然後在此基礎上根據”append data from“來做第一次行列轉換。
sed '/append data from/{N;N; s/\n/ /}'
這樣,格式化後的內容就類似下面的形式。
append data from MIG_TEST.MO1_MEMO_EXT_11 to MIG_TEST.MO1_MEMO 2083618 rows created.
Elapsed: 00:01:24.92
Commit complete.
Elapsed: 00:00:00.08
append data from MIG_TEST.MO1_MEMO_EXT_12 to MIG_TEST.MO1_MEMO 976772 rows created.
Elapsed: 00:00:32.67
Commit complete.
Elapsed: 00:00:00.05
append data from MIG_TEST.MO1_MEMO_EXT_13 to MIG_TEST.MO1_MEMO 851574 rows created.
Elapsed: 00:00:30.06
Commit complete.
Elapsed: 00:00:00.02
然後再做一次行列轉換,按照關鍵字“rows created" 來做行列轉換
最後的輸入類似下面。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO 1702297 rows created. Elapsed: 00:00:57.67
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO 1280364 rows created. Elapsed: 00:00:52.77
完整的命令如下:
sed -e '/^$/d' append_details.log|sed '/append data from/{N;N; s/\n/ /}' |sed '/rows created/{N;s/\n/ / }'|grep 'append'
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8494287/viewspace-1347088/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 行列轉換
- linux_sed替換特殊符號Linux符號
- Kettle行列轉換
- 偽行列轉換!
- 行列轉換sqlSQL
- 複雜的行列轉換
- 通用的行列轉換的方法
- 行列轉換 交叉表 (轉)
- Oracle-行列轉換Oracle
- MySQL行列轉換拼接MySql
- 行列轉換之大全~~~
- sql server 行列轉換SQLServer
- 使用vue實現行列轉換的一種方法。Vue
- oracle和mysql的行列轉換OracleMySql
- 行列轉換的一個例子
- oracle行列轉換-多行轉換成字串Oracle字串
- 行列轉換,列行轉換統計
- oracle行列轉換-行轉列Oracle
- oracle行列轉換-列轉行Oracle
- oracle 11g 使用 pivot/unpivot 行列轉換Oracle
- mysql行列轉換詳解MySql
- sql server行列轉換案例SQLServer
- Oracle 行列轉換 經典Oracle
- Oracle 行列轉換總結Oracle
- Oracle 行列轉換小結Oracle
- 【SQL 學習】行列轉換SQL
- 【SQL】行列轉換方法示例SQL
- Oracle行列轉換總結Oracle
- Shell練習 行列轉換
- oracle行列轉換-字串轉換成多列Oracle字串
- oracle行列轉換-多列轉換成字串Oracle字串
- sql 實現表的行列轉換SQL
- 記錄一個行列轉換
- 行列轉換問題總結
- Oracle行列轉換及pivot子句的用法Oracle
- 幾個行列轉換的實用小例子
- pivot、unpivot實現oracle行列轉換Oracle
- Oracle--SQL行列轉換實戰OracleSQL