首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >BASH中的管道导致与db2的连接丢失

BASH中的管道导致与db2的连接丢失
EN

Stack Overflow用户
提问于 2016-08-01 11:15:57
回答 1查看 76关注 0票数 3
代码语言:javascript
运行
复制
# it works fine
db2 connect to <db_name> user <user> using <passwd>
while read aline
do
    tab=$(echo $aline | awk -F',' '{print $1}')
    col=$(echo $aline | awk -F',' '{print $2}')
    max_id=$(db2 -x "select count($col) from $tab")
    echo $tab   $col   $max_id
done < tab.ls


# it doesn't work because of lost DB connection
db2 connect to <db_name> user <user> using <passwd>
cat tab.lst | while read aline
do
    tab=$(echo $aline | awk -F',' '{print $1}')
    col=$(echo $aline | awk -F',' '{print $2}')
    max_id=$(db2 -x "select count($col) from $tab")
    echo $tab   $col   $max_id
done

我有两部分代码,两部分只有很小的差别,第一部分按预期运行,但第二部分没有。

似乎是管道导致了数据库连接的丢失。

有谁能解释一下为什么。

提前感谢!

顺便说一句:我在RH Linux6.6,bash上测试过

EN

回答 1

Stack Overflow用户

发布于 2017-01-21 20:31:17

DB2 documentation说:

别名一次只能连接到一个DB2数据库;但是,通过使用

参数来区分连接,可以使用多个connect语句连接到多个DB2数据源。

在上面的示例中,您连接了两次。请考虑重置或终止连接:

代码语言:javascript
运行
复制
db2 connection reset

代码语言:javascript
运行
复制
db2 terminate
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38690509

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档