• Resolved itcgpit

    (@itcgpit)


    i want Order by meta value, pro first, then free as well as pro in randowm order.

    query_posts($query_string . ‘&meta_value=pro&orderby=rand’);

    I get pro list with random, but I want pro as well as free, but with pro list first, then meta_value free list.

    I also set orderby meta_value

    query_posts($query_string . ‘&orderby=meta_value_num’);

    This does not work, and in query string default for cat. It will take orderby date with both meta value = pro and free.

    Any suggestions?
    query-posts

Viewing 8 replies - 1 through 8 (of 8 total)
  • Moderator keesiemeijer

    (@keesiemeijer)

    Hi itcgpit.

    Try it by adding a filter to the ‘posts_orderby’ clause.
    https://codex.www.ads-software.com/Plugin_API/Filter_Reference/posts_orderby

    In this example I’ve used the meta key ‘product_type’. All posts will be random but with the product_type value ‘pro’ showing up first.

    Use a new WP_Query like this in your theme template files:

    <?php
    // query arguments for posts with a custom field 'product_type'
    $args = array(
    	'ignore_sticky_posts' => 1, // ignore sticky posts
    	'meta_query' => array(
    		array(
    			'key' => 'product_type', // custom field key with values free and pro
    		)
    	),
    );
    
    // add the filter before the query
    add_filter( 'posts_orderby', 'order_by_meta_key' );
    
    // the query
    $query = new WP_Query( $args );
    
    // remove the filter after the query
    remove_filter( 'posts_orderby', 'order_by_meta_key' );
    ?>

    https://codex.www.ads-software.com/Function_Reference/WP_Query

    And add this to your theme’s function.php

    function order_by_meta_key( $orderby ) {
        global $wpdb;
    
        // order by  'pro' values first, then random
        $orderby = "$wpdb->postmeta.meta_value = 'pro' DESC, rand()";
    
        return $orderby;
    }

    btw:
    consider creating a child theme instead of editing your theme directly – if you upgrade the theme all your modifications will be lost.

    Thread Starter itcgpit

    (@itcgpit)

    thanks sir for reply

    first i add your code with my meta key = j_listing_type then i print query and it say fun not define so i add your code in theme -> function.php file butstill in result – it order by below.
    plz solve this thanks. sir ??
    GROUP BY wp_posts.ID ORDER BY wp_posts.post_date DESC LIMIT 0, 10

    my post type is – listing
    meta key = J_listing
    meta_value pro and free

    Moderator keesiemeijer

    (@keesiemeijer)

    Try adding the post type and meta key to the query arguments.

    $args = array(
    	'post_type'           => 'listing',
    	'ignore_sticky_posts' => 1, // ignore sticky posts
    	'meta_query'          => array(
    		array(
    			'key' => 'J_listing', // custom field key with values free and pro
    		)
    	),
    );

    Thread Starter itcgpit

    (@itcgpit)

    still same error .
    GROUP BY wp_posts.ID ORDER BY wp_posts.post_date DESC LIMIT 0, 10

    ya but if i remove from function that time it say order_metavalue not found in plugin.php so should i add that function.php code in plugin.php file ?

    thanks plz help. ??

    Moderator keesiemeijer

    (@keesiemeijer)

    Are you sure the meta key (j_listing_type or J_listing) and post type (listing) are correct?

    The function order_by_meta_key() goes in your theme’s functions.php.

    Or create a plugin with the function code in it.

    Try changing this?

    // add the filter before the query
    add_filter( 'posts_orderby', 'order_by_meta_key' );
    
    // the query
    $query = new WP_Query( $args );
    
    // remove the filter after the query
    remove_filter( 'posts_orderby', 'order_by_meta_key' );

    to this:

    // add the filter before the query
    add_filter( 'posts_orderby', 'order_by_meta_key', 999 );
    
    // the query
    $query = new WP_Query( $args );
    
    // remove the filter after the query
    remove_filter( 'posts_orderby', 'order_by_meta_key', 999 );

    Thread Starter itcgpit

    (@itcgpit)

    Thank you so much you made my day ?? love you wordpress ?? thanks sir

    Thread Starter itcgpit

    (@itcgpit)

    thanks sir now i want to implement order by metavalue same in my search function too.
    but search fun dont havel loop so i need to change it from module-function file.
    so help me on that.

    public fun mulit-search

    if () …query ..else if query…. etc

    $results = array();
    $results[‘result’] = $wpdb->get_results( $query );
    $results[‘query’] = $wpdb->query( $query );
    return $results;
    above is my search func.
    write now in search its GROUP BY $wpdb->posts.ID {$limit} .. i try to add it order by in last in if and else if but it will not work. so plz help me thanks again. ??

    Thread Starter itcgpit

    (@itcgpit)

    hi .. any update.. ! in my function

    function j_multi_search( $sfrom, $location, $limit = null ) {
    global $wpdb;
    if ( !empty( $sfrom ) || !empty( $location ) )
    $n = ‘%’;
    $post_type = POST_TYPE;
    $post_status = ‘publish’;
    $meta_key = “j_address”;

    so i added more $meta_key2 = ‘j_listing_type’;
    $meta_val2 = array(‘pro’,’free’);

    but still it will not take as order by.. any idea. help plz thanks. give me your email id ??

Viewing 8 replies - 1 through 8 (of 8 total)
  • The topic ‘Order by meta value, pro first, then free’ is closed to new replies.