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, 4515 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 ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(1)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
PHP
MySQL-Abfrage mit php: Wert + true bzw. false (2)

Frage von tomolpi zum Thema PHP ...

PHP
gelöst PHP Dropdownmenü mit SQL-Abfrage (4)

Frage von tobmes zum Thema PHP ...

Datenbanken
gelöst SQL-Abfrage - DISTINCT - letztes Datum (3)

Frage von emeriks zum Thema Datenbanken ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
gelöst Server erkennt Client nicht wenn er ausserhalb des DHCP Pools liegt (28)

Frage von Mar-west zum Thema LAN, WAN, Wireless ...

Outlook & Mail
Outlook 2010 findet ost datei nicht (18)

Frage von Floh21 zum Thema Outlook & Mail ...

Windows Server
Server 2008R2 startet nicht mehr (Bad Patch 0xa) (18)

Frage von Haures zum Thema Windows Server ...