前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用sed做特殊的行列转换(r2笔记40天)

使用sed做特殊的行列转换(r2笔记40天)

作者头像
jeanron100
发布2018-03-14 15:48:53
7960
发布2018-03-14 15:48:53
举报

行列转换在数据库,开发语言中都是一个津津乐道的话题,今天来简单演示一个使用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'

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2014-07-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 杨建荣的学习笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档