Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst Jokerzeichen In einem Suchformular

Mitglied: helmuthelmut2000

helmuthelmut2000 (Level 2) - Jetzt verbinden

16.11.2007, aktualisiert 17.11.2007, 5946 Aufrufe, 2 Kommentare

Hallo,

Ich habe da ein Problem in meinem Suchformular.

Da habe ich ein paar Felder wo man Werte eingeben sollte.
Und das wird dann aus einer MSSQL-DB ausgegeben.
Die ausgabe mach ich so:


(select * from Ergebnisse WHERE Artikelnummer='".$_POST["Artikelnummer"]."' AND Material='".$_POST["Material"]."' AND Abmessung='".$_POST["Abmessung"]."'"

Das AND dazwischen sagt doch, Das dieses dann ausgegeben wird, was man da eingibt.
Gibt es da auch ein Jokerzeichen z.B. * oder % ?
Wenn es mir z.b. alles was in Material und Abmessung eingegeben ist ausgibt, das ich dann in Artikelnummern leer lassen kann. Ich sollte aber auch in Artikelnummer was eingeben können.

Wisst ihr wie ich das mein?
Muß ich da in dem select schon wo das % einfügen?
Aber wo?

Danke.

Gruß
Helmut
Mitglied: Biber
17.11.2007 um 02:00 Uhr
Moin Helmuthelmut2000,

allgemein zu Jokerzeichen in den SQL-Dialekten inclusive mySQL:

  • für ein, mehrere Zeichen oder kein Zeichen steht das Prozentzeichen (%)
  • für (jeweils) ein Zeichen steht der Unterstrich (_)
  • beide Jokerzeichen kommen nur zum Tragen in Verbindung mit dem LIKE-Operator.

01.
select * from Ergebnisse  
02.
    WHERE Artikelnummer LIKE 'XYZ%'  
03.
         AND Material LIKE '%BLECH%'  
04.
         AND Format LIKE 'DIN A_';
Wobei anzumerken ist:
  • ein LIKE in der Where-Klausel ist langsam, zwei sind MEHR als doppelt so lahm, drei LIKEs würde ich nur nehmen, wenn Du nebenbei noch etwas anderes Sinnvolles machen kannst...telefonieren oder Kaffee aufsetzen oder so.
  • wenn denn aus welchen Gründen auch immer auch immer mehrere LIKEs unabwendbar sein sollten, dann ist es performanter, statt mehreren LIKE..AND..LIKE..AND LIKE's nur ein einziges LIKE auf einen Gesamtstring zu machen.
01.
select * from Ergebnisse  
02.
    WHERE Artikelnummer || Material || Format  
03.
          LIKE 'XYZ%' || 'BLECH%' || 'DIN A_';
  • in der Regel werden die Jokerzeichen in der GUI/im Formular schon so eingegeben, wie der geehrte User es von M$ gewohnt ist:
  • als "*" für beliebige und beliebig viele Zeichen
  • als "?" für ein beliebiges Zeichen.
  • Die Umsetzung machst Du dann mit Replace(Replace(eingebenerString,"*","%"). "?"."_") oder sinngemäß.

Ich verschiebe den Beitrag mal nach von "Entwicklung" nach "Datenbanken".

Grüße
Biber
Bitte warten ..
Mitglied: helmuthelmut2000
17.11.2007 um 18:11 Uhr
Hallo,

Danke,

Alles klar, hat so einwandfrei funktioniert.

Gruß
Helmut
Bitte warten ..
Neue Wissensbeiträge
Internet

Datendealing im WWW Tracking Methoden immer brutaler

Information von sabines vor 2 StundenInternet

Interessanter Artikel zum Thema Tracking im WWW und die immer "besseren" Methoden des Trackings. Professor Arvind Narayanan (Princeton-Universität) betreibt ...

Erkennung und -Abwehr

Ups: Einfaches Nullzeichen hebelte den Anti-Malware-Schutzt in Windows 10 aus

Information von kgborn vor 14 StundenErkennung und -Abwehr

Windows 10 ist das sicherste Windows aller Zeiten, wie Microsoft betont. Insidern ist aber klar, das es da Lücken, ...

Windows 10

Windows 10 on ARM: von Microsoft entfernte Info - Klartext, was nicht geht

Information von kgborn vor 16 StundenWindows 10

Windows 10 on ARM ist ja eine neue Variante, die Microsoft im Verbund mit Geräteherstellern am Markt etablieren will. ...

Microsoft
TV-Tipp: Das Microsoft-Dilemma
Information von kgborn vor 17 StundenMicrosoft10 Kommentare

Aktuell gibt es in Behörden und in Firmen eine fatale Abhängigkeit von Microsoft und dessen Produkten. Planlos agieren die ...

Heiß diskutierte Inhalte
Windows 10
Windows 10 (1709) Tastur und Maus wieder einschalten?
Frage von LochkartenstanzerWindows 1026 Kommentare

Moin, Ich habe von einem Kunden einen Win10-Rechner bekommen, bei dem weder Tastatur noch Maus geht. Die Hardware funktioniert ...

Server
Route-Befehl Unterstützung (unter CMD)
gelöst Frage von FKRR56Server17 Kommentare

Guten Tag , i.M. habe ich Probleme über den CMD-Route-Befehl ein Routing auf einen entfernten Server zuzulassen. Der Server ...

Firewall
RB2011 Firewall Rule eine bestimmte Mac oder IP Adresse nicht zu blockieren
Frage von lightmanFirewall15 Kommentare

Hallo liebes Forum mit ihren Spezialisten. Ich habe meine Firewall so konfiguriert das kein Endgerät ohne meine Speziellen Erlaubnis ...

Humor (lol)
Was könnte man mit einem Server machen? Idee gesucht
Frage von 2SeitenHumor (lol)15 Kommentare

Hey Zusammen Ich habe einen alten HP G2 Rackserver zu Hause rumliegen. 28GB Ram, 1xAMD Prozi mit etwa 2GHz. ...