CAST fehlender Operator
Access 2007, Microsoft Visual Basic 6.5
In einer Suche mit Dlookup wird CAST zur Umwandlung einer im Textformat vorliegenden Zahl zu int verwendet. Als Fehlermeldung Laufzeitfehler 3075 wird ein fehlender Operator angegeben.
Dim Test As Variant
Test = DLookup("MAX(CAST(RIGHT([VersNr],11) AS int))", "Tabelle", "LEFT(VersNr,1) = 'D'")
In der Tabelle ist die Spalte VersNr als Text der Feldgröße 12 definiert. Die gesuchten Nummern lauten z.B. D1430 etc., es soll die größte Nummer gefunden werden. Wo könnte der Fehler liegen ?
Vorab Dake für jede Hilfe, PCFJKG.
In einer Suche mit Dlookup wird CAST zur Umwandlung einer im Textformat vorliegenden Zahl zu int verwendet. Als Fehlermeldung Laufzeitfehler 3075 wird ein fehlender Operator angegeben.
Dim Test As Variant
Test = DLookup("MAX(CAST(RIGHT([VersNr],11) AS int))", "Tabelle", "LEFT(VersNr,1) = 'D'")
In der Tabelle ist die Spalte VersNr als Text der Feldgröße 12 definiert. Die gesuchten Nummern lauten z.B. D1430 etc., es soll die größte Nummer gefunden werden. Wo könnte der Fehler liegen ?
Vorab Dake für jede Hilfe, PCFJKG.
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 123812
Url: https://administrator.de/forum/cast-fehlender-operator-123812.html
Ausgedruckt am: 24.01.2025 um 05:01 Uhr
6 Kommentare
Neuester Kommentar
Hallo,
ich bin nicht sicher ob MS Access Funktionen innerhalb der Domänen-Funktionen (DLookup, DMax etc) ausführen kann.
Lösungsvorschlag: Erstelle eine Abfrage, die das Feld der Tabelle entsprechend modifiziert, d.h. RIGHT(...) und CAST(...) bereits enthält. Dann frage diese Abfrage mit DMax() ab.
btw. Gibt es in Access-SQL wirklich die Funktion cast()? Sonst versuch es mal mit val(...)
Gruß
Stefan
ich bin nicht sicher ob MS Access Funktionen innerhalb der Domänen-Funktionen (DLookup, DMax etc) ausführen kann.
Lösungsvorschlag: Erstelle eine Abfrage, die das Feld der Tabelle entsprechend modifiziert, d.h. RIGHT(...) und CAST(...) bereits enthält. Dann frage diese Abfrage mit DMax() ab.
btw. Gibt es in Access-SQL wirklich die Funktion cast()? Sonst versuch es mal mit val(...)
Gruß
Stefan
Moin PCFJKG,
ich weiß nicht...
Manche Probleme sollte man/frau nicht zu lösen versuchen, sondern einfach gar nicht heraufbeschwören.
1. Wenn Du die "höchste" vergebene VersNr finden willst, die mit "Dnnnn" beginnt, dann schenkt Dir das versuchte Umformen auf einen INT. nimm einfach ein "Max(VersNr)".
2. Wenn Du schon nicht darauf hören willst, dann nimm statt der schlampig hingebratzten CAST-Funktion die CInt()-Funktion
> ..Test = DLookup("MAX(CInt(RIGHT([VersNr],11) ))", "Tabelle", "LEFT(VersNr,1) = 'D'")
3. Wenn Du schon in einen INT (was auch immer Access darunter zu verstehen vorgibt) konvertieren willst, dann überprüf noch mal, ob für einen INT-Wert denn die rechten elf (11!!) Zeichen eines Strings nicht ein bisschen ruppig sind.
Ein Test mit
liefert jedenfalls (logischerweise) sofort einen "Überlauf", wenn es in einem KlickiBunti-Query-Fenster angestupst wird.
Grüße
Biber
ich weiß nicht...
Manche Probleme sollte man/frau nicht zu lösen versuchen, sondern einfach gar nicht heraufbeschwören.
1. Wenn Du die "höchste" vergebene VersNr finden willst, die mit "Dnnnn" beginnt, dann schenkt Dir das versuchte Umformen auf einen INT. nimm einfach ein "Max(VersNr)".
2. Wenn Du schon nicht darauf hören willst, dann nimm statt der schlampig hingebratzten CAST-Funktion die CInt()-Funktion
> ..Test = DLookup("MAX(CInt(RIGHT([VersNr],11) ))", "Tabelle", "LEFT(VersNr,1) = 'D'")
3. Wenn Du schon in einen INT (was auch immer Access darunter zu verstehen vorgibt) konvertieren willst, dann überprüf noch mal, ob für einen INT-Wert denn die rechten elf (11!!) Zeichen eines Strings nicht ein bisschen ruppig sind.
Ein Test mit
SELECT CInt("1234") as castedshort2int,
cint ("12345678901") as An11charsLongString
From irgendneTabelle
Grüße
Biber
Moin PCFJKG,
okay, eine "Max(VersNr)" wie von mir vorgeschlagen würde in der Tat nicht funktionieren, wenn diese "VersNr"-Strings unterschiedliche Längen haben (also "D1" existiert und auch "D12" und "D1111").
Da kommt natürlich bei der alphanummerischen MAX()-Auswertung eine andere Reihenfolge als die nach den Zahlenwerten geordnete.
Zu der Nachfrage bezüglich "der schlampig hingebratzten CAST-Funktion".
Damit meinte ich nicht Deine Umsetzung, sondern die ziemlich halbgare Implemetierung seitens der RedmonderInnen.
Das Typische dabei ist, dass "allgemein als Standard erwartete Funktionen" wie bei SQL halt CAST/CONVERT schon irgendwie umgesetzt werden, aber eben "der Form halber".
So wie bei der meisten (verkauften) Software "der Form halber" auch irgendein Hilfefenster aufpoppt wenn F1 gedrückt wird.
Also es ist schon etwas vorhanden. Aber es hat unübersehbar Potentiale.
<OT>
Ein ähnliches Dauerärgernis-Thema der "pro forma"-realisierten Standardfunktionen sind beispielsweise die bei ADO/DAO ja höchst individuell auseinanderlaufenden Methoden der RecordSet-Objekte.
Ein buchstabengleiches "rst.Find" mit einem DAO-Recordset kann ein ganz anderes Ergebnis bringen als ein "rst.Find" mt einem ADO-Object.
Und das ist nicht die Form von Kompatibilität, die ich mir erhoffe eigentlich.
</OT>
Grüße
Biber
okay, eine "Max(VersNr)" wie von mir vorgeschlagen würde in der Tat nicht funktionieren, wenn diese "VersNr"-Strings unterschiedliche Längen haben (also "D1" existiert und auch "D12" und "D1111").
Da kommt natürlich bei der alphanummerischen MAX()-Auswertung eine andere Reihenfolge als die nach den Zahlenwerten geordnete.
Zu der Nachfrage bezüglich "der schlampig hingebratzten CAST-Funktion".
Damit meinte ich nicht Deine Umsetzung, sondern die ziemlich halbgare Implemetierung seitens der RedmonderInnen.
Das Typische dabei ist, dass "allgemein als Standard erwartete Funktionen" wie bei SQL halt CAST/CONVERT schon irgendwie umgesetzt werden, aber eben "der Form halber".
So wie bei der meisten (verkauften) Software "der Form halber" auch irgendein Hilfefenster aufpoppt wenn F1 gedrückt wird.
Also es ist schon etwas vorhanden. Aber es hat unübersehbar Potentiale.
<OT>
Ein ähnliches Dauerärgernis-Thema der "pro forma"-realisierten Standardfunktionen sind beispielsweise die bei ADO/DAO ja höchst individuell auseinanderlaufenden Methoden der RecordSet-Objekte.
Ein buchstabengleiches "rst.Find" mit einem DAO-Recordset kann ein ganz anderes Ergebnis bringen als ein "rst.Find" mt einem ADO-Object.
Und das ist nicht die Form von Kompatibilität, die ich mir erhoffe eigentlich.
</OT>
Grüße
Biber