免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 3756 | 回复: 27
打印 上一主题 下一主题

【求教】将一个文件中比另一个文多出的记录显示出来。用脚本怎么实现呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-11 15:23 |只看该作者 |倒序浏览
有下面两个数据库脚本:

tmp1.txt内容如下:


use FaultDB
go

delete tbl_AlarmCfg where AlarmGroupID = -65495 and AlarmID >= 2097152
go

go
insert into tbl_AlarmCfg(AlarmGroupID,AlarmID,AlarmType,AlarmClass,AlarmFunc,AlarmLevel,HaveDevSerialNo,AlarmName,Meaning,DefineField,PosInfo) values(-65495, 36700342 , 0, 3, 5, 2, 0, '配置的扣板类型或数量与真实扣板类型或数目不一致异常', '配置的扣板类型或数量与真实扣板类型或数目不一致异常', 3, '3,4#')
go         
insert into tbl_AlarmCfg(AlarmGroupID,AlarmID,AlarmType,AlarmClass,AlarmFunc,AlarmLevel,HaveDevSerialNo,AlarmName,Meaning,DefineField,PosInfo) values(-65495, 119537665, 0, 5, 10, 2, 0, '发生主备倒换', '主备板之间发生了倒换', 4, '3,4#原主板槽位号,单板的描述(仅网管可见)')
go         
     

tmp2.txt内容如下:

use FaultDB
go

delete tbl_AlarmCfg where AlarmGroupID = -65495 and AlarmID >= 2097152
go

go
insert into tbl_AlarmCfg(AlarmGroupID,AlarmID,AlarmType,AlarmClass,AlarmFunc,AlarmLevel,HaveDevSerialNo,AlarmName,Meaning,DefineField,PosInfo) values(-65495, 36700342 , 0, 3, 5, 2, 0, '配置的扣板类型或数量与真实扣板类型或数目不一致异常', '配置的扣板类型或数量与真实扣板类型或数目不一致异常', 3, '3,4#')
go         
insert into tbl_AlarmCfg(AlarmGroupID,AlarmID,AlarmType,AlarmClass,AlarmFunc,AlarmLevel,HaveDevSerialNo,AlarmName,Meaning,DefineField,PosInfo) values(-65495, 119537665, 0, 5, 10, 2, 0, '发生主备倒换', '主备板之间发生了倒换', 4, '3,4#原主板槽位号,单板的描述(仅网管可见)')
go         
insert into tbl_AlarmCfg(AlarmGroupID,AlarmID,AlarmType,AlarmClass,AlarmFunc,AlarmLevel,HaveDevSerialNo,AlarmName,Meaning,DefineField,PosInfo) values(-65495, 170917970, 0, 3, 5, 4, 0, 'ADSL端口链路丢失', '端口链路丢失', 6, '3,4,5,6#端口的描述(仅网管可见)')
go  

以数据库表第二字段    AlarmID的值为关键字 比如36700342 ,将tmp2.txt比tmp1.txt多出的记录显示出来,怎么办呢?

论坛徽章:
0
2 [报告]
发表于 2009-05-11 15:40 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2009-05-11 16:18 |只看该作者
sort -m tmp1.txt tmp2.txt | sort | grep "insert" | uniq -u

论坛徽章:
0
4 [报告]
发表于 2009-05-11 18:54 |只看该作者
如果AlarmID不会重复的话:


  1. awk -F" ?, " 'NR==FNR&&/^insert/{a[$2]=$0};NR>FNR&&/^insert/&&!($2 in a)' tmp1.txt tmp2.txt
复制代码

论坛徽章:
0
5 [报告]
发表于 2009-05-11 21:53 |只看该作者
自己看下diff命令,应该能满足你
diff tmp1.txt tmp2.txt

[ 本帖最后由 angeljyt 于 2009-5-11 21:55 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2009-05-14 20:04 |只看该作者

回复 #4 kwokcn 的帖子

AlarmID是不会重复的。如果tmp1, tmp2中都有某条记录。而要tmp2中的为准,又怎么处理呢?

论坛徽章:
2
申猴
日期:2013-12-26 22:11:31天秤座
日期:2014-12-23 10:23:19
7 [报告]
发表于 2009-05-14 20:17 |只看该作者
diff不行吗?

论坛徽章:
0
8 [报告]
发表于 2009-05-14 20:27 |只看该作者
原帖由 JackMa2009 于 2009-5-14 20:04 发表
AlarmID是不会重复的。如果tmp1, tmp2中都有某条记录。而要tmp2中的为准,又怎么处理呢?

没看明白,如果又要tmp2多出的记录,tmp1和tmp2相同的记录又要以tmp2为准,那不就是tmp2么?……

如果是统计tmp1和tmp2中AlarmID相同的词条,显示tmp2的:

  1. awk -F" ?, " 'NR==FNR&&/^insert/{a[$2]++};NR>FNR&&/^insert/&&($2 in a)' tmp1.txt tmp2.txt
复制代码

论坛徽章:
0
9 [报告]
发表于 2009-05-15 09:10 |只看该作者

回复 #8 kwokcn 的帖子

这样讲吧:
1.将tmp2.txt比tmp1.txt多的,相同的(以tmp2.txt中的为准)显示出。
2.将tmp1.txt中有而tmp2.txt没有的也显示出来。

应用背景是这样的,即,对tmp1.txt增量增加tmp2.txt中的记录

谢谢!

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
10 [报告]
发表于 2009-05-15 10:36 |只看该作者
这个意思? cat <(grep -Fvxf tmp2.txt tmp1.txt) tmp2.txt

[ 本帖最后由 blackold 于 2009-5-15 11:08 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP