亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問(wèn)板塊 發(fā)新帖
查看: 2476 | 回復(fù): 9
打印 上一主題 下一主題

求一段 根據(jù)表名下面 { } 之間的內(nèi)容 判斷的輸出 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2007-12-10 11:42 |只看該作者 |倒序?yàn)g覽
求一段 根據(jù)表名下面 { } 之間的內(nèi)容 判斷的輸出

文件 sjk.sql 內(nèi)容如下
creat table a

{
  
  jgm char(10);
  cc char(10);
}

creat table ab


{

  lkj char(6);
  tt char(10);
}

creat table c1
{
  cc char(10);
  l char(20);
  ia int;
  jgm char(10);
  h char(10);
}

creat table dd

{
abc int;
  jgm char(10);
  yy char(10);
}

creat table cy1



{


  kk char(10);
}


如何 把有 jgm 的 表名打印出來(lái)
如 顯示如下內(nèi)容 :

表 a 含有 jgm 字段 OK

表 ab  未含有 jgm 字段 ERROR

表 c1 含有 jgm 字段 OK

表 dd 含有 jgm 字段 OK

表 cy1  未含有 jgm 字段 ERROR

[ 本帖最后由 hbczjzc 于 2007-12-10 11:48 編輯 ]

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2007-12-10 12:17 |只看該作者
sed -n '
/creat table/{:a;N;/}/!ba;
/jgm/{s/creat table \([^ ]*\)\n.*$/table \1 contain jgm OK/p};
/jgm/!{s/creat table \([^ ]*\)\n.*$/table \1 not contain jgm ERROR/p}}' URfile

[ 本帖最后由 BLZer 于 2007-12-10 12:24 編輯 ]

論壇徽章:
23
15-16賽季CBA聯(lián)賽之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午馬
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16賽季CBA聯(lián)賽之山東
日期:2017-12-21 16:39:1915-16賽季CBA聯(lián)賽之廣東
日期:2016-01-19 13:33:372015亞冠之山東魯能
日期:2015-10-13 09:39:062015亞冠之西悉尼流浪者
日期:2015-09-21 08:27:57
3 [報(bào)告]
發(fā)表于 2007-12-10 12:22 |只看該作者
awk '/creat/{a=$3;b=0;while(getline){if(/}/)break;if(/jgm/)b=1};if(b)print a" OK";else print a" ERROR"}' sjk.sql

論壇徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亞冠之浦和紅鉆
日期:2015-06-23 19:10:532015亞冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16賽季CBA聯(lián)賽之山東
日期:2016-01-31 18:25:0515-16賽季CBA聯(lián)賽之四川
日期:2016-02-16 16:08:30程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-06-29 06:20:002017金雞報(bào)曉
日期:2017-01-10 15:19:5615-16賽季CBA聯(lián)賽之佛山
日期:2017-02-27 20:41:19
4 [報(bào)告]
發(fā)表于 2007-12-10 12:35 |只看該作者

  1. awk 'BEGIN{RS="}"}
  2. $3{print $3,($0~/jgm/)?"OK":"ERROR"}' urfile
復(fù)制代碼

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2007-12-10 12:47 |只看該作者

  1. awk 'BEGIN{RS="}"}/jgm/{printf "表 %s 含有jgm字段 OK\n",$3}'
復(fù)制代碼


解釋?zhuān)?br /> BEGIN{RS="}"}  把}作為行分隔符,這樣,每個(gè)create table ??{ ..... }就作為一行來(lái)處理
/jgm/{printf "表 %s 含有jgm字段 OK\n",$3} 如果某邏輯行(用}分隔的,而不是用\n分隔的)包含jgm,就打印
因?yàn)槿笔∈怯每瞻追麃?lái)分隔字段的,因此,第三個(gè)字段就是  表名

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2007-12-10 13:20 |只看該作者
用}來(lái)分割,妙啊。。。。。

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2007-12-10 14:28 |只看該作者
多謝,樓上幾位相助。

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2007-12-10 14:47 |只看該作者
原帖由 waker 于 2007-12-10 12:35 發(fā)表

awk 'BEGIN{RS="}"}
$3{print $3,($0~/jgm/)?"OK":"ERROR"}' urfile


這里為什么要寫(xiě)上$3呢?
不明白

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2007-12-10 23:29 |只看該作者
原帖由 mcolinc 于 2007-12-10 14:47 發(fā)表


這里為什么要寫(xiě)上$3呢?
不明白

這里相當(dāng)于if($3!=""),防止空行的時(shí)候也打印ERROR字符。

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2007-12-11 10:00 |只看該作者
恩,明白了
謝謝ls的解答
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專(zhuān)區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過(guò)ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP