Mysql
 sql >> Baza danych >  >> RDS >> Mysql

podświetlanie wyszukiwania mysql i php

W tym bloku kodu:

//display results
while ($row = $stmt->fetch())
{
    $explode_criteria = explode(" ", $_GET['criteria']);
    foreach ($explode_criteria as $key)
    {
        $highlight = preg_replace("/" . $key . "/", "<span class='highlight'>" . $key . "</span>", $row['name']);

        echo '<td><a target="_blank" href="' . $row['url'] . '">' . $highlight . '</a></td>';
        echo '<td>' . $row['version'] . '</td>';
        echo '<td>' . $row['cat'] . '</td>';
        echo '<td>' . $row['author'] . '</td>';

        echo '<td>' . $row['added'] . '</td>';
        echo '<td>' . $row['auth_dept'] . '</td>';

        echo '<td>';
    }
}

Pętla stale odwołuje się do $row['name'] , więc zastąpienie jest wykonane, ale następnym razem, gdy wystąpi pętla, zastępuje następne słowo w oryginalnym niezmodyfikowanym $row['name']

Myślę, że to powinno ci pomóc:

//display results
while ($row = $stmt->fetch())
{
    $explode_criteria = explode(" ", $_GET['criteria']);
    $highlight = $row['name']; // capture $row['name'] here
    foreach ($explode_criteria as $key)
    {
        // escape the user input
        $key2 = preg_quote($key, '/');
        // keep affecting $highlight
        $highlight = preg_replace("/" . $key2 . "/", "<span class='highlight'>" . $key . "</span>", $highlight);

        echo '<td><a target="_blank" href="' . $row['url'] . '">' . $highlight . '</a></td>';
        echo '<td>' . $row['version'] . '</td>';
        echo '<td>' . $row['cat'] . '</td>';
        echo '<td>' . $row['author'] . '</td>';

        echo '<td>' . $row['added'] . '</td>';
        echo '<td>' . $row['auth_dept'] . '</td>';

        echo '<td>';
    }
}



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQLSTATE[HY000] [2002] php_network_getaddresses:getaddrinfo nie powiodło się:podana nazwa węzła lub nazwa serwera lub nieznana

  2. Uzyskaj rozkład częstotliwości zakresu dziesiętnego w MySQL

  3. Grails 2.4.4 Tworzenie i upuszczanie DataSource nie powoduje usunięcia wszystkich tabel z FK

  4. Użyj pełnego kalendarza bez daty

  5. Odpowiednik daty i godziny w java.sql ? (czy istnieje java.sql.datetime ?)