sed+awk模拟简单sql查询(26天)
发布日期:2021-06-30 13:28:18 浏览次数:2 分类:技术文章

本文共 1967 字,大约阅读时间需要 6 分钟。

 经常需要用sqlplus去查询一些数据字典类型的数据,这些数据量不大,而且需要环境之间都是一样的,所以就想使用离线查询的方式,把那些数据以平面文件的形式存放,然后通过系统级的操作来输出。以下使用 sed 和awk来实现。还有很多很多需要改进的地方,就当做是抛砖引用了

1.数据量极小的行级筛选

.....

echo 'MODU CC_VERSION           MODULE_VERSION       PROJ_NAME

---- -------------------- -------------------- ------------------------------'

data_path=`pwd`/data

data_file=${data_path}/ccmodule.data   --数据通过sqlplus spool 到这个文件中

sed -n "/$1/p"  $data_file|uniq

输出结果如下:

MODU CC_VERSION           MODULE_VERSION       DEV_PATH

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

MO1        550                                   550                 devpath1

MO2        550                                   550                  devpath2

MO3        550                                   550                  devpath3

MO4        550                                   550                  devpath4

--因为这个数据量极小,而且数据行内的数据分布很有规律,所以我用了sed做了行级操作

2.多重查询条件

类似数据库查询中的 and or条件

......

cc_module=`echo $2|tr [[:lower:]] [[:upper:]]`

data_path=`pwd`/data

data_file=${data_path}/ccobj.data  --数据通过sqlplus spool 到这个文件中

echo 'MODU OBJECT OBJECT_NAME                    DB_AREA_CODE    VERSION

---- ------ ------------------------------ --------------- --------------------'

cat  $data_file |awk '

BEGIN{

cc_version="'$1'"

cc_module="'$cc_module'"

cc_index=1

}

{

if ($1== cc_module && $5 == cc_version)    --组合查询条件,and/or。。。

{

print cc_index,$0

cc_index=cc_index+1

}

}'

--查询结果如下

MODU OBJECT OBJECT_NAME                    DB_AREA_CODE    VERSION

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

1 MO1  app       MO1_TAB1                          DB_AREA1                       550

2 MO1   app      MO1_TAB2                          DB_AREA2                        550

3.动态模糊匹配

 类似数据中的Like 匹配

.......

obj_name=`echo $2|tr [[:lower:]] [[:upper:]]`

data_path=`pwd`/data

data_file=${data_path}/ccobj.data

echo 'MODU OBJECT OBJECT_NAME                    DB_AREA_CODE    VERSION

---- ------ ------------------------------ --------------- --------------------'

cat  $data_file |awk '

BEGIN{

cc_version="'$1'"

obj_name="'$obj_name'"

cc_index=1

}

{

if ($3~obj_name && $5 == cc_version)  --动态模糊匹配

{

print cc_index,$0

cc_index=cc_index+1

}

}'

输出结果如下:

MODU OBJECT OBJECT_NAME                    DB_AREA_CODE    VERSION

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

1 MO1 DUMMY  MO1_TAB1                           DUMMY                         550

2 MO2 DUMMY  MO1_TAB2                           DUMMY                         550

转载地址:https://jeanron100.blog.csdn.net/article/details/102506776 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:关于oracle invalid components问题的解决(28天)
下一篇:10g升级至11g exp的问题解决(23天)

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月11日 11时13分02秒