gpt4 book ai didi

oracle - 将 oracle 查询中的多列值分配给 Unix 中的多个变量

转载 作者:行者123 更新时间:2023-12-02 01:30:10 24 4
gpt4 key购买 nike

我需要从 oracle 查询中读取 10 列的值并将其分配给 10 个 unix 变量。查询将只返回一条记录(行)。

我尝试在选择查询中使用定界符 (;) 附加所有这些列,并将其分配给 unix 中的单个变量 (V)。我想我可以使用“cut”并为 V 中所有必需的 10 个变量赋值。

但问题是有些栏目具有特殊性,我很难删除所需的详细信息。有时分隔符 (;) 本身出现在列值中。代码也很长。

是否有更好的方法将查询中的多个列值分配给 unix 变量?

此外,当我从查询中读取“-e”并将其传递给 unix 变量时,它会变成“?e”。无论如何我们可以解决这个问题。

谢谢。

最佳答案

有很多方法可以实现,具体取决于您想要实现的目标。这是一个特殊情况;作为分隔符。但是,您始终可以使用默认的空格分隔符。

variable=$($ORACLE_HOME/bin/sqlplus -s /  as sysdba <<EOF
set head off
set verify off
set feedback off
select sysdate || ';' || systimestamp from dual;
exit;
EOF
)

sysdate=$(echo $variable | awk -F ';' '{print $1}')
echo 'col1:'$sysdate

systimestamp=$(echo $variable | awk -F ';' '{print $2}')
echo 'col2:'$systimestamp

关于oracle - 将 oracle 查询中的多列值分配给 Unix 中的多个变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34749343/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com