免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: 侧面bt
打印 上一主题 下一主题

黑哥,请进,我需要你的帮助!!! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-07 11:27 |显示全部楼层 |倒序浏览
本帖最后由 侧面bt 于 2010-07-07 12:00 编辑

现在要把错误日志文件里面的sql语句提出来,组合成正确的重装执行,日志文件的格式如下:

[time] 2010-07-05 10:45:54.765432
[tid] 6308
[file] ../src/DBOpr.cpp
[line] 38
[info] DB Error: Fail To Execute SQL: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'UpdatePeroid = 0 where id= 1164605496' at line 1
SQL: update table_29 set dname = 'sunsecond.com', IPNum = 1, IP = '114.80.162.3',  UpdateTime = '2010-07-05 10:45:54' UpdatePeroid = 0 where id = 116460549

[time] 2010-07-05 10:45:57.229553
[tid] 6310
[file] ../src/DBOpr.cpp
[line] 38
[info] DB Error: Fail To Execute SQL: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'UpdatePeroid = 0 where id= 14204116719' at line 1
SQL: update table_21 set dname = '15aaa.com', IPNum = 3, IP = '173.244.202.183
n173.244.202.184
173.244.202.189'
UpdateTime = '2010-07-05 10:45:57' UpdatePeroid = 0 where id = 1420411671

现在的问题是对于ip个数是1个的倒还好处理,因为都在一行内,但对于IP有多个的,由于IP这个字段是换\n分隔的,所以在日志文件里变成了多行,还在要还原为一行,比如第一条记录要还原成:
update table_21 set dname = '15aaa.com', IPNum = 3, IP = '173.244.202.183\n173.244.202.184\n173.244.202.189' UpdateTime = '2010-07-05 10:45:57' UpdatePeroid = 0 where id = 142041167

请问黑哥该怎么处理啊,用什么好,awk还是sed还是其它方法,谢了,对了,日志记录非常大,大概有10万条以上。

论坛徽章:
0
2 [报告]
发表于 2010-07-07 12:13 |显示全部楼层
谢谢楼上的,可以解释一下吗,看不太懂。

论坛徽章:
0
3 [报告]
发表于 2010-07-07 17:42 |显示全部楼层
执行了,感觉黑哥的最快!

论坛徽章:
0
4 [报告]
发表于 2010-07-07 17:46 |显示全部楼层
回复  侧面bt


    如果是gawk:
blackold 发表于 2010-07-07 12:57


黑哥,你的简直是天书啊,看不懂啊,解释一下好吗?

论坛徽章:
0
5 [报告]
发表于 2010-07-07 18:35 |显示全部楼层
黑哥,现在库里的IP是换\n分隔的,而你的脚本是用空格分隔,我试着改了一下,不对,麻烦你再改一下吧,谢谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP