0

我有 100 条记录。当我运行下面的代码时,SQL*Plus 连接打开了很多次,占用了 100% 的 CPU。有什么方法可以只打开一次 SQL*Plus 连接,即外部while循环?

**#!/bin/bash
export ORACLE_HOME=/software/oracle/ora10204
export PATH=$PATH:$ORACLE_HOME/bin
INPUT_FILE='file.csv'
IFS=','
i=0
while read name id do
a[i]="$name"
b[i]="$id"
echo "${a[$i]}  ${b[$i]}"
set serveroutput on;
sqlplus .../...@'(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=...)(HOST=...)(PORT=...)))(CONNECT_DATA=(SID=...)))'<<EOF
insert into code_entry(inh_valu,edi_valu) values('${a[$i]}' , '${b[$i]}');
EOF
let i=$i+1
done < $INPUT_FILE**
4

1 回答 1

0

您可以创建一个 SQL 脚本,在您的 shell 脚本结束时使用 SQL*Plus 调用一次。它将使用INSERT ALLDML 命令,您只需>>在现有循环中使用您的 shell 脚本和重定向运算符 ( ) 将字符串附加到它。

运行 shell 脚本后,您的 SQL 脚本可能如下所示:

insert all
into code_entry (inh_valu, edi_valu) values (1, 'foo')
into code_entry (inh_valu, edi_valu) values (2, 'bar');
...

然后,您将像这样运行它:

$ sqlplus scott/tiger @myscript.sql

示例 shell 脚本可能如下所示:

echo "insert all" > myscript.sql

INPUT_FILE='file.csv'
IFS=','
i=0
while read name id do
  a[i]="$name"
  b[i]="$id"
  echo "into code_entry(...) values ('${a[$i]}', '${b[$i]}')" >> myscript.sql
  let i=$i+1
done < $INPUT_FILE**

echo ";" >> myscript.sql

sqlplus .../...@'(DESCRIPTION=...)' @myscript.sql
于 2013-05-09T05:40:09.677 回答