免费注册 查看新帖 |

Chinaunix

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

请教如何用shell实现这样的SQL功能??? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-01-26 22:55 |只看该作者 |倒序浏览
比如现在我有1万行如下文本:
09/26/2004 SMDAP1126 161238 485 366 2 32
09/26/2004 CBSDEV02-UX 152242121 5548 2582 4709 36
09/26/2004 SMDAP1120 375711 6938 6691 21 31
09/26/2004 CBSDEV01-UX 84840926 2404 2481 1408 2385
09/26/2004 CBSDEV04SV 344955 25 9 1 0
09/26/2004 SMDAP1127 43878618 1454 215 434 0
09/27/2004 CBSDEV02-UX 181720181 5860 2577 5035 35
09/27/2004 SMDAP1126 175407 2656 234 2 2333
09/27/2004 SMDAP1120 706517 7675 7422 74 31
...........................

我想对文本按第1,2列进行汇总如下:
09/26/2004 SMDAP1126 20303 432321 5423 132 533
09/27/2004 SMDAP1126 30503 433321 1233 132 533
.......
09/26/2004 CBSDEV02-UX 4323 452 123 532
.........

即如果第1,2列相同,对3,4,5,6累加汇总,在数据库中用select from group by很容易实现,可用shell/awk/sed如何实现?

急用,谢谢!!!

论坛徽章:
0
2 [报告]
发表于 2005-01-27 11:41 |只看该作者

请教如何用shell实现这样的SQL功能???

试着写一个:
awk '{sum1[$1"x"$2]+=$3;sum2[$1"x"$2]+=$4;sum3[$1"x"$2]+=$5;sum4[$1"x"$2]+=$6;a[$1"x"$2]=$1" "$2}END{for(i in a) print a,sum1,sum2,sum3,sum4}' file

论坛徽章:
0
3 [报告]
发表于 2005-01-27 16:46 |只看该作者

请教如何用shell实现这样的SQL功能???

发表于: 2005-01-27 11:01    发表主题:      

--------------------------------------------------------------------------------

试着写一个:
awk '{sum1[$1"x"$2]+=$3;sum2[$1"x"$2]+=$4;sum3[$1"x"$2]+=$5;sum4[$1"x"$2]+=$6;a[$1"x"$2]=$1" "$2}END{for(i in a) print a,sum1,sum2,sum3,sum4}' file

可是按这个所得结果中,并没有求出和,都是0.

论坛徽章:
0
4 [报告]
发表于 2005-01-27 17:00 |只看该作者

请教如何用shell实现这样的SQL功能???

原帖由 "nv2test" 发表:
e

可是按这个所得结果中,并没有求出和,都是0.


bash-2.03$ cat file
09/26/2004 SMDAP1126 161238 485 366 2 32
09/26/2004 CBSDEV02-UX 152242121 5548 2582 4709 36
09/26/2004 SMDAP1120 375711 6938 6691 21 31
09/26/2004 CBSDEV01-UX 84840926 2404 2481 1408 2385
09/26/2004 CBSDEV04SV 344955 25 9 1 0
09/26/2004 SMDAP1127 43878618 1454 215 434 0
09/27/2004 CBSDEV02-UX 181720181 5860 2577 5035 35
09/27/2004 SMDAP1126 175407 2656 234 2 2333
09/27/2004 SMDAP1120 706517 7675 7422 74 31


bash-2.03$ awk '{sum1[$1"x"$2]+=$3;sum2[$1"x"$2]+=$4;sum3[$1"x"$2]+=$5;sum4[$1"x"$2]+=$6;a[$1"x"$2]=$1" "$2}END{for(i in a) print a,sum1,sum2,sum3,sum4}' file
09/26/2004 CBSDEV01-UX 84840926 2404 2481 1408
09/26/2004 CBSDEV02-UX 152242121 5548 2582 4709
09/27/2004 CBSDEV02-UX 181720181 5860 2577 5035
09/26/2004 CBSDEV04SV 344955 25 9 1
09/26/2004 SMDAP1120 375711 6938 6691 21
09/27/2004 SMDAP1120 706517 7675 7422 74
09/26/2004 SMDAP1126 161238 485 366 2
09/27/2004 SMDAP1126 175407 2656 234 2
09/26/2004 SMDAP1127 43878618 1454 215 434

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
5 [报告]
发表于 2005-01-27 17:05 |只看该作者

请教如何用shell实现这样的SQL功能???

有现成的数据库不用?!

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
6 [报告]
发表于 2005-01-27 17:10 |只看该作者

请教如何用shell实现这样的SQL功能???

shell比上帝还万能

论坛徽章:
0
7 [报告]
发表于 2005-01-27 17:12 |只看该作者

请教如何用shell实现这样的SQL功能???

用正确的工具做正确的事情是王道啊

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
8 [报告]
发表于 2005-01-27 17:16 |只看该作者

请教如何用shell实现这样的SQL功能???

这在于怎么理解unix中的每个工具的用途!
这些工具就好比一些积木,只有充分发挥它们各自的优势,才能更好的完成任务!

论坛徽章:
0
9 [报告]
发表于 2005-01-28 11:16 |只看该作者

请教如何用shell实现这样的SQL功能???

To icesummit:
非常感谢你的脚本,太棒了!
只是有一点,不知如何用awk对时间这一列排序,数值没问题,真怪!

To 寂寞烈火:
Q: 有现成的数据库不用?!
A: 机器里没有数据库,这不是数据库产生的输出结果. 所以icesummit的script帮我大忙!

谢谢各位,我的shell功底有点不好意思!

论坛徽章:
0
10 [报告]
发表于 2005-01-28 13:27 |只看该作者

请教如何用shell实现这样的SQL功能???

原帖由 "ddlldd2000" 发表:
To icesummit:
只是有一点,不知如何用awk对时间这一列排序,数值没问题,真怪!


要不你先拿sort把你的文件排序了再用awk?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP