![]() |
Datenbank: Oracle • Version: 11g • Zugriff über: ODBC->ADO
Kann man mit TADOQuery nur einen Befehl absetzen?
Hallo,
ich habe versucht in einem ExecuteSQL einer TADOQuery mehrere Befehle abzusetzen, bekomme dann aber immer die Ora-Fehlermeldung "Falscher Character", bei folgendem SQL-Statement:
Code:
Jede der Zeilen einzeln ausgeführt funktioniert. Das ist jetzt nur ein Beispiel.
Insert Into Sachbearbeiter Values(4,'SB4');
Insert Into Sachbearbeiter Values(5,'SB5'); Insert Into Sachbearbeiter Values(6,'SB6'); Ich dachte immer, dass man mehrere Anweisungen mit Semikolon getrennt hintereinander ausführen kann. Liegt das vllt. an der Krücke über ADO->ODBC->DB? |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Du greift auf Oralce mittels ADO und ODBC zu? Mutig Mutig. Ein Wunder das das überhaupt funktioniert.
Spaß beiseite. Bei dir Fehlt noch die Feldangabe:
Code:
Oder soll Oracle raten (wie es manch andere DB's machen) in welche Felder du die Werte eintragen willst?
Insert Into Sachbearbeiter(FELDNAME1, FELDNAME2) Values(4, 'SB4');
|
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Ich glaub das ist auch ohne ODBC so (und nicht nur bei ADO?)
Mehrere Befehle benötigen m.E. script Form (>console). Workaround für Oracle und irgendeine maximale Größe ist ein anonymer Block, also PL/SQL Proc ohne Namen :
Code:
P.S: Oracle rät, dass alle Felder in natürlicher Reihenfolge gemeint sind.
Begin
Insert Into Sachbearbeiter Values(4,'SB4'); Insert Into Sachbearbeiter Values(5,'SB5'); Insert Into Sachbearbeiter Values(6,'SB6'); End; Ich würde das aber niemals so verwenden. |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo Bernhard,
das ist nur ein Testbeispiel, das ich dafür konstruiert habe. Die Tabelle hat nur die zwei Felder und wie gesagt jedes Statement für sich genommen funktioniert. Habe es trotzdem auch mal mit den Feldnamen zusätzlich probiert. Der selbe Fehler:
Code:
Das der Zugriffsweg suboptimal ist, weiß ich, haben wir uns glaub ich in älteren Threads von mir auch schonmal drüber unterhalten. Leider kann ich das nicht ändern, da ich dabei nicht das sagen habe und bei den "Sagen-Habern" keiner hört, was ich dazu zu sagen habe :-)
Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(4,'SB4');
Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(5,'SB5'); Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(6,'SB6'); Könnte es denn am ODBC liegen? Ist aber schon der Oracle-ODBC-Treiber, nicht der von MS. |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
siehe oben
|
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Sorry jobo, roter Kasten war in Urlaub und ich hab deinen Post nicht registriert.
Dein Tipp mit dem Begin...End Block funktioniert liefert aber zurück, das nur 1 Datensatz geändert wurde, egal, wieviele es tatsächlich waren. Ist aber nicht schlimm. Eine zweite umständliche Version, die ich inzwischen selber gefunden habe, und die auch die korekte Anzahl an geänderten Datensätzen zurückliefert ist:
Code:
Insert Into Sachbearbeiter(ID,BEZEICHNUNG)
( SELECT 7 AS ID, 'SB7' AS SB FROM DUAL UNION ALL SELECT 8 AS ID, 'SB8' AS SB FROM DUAL ) Wie gesagt, das war für mich nur ein Test, da ich das mal ausprobieren wollte, was als eine Lösung in dem ![]() |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Damit ist es wieder nur ein Statement, das muss natürlich gehen.
Der zurückgelieferte RowCount ist wahrscheinlich stumpf der des letzten Statements. Kann man notfalls vielleicht irgendwie faken. |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Ich hab's im Prinzip so gelöst:
Delphi-Quellcode:
Gruß
for i:=0 to sqlcliste.count-1 do begin
sql.text:=copy(sqlcliste[i],1,length(sqlcliste)-1); sql.sqlexec; end K-H |
AW: Kann man mit TADOQuery nur einen Befehl absetzen?
Wenn SQL-Insert Anweisungen direkt über die TADOConnection absetzt, dann ist das schneller als über eine TADOQuery.
Natürlich kann man dann keine Parameter mehr benützen.
Delphi-Quellcode:
sql :=
'Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(4,''SB4'');'#13#10+ 'Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(5,''SB5'');'#13#10+ 'Insert Into Sachbearbeiter(ID,BEZEICHNUNG) Values(6,''SB6'')'; AdoConnection1.Execute(sql); |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:49 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz