- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我试图在大量数据导入后自动执行一些约束检查,但遇到了流动问题。我找到了一个解决方法,我也会描述它,但是如果有人比我更了解 Linux 并且可以解释为什么会发生这种情况,我将非常感激。
因此,如果我在以实例所有者身份登录后从 DB2 CLI 运行以下命令,我将打印输出值,没有任何错误。
bla:~> VAL=$(db2 -x 'select count(*) from SIM.SUPPLIER')
bla:~> echo value = $VAL
value = 621684
如果我将命令保存在 select.sh 文件中并使用 在同一进程中调用脚本。 select.sh
以实例所有者身份登录后,我收到一条错误消息,指出没有连接到数据库。我认为命令替换以某种方式在未转发与服务器的连接的新线程中运行。
select.sh内容:
VAL=$(db2 -x 'select count(*) from SCHEMA.TABLE')
echo value = $VAL
我如何运行脚本:
bla:~> db2 connect to DB
Database Connection Information
Database server = DB2/LINUXX8664 11.1.0
SQL authorization ID = DB2INS10
Local database alias = DB
bla:~> . select.sh
value = SQL1024N A database connection does not exist. SQLSTATE=08003
bla:~>
如果 select.sh 只包含 db2 命令,没有分配给 VAL,则连接不会丢失:
select.sh内容:
db2 -x 'select count(*) from SIM.SUPPLIER'
bla:~> . select.sh
621684
bla:~>
现在解决方法:在一个文件中编写 SQL 选择并调用在 select.sh 中运行该文件可以达到目的并且连接不会丢失。
选择.sh内容
echo 'select count(*) from SIM.SUPPLIER;' > sql
db2 -txf sql
bla:~> . select.sh
621684
bla:~>
但这行不通,我不明白为什么:
echo 'select count(*) from SIM.SUPPLIER;' > sql
echo $(db2 -txf sql)
bla:~/> . select.sh
SQL1024N A database connection does not exist. SQLSTATE=08003
bla:~/>
那么有人可以向我解释为什么命令替换会失去服务器连接,以及我如何在保持服务器连接的同时仍然使用它。
PS:我不允许在任何脚本中连接到服务器。出于安全原因,不应将凭据写入文件内。服务器连接必须在调用其他脚本之前建立,并且只能建立一次。
谢谢
最佳答案
原因是 VAL=$(....)
和 echo $(db2 -txf sql)
都运行一个子 shell,并且在那个子shell没有数据库连接。您的解决方法不涉及子 shell,因此它有效。
对于 bash,如果您无法在脚本中使用 connect
,那么您必须避免对 Db2 CLP 进行子脱 shell ,就像您使用解决方法一样。
您可以使用临时文件来避免子 shell,代价是更多的解析等。例如,不要使用 VAL=$(db2 ...)
使用 db2 ... > $tmpfile
后跟 VAL=$(cat $tmpfile)
或类似技术。
您不能这样“转发连接”。
如果您能够将 ksh93 与协进程一起使用,那么您就可以在进程之间进行通信,并确保所有 db2 CLP 操作都发生在一个任务中,然后将结果通过管道传递给另一个任务。但这样的复杂性很少是值得的,使用不同的非 shell 脚本语言可能更可取。
关于sql - 在 shell 脚本中运行选择时 DB2 服务器连接丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55138471/
我相信我在子 shell 中调用 exit 会导致我的程序继续: #!/bin/bash grep str file | while read line do exit 0 done
我相信我在子 shell 中调用 exit 会导致我的程序继续: #!/bin/bash grep str file | while read line do exit 0 done
我有几个脚本,它们的第一部分看起来是一样的。这部分的功能是识别脚本在哪台机器上运行并相应地设置几个变量。它看起来像这样: ENV=`echo $LOGNAME | cut -c1-8` if
这是我正在尝试做的事情。我有 4 个 shell 脚本。脚本 1 需要先运行,然后是 2,然后是 3,然后是 4,并且它们必须按此顺序运行。脚本 1 需要运行(并在后台等待)2 才能正常运行,但是脚本
我有一个名为 a.sh 的脚本,其中的内容是: //a.sh: #!/bin/bash temp=0 while [ "$temp" -ne 500 ] do echo `date`
在snakemake中,使用shell()函数执行多个命令的推荐方式是什么? 最佳答案 您可以调用shell()多次内run规则块(规则可以指定 run: 而不是 shell: ): rule pro
我有一个 shell 脚本,我向其中传递了一些参数。Test1.sh -a 1 -b 2 -c“一二三” 在 Test1.sh 中,我按以下方式调用另一个 shell 脚本。Test2.sh $* 我
我有 2 个 shell 脚本。 第二个shell脚本包含以下函数第二个.sh func1 func2 first.sh 将使用一些参数调用第二个 shell 脚本, 将使用特定于该函数的一些其他参数
我有一个 Unix shell 脚本 test.sh。在脚本中,我想调用另一个 shell,然后从子 shell 执行 shell 脚本中的其余命令并退出 说清楚: test.sh #! /bin/b
我想在 shell 脚本中更改路径环境变量。路径变量需要在shell脚本执行后修改。 最佳答案 我知道有两种方法可以做到这一点。第一种是在当前 shell 的上下文中运行脚本: . myscript.
此 shell 脚本按预期运行。 trap 'echo exit' EXIT foo() { exit } echo begin foo echo end 这是输出。 $ sh foo.sh
我正在使用 vimshell在 vim 中执行命令 nnoremap vs :VimShellPop 使用此键映射,我可以打开 vim shell 并执行诸如“捆绑安装”之类的命令,然后 输入 exi
我想连接到不同的 shell(csh、ksh 等)并在每个切换的 shell 中执行命令。 下面是反射(reflect)我的意图的示例程序: #!/bin/bash echo $SHELL csh e
我目前正在尝试使用 BNF 和 LL 解析器在 C 中重新编写 shell。 否则,我需要知道 shell 运算符的优先级是什么| , > , > , & , ; ? 有没有人可以提供给我? 谢谢 最
不幸的是,我没有suspend 命令(busybox/ash)。但是我可以使用 kill -STOP $$ 从后台 shell (sh &) 返回到父 shell(以及 fg 之后)。 但是我不想输入
我需要知道,当用户切换到另一个 shell 时,通过单击它。 我试过 shellListener.shellDeactivated()但是当 shell 失去对它自己的控件的焦点时,会触发此事件,这意
file1.txt aaaa bbbb cccc dddd eeee file2.txt DDDD cccc aaaa 结果 bbbb eeee 如果能不区分大小写就更好了! 谢谢! 最佳答案 gre
我见过解压缩目录中所有 zip 文件的循环。但是,在运行此之前,我宁愿确保我将要运行的内容正常工作: for i in dir; do cd $i; unzip '*.zip'; rm -rf *.z
我对编程还很陌生,但我想知道 vim、emacs、nano 等 shell 文本编辑器如何能够控制命令行窗口。我主要是一名 Windows 程序员,所以可能在 *nix 上有所不同。据我所知,只能将文
我有一个包含第 7 列日期的文件,我的要求是将它与今天的日期进行比较,如果小于它,则删除该完整行。 此外,如果第 7 列中提到的任何日期超过 15 天,则将其修改为最多 15 天 下面的例子- now
我是一名优秀的程序员,十分优秀!