Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Reguläre ausdrücke bei der WHERE Klause!?

Empfohlene Antworten

Hallo zusammen,

ich möchte eine Abfrage mit Regulären ausdrüchen generieren.

z.B. möchte alle strings ausser <>[0,1,3] haben, so ungefähr.....ist es möglich?

Habe bis jetzt keine gescheide Doku drüber gelesen...!?

Meine DB ist MsSQL

danke im vorraus

Es geht alles ;)

Gib uns doch ein konkretes Beispiel was Du haben möchtest, dann können wir Dir helfen.

ey super,

oki, mein konkreter Fall ist:

habe ein String "T12345678": hat immer 8 stellige nummer und vorne immer die Buchstabe "T". Wenn die 5. Stelle sich ändert, dann sagt immer was aus, also ich muss sagen

WENN "T____<>[1,2]___", DANN meine Anweisung

WENN "T____<>[3,4]___", DANN meine Anweisung

...

so ungefähr

Hi,

vielleicht hilft Dir folgender Auszug aus einer SQL-Referenz.

(Quelle: http://www.in.fh-merseburg.de/~rittmeie/sql.htm)

Das LIKE-Prädikat

In dem nach LIKE angegebenen Ausdruck können Platzhalter verwendet werden. So bedeutet der Unterstrich '_' genau ein beliebiges Zeichen, das Prozentzeichen '%' steht für eine beliebig lange Zeichenkette. Beispiel: Kundendaten der Kunden, die Meierhofer, Mayerhofer oder so ähnlich heißen.

_

SELECT * FROM Kunde

WHERE name LIKE 'M__erhofer';

Bei Deinem Beispiel müsste es dann heißen:

SELECT irgendwas FROM tbl_irgendwo WHERE T-feld LIKE 'T1234_678';

Eventuell musst Du noch ein paar Abfragen verschachtelt mit reinbauen, falls sich das 1234 oder das 678 auch ändern darf.

Btw: Warum habt ihr beim DB-Design die 5. Stelle nicht in ein extra Feld gelegt? Da das IMHO ein Status o.ä. ist, wäre das der bessere / einfachere Weg.

Originally posted by kartoffeln

habe ein String "T12345678": hat immer 8 stellige nummer und vorne immer die Buchstabe "T". Wenn die 5. Stelle sich ändert, dann sagt immer was aus, also ich muss sagen

WENN "T____<>[1,2]___", DANN meine Anweisung

WENN "T____<>[3,4]___", DANN meine Anweisung

Ich würde es mit einem Substring lösen.

Also:

if substr(Feldname,5,5) not in (1,2) then...

if substr(Feldname,5,5) not in (3,4) then...

Falls sich irgendwann mal mehr als die 5. Stelle ändert (z.B. die Stellen 1 und 2), kannst Du nach dem Feldnamen die Stelle im String einsetzen, ab der verglichen werden soll: substr(Feldname,1,2).

Ich hoffe, das passt so...mein SQL ist ein bissl eingerostet. ;)

also nochmal meine Frage:

ich möchte den String nicht so "einfach" verarbeiten, sondern es MUSS in der WHERE-Klause

mit dem regulären ausdruck dementsprechen bearbeitet werden. s.o.

vielen Dank

Hallo Kartoffeln!

Bis auf Wildcards bei LIKE gibt es keine regular Expressions bei Datenbanken. Zumindest nicht bei MySQL oder Oracle und meines Wissens.

Gruß,

Florian

Originally posted by kartoffeln

ich möchte den String nicht so "einfach" verarbeiten, sondern es MUSS in der WHERE-Klause mit dem regulären ausdruck dementsprechen bearbeitet werden. s.o.

Mal ne doofe Frage: kannst Du in Deiner DB nicht ne Funktion mit einem Übergabeparameter schreiben? Wäre einfacher für Dich, dann hättest Du oben Deine SQL-Abfrage mit allen Feldern, die Du brauchst und kannst unten Deine Anweisungen sowie den Rückgabewert festlegen. Kleines Beispiel

Ansonsten kannst Du if-Abfragen und die Sache mit dem Substring genauso gut in Deine SQL-Abfrage reinfriemeln. Wird dann halt ein bissl umständlich...

Originally posted by Florian_K

Bis auf Wildcards bei LIKE gibt es keine regular Expressions bei Datenbanken. Zumindest nicht bei MySQL oder Oracle und meines Wissens.

Das ist nicht korrekt. Exakt dafür hat MySQL den REGEXP-Operator, der auch in der WHERE-Klausel verwendet werden darf.

@kartoffeln:

Um welches Datenbanksystem in welcher Version handelt es sich hier genau?

Mit mssql kann ich den MS SQL Server in Verbindung bringen, es koennte aber auch vielleicht ein Tipfehler sein und eigentlich ist MySQL gemeint.

Was stimmt nun?

Siehe dazu auch diese Ankuendigung.;)

meine DB ist NICHT MySQL, sondern MSSQL...!

Leider geht die REGEXP unter MSSQL nicht soweit ich weiss!?? Oder doch?

Gruß

@kartoffeln:

Sorry, ich hatte übersehen, dass du MSSQL benutzt... :rolleyes: Damit geht's IMHO wirklich nicht, nur die üblichen Platzhalter. :(

hi,

moechtest du werte in der tabelle fuer datensaetze mit einem zeichen an einer bestimmten stelle in einem feld aendern?

dann teile das doch auf in mehrere statements auf:

update tabelle set feld1 = neu_wert where not substr(feld2, 5, 1) in ('1', '2')

damit verlagerst du die logik aus dem sql-statement in dein programm.

hoffe, es hilft...

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.