AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Firebird containing mit Platzhalter
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird containing mit Platzhalter

Ein Thema von Kostas · begonnen am 7. Okt 2009 · letzter Beitrag vom 7. Okt 2009
Antwort Antwort
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.058 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 14:41
Datenbank: Firebird • Version: 1.5 • Zugriff über: IBO
Hallo Zusammen,

ich möchte aus einer Adressen-Tabelle alle Adressen die beim zweiten Zeichen eine fünf haben, filtern.
Es ist also egal was das erste Zeichen ist und ebenfalls ab dem dritten Zeichen.
Ich war mir recht sicher das es mit dem "_" Operator als Platzhalten für irgend ein Zeichen geht, doch dem ist nicht so.
(Das mit der PLZ ist nur ein Beispiel zum vereinfachen)

SELECT DISTINCT D.ADRESSNR, D.plz
FROM ADRESSEN D
WHERE (D.plz containing '_5___')

Ich suche also in Verbindung mit containing ein Platzhalter für irgend ein Zeichen innerhalb einem String.

Hat jemand eine Idee?

Gruß Kostas
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.537 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 14:47
Ginge das nicht einfach mit LIKE?
SQL-Code:
SELECT DISTINCT D.ADRESSNR, D.plz
FROM ADRESSEN D
WHERE (D.plz LIKE '_5%')
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.058 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 14:53
Zitat von DeddyH:
Ginge das nicht einfach mit LIKE?
SQL-Code:
SELECT DISTINCT D.ADRESSNR, D.plz
FROM ADRESSEN D
WHERE (D.plz LIKE '_5%')

ja mit Like würde das gehen. Ich war mir so sicher das es auch mit containing geht
ich habe mich wohl geteuscht. Mit Like gehts mit containing nicht.

Delphi-Quellcode:
SELECT DISTINCT D.ADRESSNR, D.plz
FROM ADRESSEN D
WHERE (D.plz like '_5_4_')

Dankeschön
Gruß Kostas
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#4

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 15:50
Hallo Kostas,

CONTAINING ist sozusagen eine "Vereinfachung" für LIKE, bei der die Platzhalter nicht benötigt werden. Das führt aber eben dazu, dass geprüft wird, ob der Text "irgendwo" enthalten ist; und das führt dich natürlich nicht sinnvoll zum Ziel.

Gruß Jürgen
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 15:53
Selbst wenn die Platzhalter verwendet würden, wäre nicht sichergestellt das das 2. Zeichen eine 5 ist, es könnte auch das 3./4. usw. sein
Markus Kinzler
  Mit Zitat antworten Zitat
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.058 Beiträge
 
Delphi 10 Seattle Enterprise
 
#6

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 15:53
Ich habe soben in meiner Datensicherung nachgeschaut und gesehen das ich ebenfalls Like verwendet habe.
Ich hätte Haus und Hof verwetten können das es mit Containing geht.

Gruß Kostas
  Mit Zitat antworten Zitat
Kostas

Registriert seit: 14. Mai 2003
Ort: Gerstrhofen
1.058 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 15:57
Zitat von mkinzler:
Selbst wenn die Platzhalter verwendet würden, wäre nicht sichergestellt das das 2. Zeichen eine 5 ist, es könnte auch das 3./4. usw. sein
doch das geht schon indem man die volle Feldlänge nutzt.
Wenn PLZ 5 Zeichen lang ist, mit like alle fünf zeichen nutzen (D.plz like '_5_4_')
Es geht nur mit Like weil containing keine Platzhalter kennt.

Gruß Kostas
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 16:09
In diesem Fall im Allgemeinen aber nicht.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.537 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: Firebird containing mit Platzhalter

  Alt 7. Okt 2009, 16:09
Wenn ich nicht irre, bedeutet containing ja auch "irgendwo enthalten", so dass das für Deine Anforderung (5 an 2. Stelle) nicht zielführend wäre.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  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 03:49 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz