AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FireDac Oracle Param Abfrage mit String
Thema durchsuchen
Ansicht
Themen-Optionen

FireDac Oracle Param Abfrage mit String

Ein Thema von mlc42 · begonnen am 4. Jan 2018 · letzter Beitrag vom 5. Jan 2018
Antwort Antwort
mlc42

Registriert seit: 9. Feb 2013
135 Beiträge
 
#1

FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 16:34
Datenbank: Oracle • Version: 11g • Zugriff über: FireDAC
Hallo,

ich habe eine seltsamen Effekt. Alle Master/Detail Beziehungen in meinem Programm
die mit Params als Stringtyp angegeben sind, arbeiten unter Oracle nicht. Die Detailmenge bleibt
immer leer. Der gleiche Code funktioniert unter Firebird, MSSQL und Postgre einwandfrei.

Ein einfaches Beispiel FDConnection, FDQuery etc. auf ein Form und im SQL Designer z:B: eingeben

select * from tabelle where p.nummer = '1000' gibt die korrekte Datenmenge zurück.

mit

select * from tabelle where p.nummer = :pnum und pnum auf '1000' setzen,
kommt immer eine leere Datenmenge zurück.

Mit Integerparams geht das einwandfrei. Das Feld ist in der Tabelle mit char(16 byte) definiert.
Ich verwende nur Ansistring kein UTF (auch in der DB)

Das Verhalten tritt unter der aktuellen Tokyo und auch in einer alten Delphi2007 Maschine mit einer
der ersten FireDAC Versionen auf.

Ich bin für jeden Tip dankbar.

Martin
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.874 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 17:07
Versuch mal

select * from tabelle where TRUNC(p.nummer) = :pnum;
Markus Kinzler
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 18:01
Mit Integerparams geht das einwandfrei. Das Feld ist in der Tabelle mit char(16 byte) definiert.
CHAR wird in Oracle mit leerzeichen bis zur definierten Feldgröße aufgefüllt.
So einen Type sollte man am besten nur verwenden, wenn er immer "voll" ist, also hier ein 16stelliger Text reinkommt.

Eigentlich wird er normalerweise nicht mehr verwendet.

Um den Vergleich richtig zu machen müsstest Du das gleiche mit Deinem Parameterwert machen (Leerzeichen anhängen).

Das es mit diversen impliziten oder expliziten Konvertierungen doch zu einem Ergebnis kommt, würde ich als Seiteneffekt bezeichnen. Der wird nicht mehr helfen, wenn tatsächlich mal ein Buchstabe im String stünde (oder wofür ist das als Char definiert?)

Der Vorschlag mit Trunc, sowie ähnliche Verfahren brechen die Nutzung eines Index und sind damit nur hilfreich, wenn ein Index nicht benötigt wird.
Gruß, Jo
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.555 Beiträge
 
Delphi 7 Professional
 
#4

AW: FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 18:41
Und Trunc funktioniert nur, bis der erste Buchstabe bzw. die erste "Nichtziffer" (egal auf welcher Seite) kommt. (Und bei der dann auftretenden Fehlermeldung möchte ich nicht nach der Ursache suchen müssen, denn die Wahrscheinlichkeit, da sie auf Anhieb plausibel erscheint, dürfte eher gegen 0 tendieren.)

Dann doch lieber mit Trim und Index adé.
Oder RTrim, falls es mal mit Leerzeichen anfangen sollte.

Literatur dazu: CHAR versus VARCHAR2 Semantics
  Mit Zitat antworten Zitat
mlc42

Registriert seit: 9. Feb 2013
135 Beiträge
 
#5

AW: FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 19:32
Danke für die Tips

ich werde dann mal meine Tabellen auf varchar2 umstrukturieren. Vielleicht hilft das ja.
Seltsam nur das das nur bei Param auftritt.
Trunc würde in der Tat nicht funktioneren, weil die Kunden in diese Felder auch Alphazeichen
eingeben, daher die Wahl von Char.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.221 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: FireDac Oracle Param Abfrage mit String

  Alt 4. Jan 2018, 19:39
Und nimm bei der längenangabe auch gleich char statt byte.
Ein Oracle 8 wirst du wohl nicht mehr unterstützen müssen und mit Sonderzeichen außerhalb Ascii-7 Bit willst du sicherlich auch keine Längenprobleme bekommen.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:38 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