Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

PHP Abfrage

Frage Entwicklung PHP

Mitglied: 46356

46356 (Level 2)

06.06.2008, aktualisiert 09.06.2008, 4535 Aufrufe, 5 Kommentare

Guten Abend!

Ich habe ein kleines Problem und weiß nicht, wie ich dieses nun lösen kann.
Das Problem wird sich für erfahrene User sicher leicht lösen lassen:

$x = "hallo";
$verbindung = "SELECT ... FROM ... WHERE Begriff LIKE 'hallo'";

<-- Diese Methode funktioniert!



$x = "hallo";
$verbindung = "SELECT ... FROM ... WHERE Begriff LIKE '$x'";

<-- Diese Methode funktioniert nicht!??



Was mache ich falsch?

LG. Alex
Mitglied: LordGurke
06.06.2008 um 20:51 Uhr
Variablen, die in einfachen Anführungszeichen ( ' ) stehen, werden nicht durch deren Wert ersetzt, sondern bleiben so stehen.

Damit die Methode funktioniert, müsste der String so lauten:

$verbindung = "SELECT ... FROM ... WHERE `Begriff` LIKE '.$x.'";

Da sind nun Punkte zwischen Variable und Anführungszeichen.
Bitte warten ..
Mitglied: Arano
07.06.2008 um 02:33 Uhr
Die Aussage von maxi89, wegen des einfachen Anführungszeichen, ist grundsätzlich richtig, trifft hier aber nicht ganz !

Was ich meine ist, die Variable $x steht __innerhalb von doppelten__ Anführungszeichen __in einfachen__ Anführungszeichen ( " ' $x ' " ).
Sollte eigentlich funktionieren - habe es eben auch ein bisschen getestet.

Ansonsten einfach mal den Query ausgeben und schauen was wirklich drinsteht.

Schönen Abend/Nacht noch
Arano

(Variabelnamen entsprechen ihres Inhaltes wählen)
Bitte warten ..
Mitglied: Biber
08.06.2008 um 17:09 Uhr
Moin,

Die LIKE-Suche erwartet eigentlichauch (mindestens) einen Wildcard-Platzhalter
  • ein "%" für 0, 1 oder mehrere beliebige Zeichen
  • ein "_" für genau ein Zeichen im Suchstring.

Also solltest du mit "SELECT ... FROM ... WHERE Begriff LIKE 'hallo%'"; suchen oder mit "...LIKE '%hallo%' " .

So, wie Du jetzt suchst, MUSS der Suchstring exakt "hallo" entsprechen... wird selten klappen.

Grüße
Biber
Bitte warten ..
Mitglied: 46356
08.06.2008 um 20:24 Uhr
Hallo Biber!

So, wie Du jetzt suchst, MUSS der Suchstring exakt > "hallo" entsprechen... wird selten klappen.
Bis jetzt hab ich's immer mit "LIKE" versucht.

Gibt es eine bessere Alternative, mit der ich meine Datenbank durchsuchen könnte?

LG und danke,
Alex
Bitte warten ..
Mitglied: Biber
09.06.2008 um 07:16 Uhr
Moin,

  • für eine LIKE-Suche spricht: es ist saubequem und irgendwas trifft man/frau immer
  • gegen eine LIKE-Suche spricht: es ist langsam, ineffizient, teuer, wischi-waschi und teuer... sozusagen die F.D.P. unter den SQL-Suchoperatoren.

Funktionieren würden bei einem gegebenen Spalteninhalt "Heinz",
"Heini", "Karl-Heinz" und "Heidi"
01.
Select spalte where spalte LIKE "Hei_i" 
02.
-- liefert "Heidi" und "Heini" 
03.
Select spalte where spalte LIKE "Hei%" 
04.
-- liefert "Heidi", "Heini", "Heinz" 
05.
Select spalte where spalte LIKE "%Heinz%" 
06.
--liefert "Karl-Heinz" und auch "Heinz",  
07.
-- denn "%" kann auch 0 Zeichen lang sein 
08.
Select spalte where spalte LIKE "Heinz_" 
09.
-- liefert nüscht, denn es gibt keinen Spalteninhalt,  
10.
-- der mit "Heinz" anfängt und dem ein Zeichen folgt.
--> Fazit: Finden kannst Du etwas mit LIKE, aber nötig ist eigentlich so etwas nur bei der "%teilstring%"-Suche.

In allen anderen Fällen kannst Du mit
01.
 ...where spalte >="Heid" and Spalte  <= "Heinz" 
02.
... where spalte = "exakterSuchwert"
...arbeiten, was -wenn ein Index auf dieser Spalte liegt- zwischen 3 und 30x schneller ist. Selbst wenn Du dann eine
"...Where x >= "wert1" AND x <= "Wert2" "-Bedingung benutzt.

Aber die eigentliche Frage war doch, wieso Deine LIKE-Abfrage in die Grütze ging, und da wäre meine Antwort nach wie vor: Dat liegt sich an den Wildcards, den fehlenden.

Grüße
Biber
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Batchjob Ping Abfrage fehlerhaft (2)

Frage von LukiDensi zum Thema Batch & Shell ...

Batch & Shell
Powershell-Abfrage "Die 10 meisten fehlgeschlagenen Events" (2)

Frage von KMP1988 zum Thema Batch & Shell ...

PHP
gelöst PHP - unique-array() und sort() (14)

Frage von ThomasXYZ zum Thema PHP ...

Neue Wissensbeiträge
RedHat, CentOS, Fedora

Fedora, RedHat, Centos: DNS-Search Domain setzen

(13)

Tipp von Frank zum Thema RedHat, CentOS, Fedora ...

Drucker und Scanner

Samsung SL-M4025ND, firmware update und (kompatible) Tonerkassetten

(1)

Erfahrungsbericht von markus-1969 zum Thema Drucker und Scanner ...

Heiß diskutierte Inhalte
Windows 10
Windows für Privatanwender "nicht mehr handhabbar" (33)

Frage von FA-jka zum Thema Windows 10 ...

LAN, WAN, Wireless
Komplett neues Netzwerk, Ubiquiti WLAN, Router, Switch (15)

Frage von Freak-On-Silicon zum Thema LAN, WAN, Wireless ...

RedHat, CentOS, Fedora
Fedora, RedHat, Centos: DNS-Search Domain setzen (13)

Tipp von Frank zum Thema RedHat, CentOS, Fedora ...

Backup
Backup Wochen- Monats- Jahressicherung (13)

Frage von Meterpeter zum Thema Backup ...