firsty78
Goto Top

SQL Statement Syntax Oracle Excel VBA

Hallo zusammen,

ich befinde mich im VBA Editor und möchte per ODBC eine Oracle 9 Datenbank abfragen und die Daten in Excel ausgeben. Folgenden Code verwende ich

Dim cnOra As ADODB.Connection
Dim rsOra As ADODB.Recordset
Dim StrSelect As String
Dim db_name As String
Dim UserName As String
Dim Password As String
Dim i As Long

Set cnOra = New ADODB.Connection
Set rsOra = New ADODB.Recordset

db_name = "Oracle"
UserName = "User"
Password = "pw"


cnOra.Open "DSN=" + db_name + ";UID=" + UserName + ";PWD=" + Password + ";"
rsOra.CursorLocation = adUseServer

rsOra.Open _
" select E.* " _
& " from (Infor_relEs E left join Infor_relAc A " _
& " on E.Datenfelder_1 = A.MNr) " _
& " where E.Satzart = 'UA' ", cnOra, adOpenForwardOnly _

i = 1
While Not rsOra.EOF
Worksheets("Oracle").Cells(i, 1) = rsOra![Datenfelder_1]
rsOra.MoveNext
i = i + 1
Wend

rsOra.Close
cnOra.Close
Set rsOra = Nothing

Die Datenbank wird gefunden nur das SQL Statement scheint einen Fehler zu haben, den ich einfach nicht finde. Im jetzigen Zustand kommt die Meldung "[Oracle][ODBC][Ora]ORA-00942: table or view does not exist.

Wo liegt mein Fehler?

Vielen Dank

Content-Key: 83607

Url: https://administrator.de/contentid/83607

Printed on: April 25, 2024 at 16:04 o'clock

Member: Biber
Biber Mar 22, 2008 at 17:15:09 (UTC)
Goto Top
Moin firsty78,

falls Dein verwendeter User nicht gleichzeitig der Owner des Schemas ist, dann solltest Du den Schema-Namen mit angeben, z.B. "...from UnserSchema.Infor_relEs E..."

[OT]
Abgesehen davon halte ich Dein SQL für ...na ja, sagen wir mal syntaktischen Overkill.

Wenn Ziel der Aktion ist, alle Datenfelder_1 in einer Excel-Spalte aufzulisten mit dem Kriterium, dass die Satzart gleich 'UA' ist und dass sich ein LEFT JOIN an irgendeine andere Tabelle flanschen lässt...

...dann reicht auch ein...
 select Datenfelder_1 from UnserSchema.Infor_relEs where Satzart = 'UA';  
[/OT]

Grüße
Biber
Member: firsty78
firsty78 Mar 31, 2008 at 09:02:15 (UTC)
Goto Top
Hallo Biber,

vielen Dank für Deine Antwort und sorry für die späte Rückmeldung. Hatte Urlaub, Umzug, kein Internet,...

Wenn Du von einem "syntaktischen Overkill" sprichst meinst Du dann, dass mein komplettes Statement irgendwie "schrottig" ist? Oder meinst Du, dass es etwas überdimensioniert ist? Ich habe den left join, da ich aus der relac ebenfalls Daten laden möchte.

Gruß,
firsty
Member: Biber
Biber Mar 31, 2008 at 09:13:35 (UTC)
Goto Top
Moin firsty78,

Oder meinst Du, dass es etwas überdimensioniert ist?
Dies meinte ich.
Ich habe den left join, da ich aus der relac ebenfalls Daten laden möchte.
Davon ist aber nichts zu sehen. Oben steht nur ein "select E.*", wobei E der Alias für die Tabelle Infor_relEs ist. Die Felder der geJOINten Tabelle A (= Infor_RelAc) erblicken nie das Tageslicht beziehungsweise sind nicht im Resultset enthalten.

Aber eigentlich ist das ein Nebenschauplatz.
Was macht denn das Hauptproblem? Wollen wir das erst abhandeln?

Grüße
Biber
Member: firsty78
firsty78 Mar 31, 2008 at 10:22:10 (UTC)
Goto Top
Hallo Biber,

das Problem hängt tatsächlich mit dem User zusammen. Ich habe den User ausgetauscht und die Feldbezeichnungen abgeändert und der Import funktioniert - fast - korrekt.

Folgendermaßen sieht es im Moment aus:

Set cnOra = New ADODB.Connection
Set rsOra = New ADODB.Recordset

db_name = "Oracle"
UserName = "User"
Password = "pw"
StrSelect = "Select E.Datenfelder_1 ArtNr1, A.KTxt Bez from relEs E left join relAc A on E.Datenfelder_2 = A.MNr where Satzart ='UA'"

cnOra.Open "DSN=" + db_name + ";UID=" + UserName + ";PWD=" + Password + ";"
rsOra.CursorLocation = adUseServer

rsOra.Open StrSelect, cnOra, adOpenForwardOnly

i = 1
While Not rsOra.EOF
Worksheets("Oracle").Cells(i, 1) = rsOra![ArtNr1]
Worksheets("Oracle").Cells(i, 2) = rsOra![Bez]
rsOra.MoveNext
i = i + 1
Wend

rsOra.Close
cnOra.Close
Set rsOra = Nothing

"ArtNr1" enthält den korrekten Wert aus der relEs, wohingegen der Wert von "Bez" NULL ist.

Gruß,
firsty
Member: Biber
Biber Mar 31, 2008 at 10:51:59 (UTC)
Goto Top
Hmmm, firsty87,

kann das daran liegen, dass Du die aktuelle Relation über "Datenfelder_2=A.Mnr" bildest statt wie oben über "Datenfelder_1"??

Grüße
Biber
Member: firsty78
firsty78 Mar 31, 2008 at 12:24:11 (UTC)
Goto Top
Oje oje, ich schäme mich!!

Das war es, jetzt klappt alles wunderbar - ZAUBEREI!! face-smile

Vielen Dank.

Grüße,
firsty