Come limitare la ricerca ai titoli dei post?

12 mar 2011, 16:06:33
Visualizzazioni: 31K
Voti: 29

Esiste un modo per limitare la ricerca solo ai titoli dei post? So che posso modificare il file core query.php ma deve esserci un modo per farlo utilizzando i hook, giusto?

Grazie in anticipo!

0
Tutte le risposte alla domanda 1
8
39

Ecco un filtro che farà al caso tuo. Inseriscilo nel file functions.php del tuo tema o in un plugin.

/**
 * Filtro SQL per la ricerca solo nel titolo del post.
 *
 * @link    http://wordpress.stackexchange.com/a/11826/1685
 *
 * @param   string      $search
 * @param   WP_Query    $wp_query
 */
function wpse_11826_search_by_title( $search, $wp_query ) {
    if ( ! empty( $search ) && ! empty( $wp_query->query_vars['search_terms'] ) ) {
        global $wpdb;

        $q = $wp_query->query_vars;
        $n = ! empty( $q['exact'] ) ? '' : '%';

        $search = array();

        foreach ( ( array ) $q['search_terms'] as $term )
            $search[] = $wpdb->prepare( "$wpdb->posts.post_title LIKE %s", $n . $wpdb->esc_like( $term ) . $n );

        if ( ! is_user_logged_in() )
            $search[] = "$wpdb->posts.post_password = ''";

        $search = ' AND ' . implode( ' AND ', $search );
    }

    return $search;
}

add_filter( 'posts_search', 'wpse_11826_search_by_title', 10, 2 );

La maggior parte del codice è semplicemente copiato dalla classe WP_Query, ad eccezione della rimozione dei post_content LIKE.

AGGIORNAMENTO: Rimosso il deprecato like_escape() dalla versione 4.0

12 mar 2011 16:51:08
Commenti

fantastico, funziona perfettamente, sapevo che c'era un filtro per questo, ma non riuscivo a trovarlo da nessuna parte nel codex, grazie mille!

Javier Villanueva Javier Villanueva
12 mar 2011 18:19:23

@TheDeadMedic ho appena provato sul mio blog e quella particolare query ora non restituisce alcun risultato, con o senza questo codice. Hai qualche idea?

Ashfame Ashfame
4 ago 2011 02:37:00

Ora sta funzionando come al solito senza il codice ma il codice non ha funzionato per me. Mostrava gli stessi risultati :/

Ashfame Ashfame
4 ago 2011 10:32:42

@Ashfame Ho rivisto la mia risposta.

TheDeadMedic TheDeadMedic
4 ago 2011 15:44:44

Grazie, funziona bene, se rimuovi {$n} vicino a {$term} effettua una ricerca esatta. Ma c'è un problema che non cerca termini con spazi come "succo di mela". Però cerca mela.

User User
16 dic 2011 14:12:03

Sì, se rimuovi {$n}, stai rimuovendo l'iniezione della stringa con caratteri jolly. Lascia il codice così com'è e usa l'argomento della query URL exact=1 per controllare se la ricerca è approssimativa o esplicita.

TheDeadMedic TheDeadMedic
16 dic 2011 19:58:17

Messaggio PHP: Errore fatale PHP: Chiamata a metodo non definito wpdb::esc_like() --- Se hai una versione vecchia di WordPress, questa è una nuova funzione introdotta in WP 4.0

Jay Brunet Jay Brunet
10 nov 2015 01:14:13

Invece di un LIKE, potrei fare una ricerca con regex? Il modello del mio titolo è un po' più complesso... Immagino sia una domanda diversa ma apprezzo qualsiasi suggerimento. grazie

Drewdavid Drewdavid
23 nov 2019 08:12:28
Mostra i restanti 3 commenti