免费注册 查看新帖 |

Chinaunix

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

[文本处理] 怎么在awk中操作mysql [复制链接]

论坛徽章:
1
亥猪
日期:2013-10-30 23:29:55
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-03 22:07 |只看该作者 |倒序浏览
现在的需求是从mysql的10个表中取数据,然后放到10个对应的文件,然后for循环,根据特定的映射规则,遍历10个文件,把所有数据存放到1000个数据表中。

现在存放到文件没有问题,问题是:我用awk读取文件,然后需要在awk中将数据插入到表中,但是似乎这样行不通,因为awk中的''屏蔽了mysql中的一些字符,导致不能调用成功。

我现在的文件输出格式:
  1. 2001    com.oppo.ubeauty        374190938       2013-07-18 15:32:35
复制代码
shell部分脚本:
  1. awk -F'\t' '{
  2. print $1,$2,$3,$4
  3. appid=$1
  4. pkg=$2
  5. imei=$3
  6. time=$4

  7. mysql  -u${user} -p${passwd} -BN -e "use ${database};insert into ${tName} (update_time) values(time)"
  8. }
  9. END{
  10. }' ${tName}.txt
复制代码
执行这个脚本肯定报错,或许是我这种思路不对,但是确实不知道怎么做好?

论坛徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序设计版块每日发帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序设计版块每日发帖之星
日期:2016-06-12 06:20:002016科比退役纪念章
日期:2016-05-31 15:47:20CU十四周年纪念徽章
日期:2016-05-27 12:24:562015年亚洲杯之阿曼
日期:2015-05-03 21:01:352015年辞旧岁徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序设计版块每日发帖之星
日期:2016-08-11 06:20:00
2 [报告]
发表于 2013-09-03 22:16 |只看该作者
${user} 这中用法在单引号下不行。外面传进来的变量可以用-vVar=val试试

论坛徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序设计版块每日发帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序设计版块每日发帖之星
日期:2016-06-12 06:20:002016科比退役纪念章
日期:2016-05-31 15:47:20CU十四周年纪念徽章
日期:2016-05-27 12:24:562015年亚洲杯之阿曼
日期:2015-05-03 21:01:352015年辞旧岁徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序设计版块每日发帖之星
日期:2016-08-11 06:20:00
3 [报告]
发表于 2013-09-03 22:17 |只看该作者
awk调用外部命令要用system("cmd")

论坛徽章:
1
亥猪
日期:2013-10-30 23:29:55
4 [报告]
发表于 2013-09-04 08:57 |只看该作者
回复 3# liion631818


    但是怎么用mysql呢,mysql执行命令-e也需要引号的

论坛徽章:
1
亥猪
日期:2013-10-30 23:29:55
5 [报告]
发表于 2013-09-04 10:19 |只看该作者
回复 2# liion631818


    恩,用-var var=val这样就可行了,哈哈,多谢多谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP