PHP-Einfach.de
  • PHP Tutorial
  • MySQL Tutorial
  • Für Fortgeschrittene
  • Webhosting
  • Forum

Codeschnipsel

komplette SQL DB nach einem Ausdruck durchsuchen

Zurück zur Übersicht
Diese Funktion durchsucht eine beliebige SQL Datenbank komplett nach einem Suchwort.

In meinem kleinem Auftragsverwaltungsprogramm ist es manchmal nötig die komplette Datenbank nach einem bestimmten Wort zu durchsuchen (Name, Strasse, Auftragsnummer etc.) Bei mehr als 20 Spalten natürlich immer etwas umständlich eine SQL Abfrage zu formulieren.
Die kleine Funktion erledigt das jetzt für mich:

<?php
require_once "mysql_connect.php";      //Include um Verbindung zu DB aufzubauen, sollte klar sein
                                    //die Funktion für eine SQL Abfrage heisst hier do_query()
                                    
$table = "tabelle";                //hier muss natürlich der Tabellenname angegeben werden



function alt_f ($table,$searchstring) {
    
$cols = do_query("SHOW COLUMNS FROM $table");      //gibt die Spaltennamen aus
    
if (!$cols) {
        die (
'Abfrage konnte nicht ausgeführt werden: ' . mysql_error());
    }
    
    
$string = "";                                        //nen paar Variablen initialisieren
    
$i = 0;
    if (
mysql_num_rows($cols) > 0) {                    // die einzelnen Spaltennamen durchlaufen
        
while ($row = mysql_fetch_assoc($cols)) {          //gibt den Spaltennamen aus
            
$i++;                                        //mitzählen
               
$string .= "`".$row[Field]."` LIKE '%$searchstring%'" ;        //fügt die Anweisung für die SQL Abfrage zusammen
               
if ($i < mysql_num_rows($cols)) $string .= " OR ";            //damit am Ende kein weiteres OR steht wird das letzte
        
}                                                                //nicht angefügt
    
}
    
    
$result = do_query(" SELECT * FROM `$table` WHERE $string ");        //stellt die SQL Anfrage mit dem eben gebastelten Suchstring
    
if (mysql_num_rows($result) > 0) {
        while(
$row = mysql_fetch_assoc($result)) {                        //Array aus Ergebnissen bilden
            
$data[] = $row;
        }
        return (
$data);                                                    //Array zurückgeben
    
}
    else return(
false);                                                    //bzw. ein False wenn die Suche erfolglos war
}


if (
$searchstring=$_POST[searchstring]) {                                //ab hier nur Script zum ausprobieren der Funktion
    
if ($result=alt_f($table,$searchstring)) {
        echo 
"Die Suche ergab ".count($result)." Ergebnisse<br>";
        foreach (
$result as $value) {
            
print_r($value); echo "<br>";
        }
    }
    else echo 
"Keine Ergebnisse";
}
else {
    echo 
'<form action="alt_f.php" Method="post"><br>
    Suchwort: <input type="text" Name="searchstring"><br>
    <input type="submit"></form>'
;
}
?>


Diese Funktion gibt jetzt aber gleich das Suchergebnis als Array zurück, wenn man aber nur den entsprechenden Suchstring gebastelt haben möchte, kann man das mit einigen kleinen Änderungen:

<?php
    
function alt_f ($table,$searchstring) {
        
$cols = do_query("SHOW COLUMNS FROM $table");      //gibt die Spaltennamen aus
        
if (!$cols) {
            die (
'Abfrage konnte nicht ausgeführt werden: ' . mysql_error());
        }
        
        
$string = "";                                        //nen paar Variablen initialisieren
        
$i = 0;
        if (
mysql_num_rows($cols) > 0) {                    // die einzelnen Spaltennamen durchlaufen
            
while ($row = mysql_fetch_assoc($cols)) {          //gibt den Spaltennamen aus
                
$i++;                                        //mitzählen
                   
$string .= "`".$row[Field]."` LIKE '%$searchstring%'" ;        //fügt die Anweisung für die SQL Abfrage zusammen
                   
if ($i < mysql_num_rows($cols)) $string .= " OR ";            //damit am Ende kein weiteres OR steht wird das letzte
            
}                                                                //nicht angefügt
        
}
        return(
$string);  //gibt den Suchstring zurück
    
}
?>


Die Abfrage müsste dann aber noch komplettiert werden und kann dann noch entsprechend angepasst werden:
<?php
$suchstring 
= alt_f($table,$meinesuche);
$q = do_query (" SELECT * FROM `$table` WHERE ". $suchstring. " DESC LIMIT(1,1) ");
?>


Kommentare

Autor Crisma

Zurück zur Übersicht
Autor: Nils Reimers
Zurück: URLs im Text identifizieren

Für Fortgeschrittene

  • Objektorientierte Programmierung
  • PHP Sicherheit
  • Script-Beispiele
  • Codeschnipsel
  • Stellenmarkt
Mit freundlicher Unterstützung von:
  • Punkt191 Werbeagentur
  • CasinoAndy Finland
  • Casinoohnelizenz.info
  • Cryptocasinomaster.com
  • CasinoHEX.at
  • inkedin.com

Hoster – Geringste Ausfallzeit

  1. webgo Ø 1 Min.
  2. Linevast Ø 2 Min.
  3. netcup Ø 3 Min.
  4. All-Inkl.com Ø 6 Min.
  5. checkdomain Ø 8 Min.
  6. dogado Ø 17 Min.
  7. bplaced Ø 17 Min.
  8. Contabo Ø 25 Min.
  9. Hetzner Ø 49 Min.
  10. ONE.com Ø 62 Min.
» Mehr erfahren

Impressum | Datenschutz | Auf PHP-Einfach.de werben

© PHP-Einfach.de 2003 - 2023

Cookie-Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
Optionen verwalten Dienste verwalten Anbieter verwalten Lese mehr über diese Zwecke
Einstellungen ansehen
{title} {title} {title}