Avatar billede grave Nybegynder
29. oktober 2002 - 13:26 Der er 2 kommentarer og
1 løsning

Oracle og shell script variabler

Jeg skal selecte en rætte i en tabel og have den ud i en shell script variable så jeg kan arbejde videre med den i scriptet.

jeg får følgende output:



BASE_PATH
--------------------------------------------------------------------------------
/docs/vbfs1/12/alr/c8241

SP2-0670: Internal number conversion failed
Usage: { EXIT | QUIT }  [ SUCCESS | FAILURE | WARNING | n |
      <variable> | :<bindvariable> ]  [ COMMIT | ROLLBACK ]
BASE_PATH:

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

når jeg kører:

USER=testuser
PASSWD=testpasswd
ORACLE_SID=testsid

CONSTR="$USER/$PASSWD@$ORACLE_SID"
SQL_STR="
SELECT          dr.BASE_PATH
INTO            :BASE_PATH
FROM            doc_master dm,
                doc_parts dp,
                doc_packages dpa,
                doc_repository dr
WHERE          dm.pub_key = dpa.pub_key
AND            dp.part_key = dpa.part_key
AND            dr.part_key = dpa.part_key
AND            dm.PUB_NUM = '$PUB_NUM';"
$SQLPLUS -s $CONSTR <<EOF
variable BASE_PATH VARCHAR2(80)
$SQL_STR
exit :BASE_PATH
EOF
echo "BASE_PATH: $BASE_PATH"


hvad betyder "Internal number conversion failed" jeg selecter kun VARCHAR2 værdier ingen numre.

er der en fejl eller andre smartere måder at køre gøre det på ??
Avatar billede teepee Nybegynder
29. oktober 2002 - 13:51 #1
Er det ikke fordi den parser '$PUB_NUM' og ikke værdien af denne?
Avatar billede teepee Nybegynder
29. oktober 2002 - 13:52 #2
Pørv lige at echo'e $SQL_STR ud
Avatar billede grave Nybegynder
29. oktober 2002 - 16:37 #3
har løst det:

RETVAL=`$SQLPLUS -s $USER/$PASSWD@$ORACLE_SID <<EOF
set serveroutput on
DECLARE
                v_BASE_PATH doc_repository.base_path%TYPE;
BEGIN
SELECT          dr.BASE_PATH
INTO            v_BASE_PATH
FROM            doc_master dm,
                doc_parts dp,
                doc_packages dpa,
                doc_repository dr
WHERE          dm.pub_key = dpa.pub_key
AND            dp.part_key = dpa.part_key
AND            dr.part_key = dpa.part_key
AND            dm.PUB_NUM = '$PUB_NUM';
dbms_output.put_line('BASE_PATH: '||v_BASE_PATH);
END;
/
EOF`
BASE_PATH=`echo $RETVAL | awk '{print $2}'`
echo "$BASE_PATH"
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester