Get Post Title Outside “The Loop”

Getting individual post data outside the loop can be difficult, but you can quickly get the information you want if you have the id of the post you are trying to get information from:

Use the following code to get the information:

global $wpdb;
$postid='1'; // replace this with the postid you are trying to access.
$postdata= $wpdb->get_results("SELECT * FROM $wpdb->posts WHERE ID=$postid");

NOTE: As Milan has pointed out, it is not the best method for this, this is the suggested method instead:

$postdata = get_post($postid);

To access and use the data is equally easy, here are some examples to get you started:

echo $postdata->post_title; //The title of the post
echo $postdata->post_content; //The content of the post

There is other useful information you can grab via this method:

  • post_author
  • post_date
  • post_date_gmt
  • post_content
  • post_title
  • post_category
  • post_excerpt
  • post_status,
  • comment_status
  • ping_status
  • post_password
  • post_name
  • to_ping
  • pinged
  • post_modified
  • post_modified_gmt
  • post_content_filtered
  • post_parent
  • guid
  • menu_order
  • post_type
  • post_mime_type
  • comment_count

9 Comments

  1. Milan Petrovic on 04/11/2009 at 03:37

    This is actually not the best method for this. Much better is to use WordPress function:

    $postdata = get_post($postid);

    This function uses internal WordPress object cache, and if the post you need is already in the cache you save on running unneeded query. Object is the same as with your method and all returned properties the same.
    .-= Milan Petrovic´s last blog ..New website res4WP.com =-.

    • cleverplugins.com on 04/11/2009 at 07:02

      Hi Milan

      Thank you for that function! That does indeed make it a lot easier, and as you say, if its already in the cache it is much faster. In cases where a lot of posts could be queried it would be good.

      One note however, if in cases where you are only interested in for instance the title of a range of posts, would it not be faster to use my original query solution, modified to only return the title from the database, or would get_post() still be better/faster?

      Thank you for adding valuable insights to my ramblings! 🙂



    • Milan Petrovic on 04/11/2009 at 07:16

      If the post is already cached it will be faster to use get_post, also get_post will cache post if it is not already. Also, such simple queries are fast do execute. But I try to avoid such coding because it is easier to do, but later is much more complicated to change and clean up.

      Since I spend a lot of time optimizing GD Star Rating plugin and adding various caching methods, I have measured all kinds of things, and the conclusion is that the best thing is to have less DB queries. They are very fast, but take into the account total number of queries executed, and it’s best to find the way to minimize that. GD Star Rating pre 1.5 versions needed some 150 queries for 10 posts because it was executing queries as they were needed. Now it needs less then 10 queries for the same 10 posts.



    • cleverplugins.com on 04/11/2009 at 10:13

      150 down to less than 10? That is what I call improvement! 🙂



  2. Dave L on 15/11/2009 at 08:08

    I am sorry but what is this supposed to do? “outside the loop” of what exactly?

  3. George Langley on 15/04/2010 at 15:02

    Thank you! I couldn’t believe the amount of time I had to spend to find such a simple solution.
    Was trying to limit the length of the title of the Previous and Next posts (without the need for plugins), since previous_post_link() and next_post_link() are so limited. The following should give anyone else looking for a solution enough of an idea.

    $prev_post = get_adjacent_post(false, '', true);
    $prev_post_link = ($prev_post ? get_permalink( $prev_post->ID ) : "");
    $prev_post_title = $prev_post->post_title;
    $next_post = get_adjacent_post(false, '', false);
    $next_post_link = ($next_post ? get_permalink( $next_post->ID ) : "");
    $next_post_title = $next_post->post_title;
    echo "$prev_post_link$prev_post_title$next_post_link$next_post_title";
    $prev_post_title = substr(($prev_post_title=wordwrap($prev_post_title,25,'n')),0,strpos($prev_post_title,'n'));
    $next_post_title = substr(($next_post_title=wordwrap($next_post_title,25,'n')),0,strpos($next_post_title,'n'));
    echo "$prev_post_title$next_post_title";
    
    • cleverplugins.com on 17/04/2010 at 07:08

      Hi George

      Thanks for dropping by and leaving that piece of code, that is gonna come in handy at some point, I am sure! 🙂



  4. handpaintportrait on 04/10/2010 at 05:22

    Nice,Tks for sharing.

Leave a Comment





Cleverplugins.com Newsletter

Articles about how to improve your WordPress website, how to get more traffic and most importantly more customers.

Subscribe

Something went wrong. Please check your entries and try again.