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

PHP Abfrage

Frage Entwicklung PHP

Mitglied: 46356

46356 (Level 2)

06.06.2008, aktualisiert 09.06.2008, 4590 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
PHP
Mit PHP SQL Array Abfrage
gelöst Frage von gamerffPHP3 Kommentare

Hallo Forum, ich bin grade an einem Projekt dran ein Telefonbuch mit Mysql, PHP und HTMl zu erstellen. Ich ...

PHP
PHP mdb Abfragen
gelöst Frage von geocastPHP5 Kommentare

Hallo zusammen Ich konstruiere gerade eine Webseite, auf der kann man Namen auswählen und E-Mails verschicken bzw. auch SMS. ...

PHP
Mit PHP eine Telnet abfrage machen und ausgeben
Frage von helmuthelmut2000PHP1 Kommentar

Hallo, Ich möchte folgendes machen und hätte da etwas Hilfe gebraucht. Ich habe an meiner Heizung einen Optolink Adapter ...

PHP
PHP Dropdownmenü mit SQL-Abfrage
gelöst Frage von tobmesPHP4 Kommentare

Hi Experten, ich glaube mein Titel ist etwas verwirrend, aber mir fällt gerade nichts besseres ein :) Also hier ...

Neue Wissensbeiträge
Erkennung und -Abwehr

Sicherheitslücke Spectre und Meltdown: Status prüfen

Anleitung von Frank vor 3 StundenErkennung und -Abwehr

Nach all den Updates der letzten Woche sollte man unbedingt auch den Status prüfen, ob die Sicherheitslücke Spectre und ...

Microsoft Office

Office 2010 Starter erneut auf einer frischen Windows-Version installieren

Tipp von Lochkartenstanzer vor 1 TagMicrosoft Office9 Kommentare

Moin, vor ein paar Tagen schlug bei mir ein Kunde auf, der sein Widnows 7 geschrottet und es inklusive ...

Datenbanken

Upgrade MongoDB 3.4 auf 3.6

Erfahrungsbericht von Frank vor 1 TagDatenbanken

Seit kurzem gibt es das 3.6 Update für die MongoDB: Sicherheit, das Sortieren, Aggregation und auch die Performance wurde ...

SAN, NAS, DAS

Backdoor Zugang und Upload-Bug in vielen Western Digital MyCloud Geräten

Information von Frank vor 1 TagSAN, NAS, DAS2 Kommentare

James Bercegay von der Firma Gulftech hat die Fehler an Western Digital gemeldet und das Unternehmen stellt bereits ein ...

Heiß diskutierte Inhalte
Netzwerke
NTFS-Berechtigung
Frage von Daoudi1973Netzwerke23 Kommentare

Hallo zusammen und frohes neues Jahr (Sorry, ich bin spät dran) Meine Frage: 1- Ich habe einen Ordner im ...

Drucker und Scanner
Gesucht DIN A3 Drucker
Frage von NebellichtDrucker und Scanner15 Kommentare

Hallo, ich möchte einen neuen DIN A3 Drucker kaufen. Um ab und zu, ca. 1 mal die Woche Farbausdrucke ...

iOS
Einladung vom iphone kalender
Frage von jensgebkeniOS15 Kommentare

Hallo Gemeinschaft, folgendes Problem - immer wenn ich von meinem Iphone einen Termin einztrage und diesem Termin Teilnehmer zuweise, ...

Windows Netzwerk
Drucker isolieren in Windows Domäne
gelöst Frage von lcer00Windows Netzwerk14 Kommentare

Hallo zusammen, habe eine Windows-AD (2012R2) in der es einen Druckerserver gibt. Mittlerweile verliere ich das Vertrauen in die ...