免费注册 查看新帖 |

Chinaunix

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

帮忙看下一个条件判断语句,谢谢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-29 15:33 |只看该作者 |倒序浏览
搞了半天了,没看到哪儿出错。。郁闷,希望高手指点下啊.
#!/usr/bin/ksh
awk '{a=$1;q="'\''";s=substr($1,1,16);p=substr($1,1,11);if(a ~ /^89/){print "declare resulte varchar(20);\n begin\n select count(*) into resulte from im.im_inv_imsi_use where inv_id  between "q $1 q" and "q s $2 q";\n if resulte = 0 then dbms_output.put_line("q $1" and "s $2 " ok"q");\n else dbms_output.put_line("q $1" between "s $2 " warning have problem!!"q");\n end if;\n end;\n/"};if(a ~ /^46/){print "declare resulte varchar(20);\n begin\n select count(*) into resulte from im.im_inv_imsi_use where iccid between "q $1 q" and "q p $2 q";\n if resulte = 0 then dbms_out.put_line( "q $1 "and "p $2 " ok "q");\n else dbms_output.put_line("q $1 between "p $2 " have problem!!"q");\n end if;\n end;\n/"}}' IMSI.txt>>jh.sql


上面的红色部分中的if(a ~ /^46/)可以用else代替,不过运行后仍然报错
awk:语法错误 在第 1 行附近
awk:非法语句 在第 1 行附近

IMSI.txt文本格式是:
89860037310838882000 9999
89860037310838892000 7492
460021788000000 9999
460021788100000 9999
....

[ 本帖最后由 jscmc2004 于 2008-12-29 15:36 编辑 ]

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
2 [报告]
发表于 2008-12-29 15:51 |只看该作者
原帖由 jscmc2004 于 2008-12-29 15:33 发表
搞了半天了,没看到哪儿出错。。郁闷,希望高手指点下啊.
#!/usr/bin/ksh
awk '{a=$1;q="'\''";s=substr($1,1,16);p=substr($1,1,11);if(a ~ /^89/){print "declare resulte varchar(20);\n begin\n select c ...

print "里面的双引号用\"

论坛徽章:
0
3 [报告]
发表于 2008-12-29 15:53 |只看该作者
晕~~~  头晕

论坛徽章:
1
2015年亚洲杯之韩国
日期:2015-04-24 09:07:02
4 [报告]
发表于 2008-12-29 15:59 |只看该作者

回复 #1 jscmc2004 的帖子

不能排排格式吗

论坛徽章:
0
5 [报告]
发表于 2008-12-29 16:50 |只看该作者
awk '{
a=$1;
q="'\''";
s=substr($1,1,16);
p=substr($1,1,11);
if(a ~ /^89/)
      {
     print "declare resulte varchar(20);\n begin\n select count(*) into resulte from im.im_inv_imsi_use where inv_id  between "q $1 q" and "q s $2 q";\n
     if resulte = 0 then dbms_output.put_line("q $1" and "s $2 " ok"q");\n
      else dbms_output.put_line("q $1" between "s $2 " warning have problem!!"q");\n
      end if;\n
      end;\n/"
      };
if(a ~ /^46/)
      {
      print "declare resulte varchar(20);\n begin\n select count(*) into resulte from im.im_inv_imsi_use where iccid between "q $1 q" and "q p $2 q";\n        if resulte = 0 then dbms_out.put_line( "q $1 "and "p $2 " ok "q");\n
      else dbms_output.put_line("q $1 between "p $2 " have problem!!"q");\n
      end if;\n
      end;\n/"
      }

}' IMSI.txt>>jh.sql

论坛徽章:
0
6 [报告]
发表于 2008-12-29 16:52 |只看该作者
我排列了格式就报错,说是有换行符。。。
所以就写成一行

论坛徽章:
0
7 [报告]
发表于 2008-12-29 16:54 |只看该作者
你可以写到一个文件里去

论坛徽章:
0
8 [报告]
发表于 2008-12-29 17:09 |只看该作者
引用5楼的提示:
awk:字符串中换行 在第 8 行附近
awk:语法错误 在第 9 行附近
awk:非法语句 在第 9 行附近。。。。。。
不懂。。。

论坛徽章:
0
9 [报告]
发表于 2008-12-29 17:10 |只看该作者
7楼的指点一下,怎么做呢?
保存为一个文件?然后再执行这个文件嘛?

论坛徽章:
0
10 [报告]
发表于 2008-12-29 17:12 |只看该作者
原帖由 jscmc2004 于 2008-12-29 16:52 发表
我排列了格式就报错,说是有换行符。。。
所以就写成一行


太长了就用 \ 换行
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP